diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/dbus/qdbusintegrator.cpp | 9 | ||||
-rw-r--r-- | src/dbus/qdbusserver.cpp | 1 |
2 files changed, 10 insertions, 0 deletions
diff --git a/src/dbus/qdbusintegrator.cpp b/src/dbus/qdbusintegrator.cpp index d05703d34d..cce8b9c28d 100644 --- a/src/dbus/qdbusintegrator.cpp +++ b/src/dbus/qdbusintegrator.cpp @@ -1038,6 +1038,15 @@ QDBusConnectionPrivate::~QDBusConnectionPrivate() "Timer and socket errors will follow and the program will probably crash", qPrintable(name)); + if (mode == ClientMode) { + // the bus service object holds a reference back to us; + // we need to destroy it before we finish destroying ourselves + Q_ASSERT(ref.load() == 0); + QObject *obj = (QObject *)busService; + disconnect(obj, Q_NULLPTR, this, Q_NULLPTR); + delete obj; + } + closeConnection(); rootNode.children.clear(); // free resources qDeleteAll(cachedMetaObjects); diff --git a/src/dbus/qdbusserver.cpp b/src/dbus/qdbusserver.cpp index 2fc7c75d83..cf1b6e9665 100644 --- a/src/dbus/qdbusserver.cpp +++ b/src/dbus/qdbusserver.cpp @@ -111,6 +111,7 @@ QDBusServer::~QDBusServer() } d->serverConnectionNames.clear(); } + d->ref.store(0); d->deleteLater(); } |