Blame SOURCES/0002-Delete-adapter-only-after-all-devices-from-the-adapt.patch

5ed677
From a316b2a48d0ad0a6e3ee7ec90a74bc771f4e3c46 Mon Sep 17 00:00:00 2001
5ed677
From: David Rosca <nowrep@gmail.com>
5ed677
Date: Mon, 27 Apr 2015 17:46:06 +0200
5ed677
Subject: [PATCH 2/2] Delete adapter only after all devices from the adapter
5ed677
 were removed
5ed677
5ed677
BUG: 346329
5ed677
---
5ed677
 bluedevil/bluedevilmanager_p.cpp | 5 ++++-
5ed677
 1 file changed, 4 insertions(+), 1 deletion(-)
5ed677
5ed677
diff --git a/bluedevil/bluedevilmanager_p.cpp b/bluedevil/bluedevilmanager_p.cpp
5ed677
index bb65467..3c45f2a 100644
5ed677
--- a/bluedevil/bluedevilmanager_p.cpp
5ed677
+++ b/bluedevil/bluedevilmanager_p.cpp
5ed677
@@ -162,7 +162,6 @@ void ManagerPrivate::_k_interfacesRemoved(const QDBusObjectPath &objectPath, con
5ed677
             }
5ed677
             if (adapter) {
5ed677
                 emit m_q->adapterRemoved(adapter);
5ed677
-                delete adapter;
5ed677
             }
5ed677
             if (m_adapters.isEmpty()) {
5ed677
                 emit m_q->usableAdapterChanged(0);
5ed677
@@ -180,6 +179,10 @@ void ManagerPrivate::_k_interfacesRemoved(const QDBusObjectPath &objectPath, con
5ed677
             Adapter * const adapter = m_devAdapter.take(object);
5ed677
             if (adapter) {
5ed677
                 adapter->removeDevice(object);
5ed677
+
5ed677
+                if (adapter->devices().isEmpty()) {
5ed677
+                    adapter->deleteLater();
5ed677
+                }
5ed677
             }
5ed677
         }
5ed677
     }
5ed677
-- 
5ed677
2.3.6
5ed677