From 75b7afbd63be9b27d3bd964891720e8c16079280 Mon Sep 17 00:00:00 2001 From: Renato Filho Date: Fri, 19 Feb 2010 17:10:24 -0300 Subject: Fixed memory leak on callbacks used on signal connection. Now using the 'destroyed()' signal the reference is cleaned after source object destroyed. --- libpyside/signalmanager.h | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) (limited to 'libpyside/signalmanager.h') diff --git a/libpyside/signalmanager.h b/libpyside/signalmanager.h index 67031a6c7..02d760ddc 100644 --- a/libpyside/signalmanager.h +++ b/libpyside/signalmanager.h @@ -61,11 +61,14 @@ public: static int qt_metacall(QObject* object, QMetaObject::Call call, int id, void** args); void addGlobalSlot(const char* slot, PyObject* callback); - void globalReceiverConnectNotify(int slotIndex); - void globalReceiverDisconnectNotify(int slotIndex); + void globalReceiverConnectNotify(QObject *sender, int slotIndex); + void globalReceiverDisconnectNotify(QObject *sender, int slotIndex); - // Used to register a new signal/slot on QMetaobjc of source. + // Used to register a new signal/slot on QMetaobject of source. static bool registerMetaMethod(QObject* source, const char* signature, QMetaMethod::MethodType type); + + // Used to discovery if SignalManager was connected with object "destroyed()" signal. + bool hasConnectionWith(const QObject *object); private: struct SignalManagerPrivate; SignalManagerPrivate* m_d; -- cgit v1.2.3