Daemon devices() can now filter by visible and/or paired

visibleDevices() is not needed anymore and has been removed
This commit is contained in:
Albert Vaca 2014-01-16 12:14:05 +01:00
parent c70f2555f1
commit 3073e66bb3
3 changed files with 12 additions and 24 deletions

View file

@ -123,22 +123,17 @@ void Daemon::forceOnNetworkChange()
} }
} }
QStringList Daemon::visibleDevices() QStringList Daemon::devices(bool onlyReachable, bool onlyVisible)
{ {
QStringList ret; QStringList ret;
Q_FOREACH(Device* device, mDevices) { Q_FOREACH(Device* device, mDevices) {
if (device->isReachable()) { if (onlyReachable && !device->isReachable()) continue;
if (onlyVisible && !device->isPaired()) continue;
ret.append(device->id()); ret.append(device->id());
} }
}
return ret; return ret;
} }
QStringList Daemon::devices()
{
return mDevices.keys();
}
void Daemon::onNewDeviceLink(const NetworkPackage& identityPackage, DeviceLink* dl) void Daemon::onNewDeviceLink(const NetworkPackage& identityPackage, DeviceLink* dl)
{ {

View file

@ -52,8 +52,7 @@ public Q_SLOTS:
Q_SCRIPTABLE void forceOnNetworkChange(); Q_SCRIPTABLE void forceOnNetworkChange();
//Returns a list of ids. The respective devices can be manipulated using the dbus path: "/modules/kdeconnect/Devices/"+id //Returns a list of ids. The respective devices can be manipulated using the dbus path: "/modules/kdeconnect/Devices/"+id
Q_SCRIPTABLE QStringList devices(); //All known devices Q_SCRIPTABLE QStringList devices(bool onlyReachable = false, bool onlyVisible = false);
Q_SCRIPTABLE QStringList visibleDevices(); //Only visible devices
Q_SIGNALS: Q_SIGNALS:
Q_SCRIPTABLE void deviceAdded(const QString& id); Q_SCRIPTABLE void deviceAdded(const QString& id);

View file

@ -112,27 +112,21 @@ void DevicesModel::refreshDeviceList()
return; return;
} }
QDBusPendingReply<QStringList> pendingDeviceIds = m_dbusInterface->devices();
pendingDeviceIds.waitForFinished();
if (pendingDeviceIds.isError()) return;
const QStringList& deviceIds = pendingDeviceIds.value();
Q_FOREACH(const QString& id, deviceIds) {
DeviceDbusInterface* deviceDbusInterface = new DeviceDbusInterface(id,this);
bool onlyPaired = (m_displayFilter & StatusPaired); bool onlyPaired = (m_displayFilter & StatusPaired);
if (onlyPaired && !deviceDbusInterface->isPaired()) continue;
bool onlyReachable = (m_displayFilter & StatusReachable); bool onlyReachable = (m_displayFilter & StatusReachable);
if (onlyReachable && !deviceDbusInterface->isReachable()) continue;
QDBusPendingReply<QStringList> pendingDeviceIds = m_dbusInterface->devices(onlyReachable, onlyPaired);
pendingDeviceIds.waitForFinished();
if (pendingDeviceIds.isError()) return;
const QStringList& deviceIds = pendingDeviceIds.value();
Q_FOREACH(const QString& id, deviceIds) {
int firstRow = m_deviceList.size(); int firstRow = m_deviceList.size();
int lastRow = firstRow; int lastRow = firstRow;
beginInsertRows(QModelIndex(), firstRow, lastRow); beginInsertRows(QModelIndex(), firstRow, lastRow);
m_deviceList.append(deviceDbusInterface); m_deviceList.append(new DeviceDbusInterface(id,this));
endInsertRows(); endInsertRows();
} }
Q_EMIT dataChanged(index(0), index(m_deviceList.size())); Q_EMIT dataChanged(index(0), index(m_deviceList.size()));