ソースを参照

Merge branch 'fix-pluginfw-memory-leaks'

* fix-pluginfw-memory-leaks:
  Break cyclic dependency by explicitly setting ref to 0.
  Removed unnecessary null check.
  Check for null pointer prior to modifying the ref count.
  Disable copy and assignment operators.
Sascha Zelzer 13 年 前
コミット
8c5711d74b

+ 1 - 1
Libs/PluginFramework/ctkServiceReference.cpp

@@ -61,7 +61,7 @@ ctkServiceReference& ctkServiceReference::operator=(int null)
 {
   if (null == 0)
   {
-    if (d_func() && !d_func()->ref.deref())
+    if (!d_func()->ref.deref())
       delete d_ptr;
     d_ptr = new ctkServiceReferencePrivate(0);
   }

+ 4 - 0
Libs/PluginFramework/ctkServiceReferencePrivate.h

@@ -103,6 +103,10 @@ public:
    * Link to registration object for this reference.
    */
   ctkServiceRegistrationPrivate* const registration;
+
+private:
+
+  Q_DISABLE_COPY(ctkServiceReferencePrivate)
 };
 
 #endif // CTKSERVICEREFERENCEPRIVATE_H

+ 4 - 3
Libs/PluginFramework/ctkServiceRegistration.cpp

@@ -51,7 +51,7 @@ ctkServiceRegistration::ctkServiceRegistration(const ctkServiceRegistration& reg
 ctkServiceRegistration::ctkServiceRegistration(ctkServiceRegistrationPrivate* registrationPrivate)
   : d_ptr(registrationPrivate)
 {
-  d_func()->ref.ref();
+  if(d_func()) d_func()->ref.ref();
 }
 
 //----------------------------------------------------------------------------
@@ -202,7 +202,8 @@ void ctkServiceRegistration::unregister()
       d->plugin = 0;
       d->dependents.clear();
       d->service = 0;
-      d->serviceInstances.clear();;
+      d->serviceInstances.clear();
+      d->reference = 0;
       d->unregistering = false;
     }
   }
@@ -228,7 +229,7 @@ ctkServiceRegistration& ctkServiceRegistration::operator=(const ctkServiceRegist
 {
   ctkServiceRegistrationPrivate* curr_d = d_func();
   d_ptr = registration.d_ptr;
-  d_ptr->ref.ref();
+  if (d_ptr) d_ptr->ref.ref();
 
   if (curr_d && !curr_d->ref.deref())
     delete curr_d;

+ 4 - 0
Libs/PluginFramework/ctkServiceRegistrationPrivate.h

@@ -123,6 +123,10 @@ public:
 
   virtual QObject* getService();
 
+private:
+
+  Q_DISABLE_COPY(ctkServiceRegistrationPrivate)
+
 };