diff --git a/plugins/display/collaborationdevmodel.cpp b/plugins/display/collaborationdevmodel.cpp index 89cadfe65..26b016c04 100644 --- a/plugins/display/collaborationdevmodel.cpp +++ b/plugins/display/collaborationdevmodel.cpp @@ -26,6 +26,7 @@ #include #include #include +#include #include @@ -56,16 +57,19 @@ CollaborationDevModel::CollaborationDevModel(QObject *parent) m_colDbusInter->connection().connect(CollaborationService, CollaborationPath, ColPropertiesInterface, "PropertiesChanged", "sa{sv}as", this, SLOT(onPropertyChanged(QDBusMessage))); + + auto *dbusWatcher = new QDBusServiceWatcher(CollaborationService, m_colDbusInter->connection(), + QDBusServiceWatcher::WatchForUnregistration, this); + connect(dbusWatcher, &QDBusServiceWatcher::serviceUnregistered, this, [this](){ + qWarning() << CollaborationService << "unregistered"; + clear(); + }); } void CollaborationDevModel::checkServiceValid() { if (!m_colDbusInter->isValid()) { - for (CollaborationDevice *device : m_devices) { - device->deleteLater(); - } - m_devices.clear(); - Q_EMIT devicesChanged(); + clear(); } } @@ -126,6 +130,16 @@ void CollaborationDevModel::updateDevice(const QStringList &devPaths) emit devicesChanged(); } +void CollaborationDevModel::clear() +{ + for (CollaborationDevice *device : m_devices) { + device->deleteLater(); + } + m_devices.clear(); + + Q_EMIT devicesChanged(); +} + CollaborationDevice *CollaborationDevModel::getDevice(const QString &machinePath) { return m_devices.value(machinePath, nullptr); diff --git a/plugins/display/collaborationdevmodel.h b/plugins/display/collaborationdevmodel.h index 6313d04dc..a48a02732 100644 --- a/plugins/display/collaborationdevmodel.h +++ b/plugins/display/collaborationdevmodel.h @@ -53,6 +53,7 @@ private slots: private: void updateDevice(const QStringList &devPaths); + void clear(); private: QDBusInterface *m_colDbusInter;