Emit less redundant events
This commit is contained in:
parent
f71f498125
commit
08938689c5
3 changed files with 23 additions and 18 deletions
|
@ -127,7 +127,11 @@ void Daemon::onNewDeviceLink(const NetworkPackage& identityPackage, DeviceLink*
|
||||||
if (d->mDevices.contains(id)) {
|
if (d->mDevices.contains(id)) {
|
||||||
//qCDebug(KDECONNECT_CORE) << "It is a known device";
|
//qCDebug(KDECONNECT_CORE) << "It is a known device";
|
||||||
Device* device = d->mDevices[id];
|
Device* device = d->mDevices[id];
|
||||||
|
bool wasReachable = device->isReachable();
|
||||||
device->addLink(identityPackage, dl);
|
device->addLink(identityPackage, dl);
|
||||||
|
if (!wasReachable) {
|
||||||
|
Q_EMIT deviceVisibilityChanged(id, true);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
//qCDebug(KDECONNECT_CORE) << "It is a new device";
|
//qCDebug(KDECONNECT_CORE) << "It is a new device";
|
||||||
|
|
||||||
|
@ -137,8 +141,6 @@ void Daemon::onNewDeviceLink(const NetworkPackage& identityPackage, DeviceLink*
|
||||||
|
|
||||||
Q_EMIT deviceAdded(id);
|
Q_EMIT deviceAdded(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
Q_EMIT deviceVisibilityChanged(id, true);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Daemon::onDeviceReachableStatusChanged()
|
void Daemon::onDeviceReachableStatusChanged()
|
||||||
|
@ -146,21 +148,17 @@ void Daemon::onDeviceReachableStatusChanged()
|
||||||
Device* device = (Device*)sender();
|
Device* device = (Device*)sender();
|
||||||
QString id = device->id();
|
QString id = device->id();
|
||||||
|
|
||||||
Q_EMIT deviceVisibilityChanged(id, device->isReachable());
|
qCDebug(KDECONNECT_CORE) << "Device" << device->name() << "status changed. Reachable:" << device->isReachable() << ". Paired: " << device->isPaired();
|
||||||
|
|
||||||
//qCDebug(KDECONNECT_CORE) << "Device" << device->name() << "reachable status changed:" << device->isReachable();
|
|
||||||
|
|
||||||
if (!device->isReachable()) {
|
|
||||||
|
|
||||||
if (!device->isPaired()) {
|
|
||||||
|
|
||||||
qCDebug(KDECONNECT_CORE) << "Destroying device" << device->name();
|
|
||||||
Q_EMIT deviceRemoved(id);
|
|
||||||
d->mDevices.remove(id);
|
|
||||||
device->deleteLater();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
if (!device->isReachable() && !device->isPaired()) {
|
||||||
|
qCDebug(KDECONNECT_CORE) << "Destroying device" << device->name();
|
||||||
|
d->mDevices.remove(id);
|
||||||
|
device->deleteLater();
|
||||||
|
Q_EMIT deviceRemoved(id);
|
||||||
|
} else {
|
||||||
|
Q_EMIT deviceVisibilityChanged(id, device->isReachable());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Daemon::setAnnouncedName(QString name)
|
void Daemon::setAnnouncedName(QString name)
|
||||||
|
|
|
@ -236,10 +236,13 @@ void Device::unpair()
|
||||||
|
|
||||||
void Device::unpairInternal()
|
void Device::unpairInternal()
|
||||||
{
|
{
|
||||||
|
bool alreadyUnpaired = (m_pairStatus != Device::Paired);
|
||||||
m_pairStatus = Device::NotPaired;
|
m_pairStatus = Device::NotPaired;
|
||||||
KdeConnectConfig::instance()->removeTrustedDevice(id());
|
KdeConnectConfig::instance()->removeTrustedDevice(id());
|
||||||
reloadPlugins(); //Will unload the plugins
|
reloadPlugins(); //Will unload the plugins
|
||||||
Q_EMIT pairingChanged(false);
|
if (!alreadyUnpaired) {
|
||||||
|
Q_EMIT pairingChanged(false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Device::pairingTimeout()
|
void Device::pairingTimeout()
|
||||||
|
@ -444,6 +447,8 @@ void Device::acceptPairing()
|
||||||
void Device::setAsPaired()
|
void Device::setAsPaired()
|
||||||
{
|
{
|
||||||
|
|
||||||
|
bool alreadyPaired = (m_pairStatus == Device::Paired);
|
||||||
|
|
||||||
m_pairStatus = Device::Paired;
|
m_pairStatus = Device::Paired;
|
||||||
|
|
||||||
m_pairingTimeut.stop(); //Just in case it was started
|
m_pairingTimeut.stop(); //Just in case it was started
|
||||||
|
@ -453,7 +458,9 @@ void Device::setAsPaired()
|
||||||
|
|
||||||
reloadPlugins(); //Will actually load the plugins
|
reloadPlugins(); //Will actually load the plugins
|
||||||
|
|
||||||
Q_EMIT pairingChanged(true);
|
if (!alreadyPaired) {
|
||||||
|
Q_EMIT pairingChanged(true);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -121,8 +121,8 @@ private Q_SLOTS:
|
||||||
void pairingTimeout();
|
void pairingTimeout();
|
||||||
|
|
||||||
Q_SIGNALS:
|
Q_SIGNALS:
|
||||||
Q_SCRIPTABLE void reachableStatusChanged();
|
|
||||||
Q_SCRIPTABLE void pluginsChanged();
|
Q_SCRIPTABLE void pluginsChanged();
|
||||||
|
Q_SCRIPTABLE void reachableStatusChanged();
|
||||||
Q_SCRIPTABLE void pairingChanged(bool paired);
|
Q_SCRIPTABLE void pairingChanged(bool paired);
|
||||||
Q_SCRIPTABLE void pairingFailed(const QString& error);
|
Q_SCRIPTABLE void pairingFailed(const QString& error);
|
||||||
Q_SCRIPTABLE void nameChanged(const QString& name);
|
Q_SCRIPTABLE void nameChanged(const QString& name);
|
||||||
|
|
Loading…
Reference in a new issue