mirror of
https://github.com/clementine-player/Clementine
synced 2024-12-17 12:02:48 +01:00
84 lines
2.9 KiB
Diff
84 lines
2.9 KiB
Diff
commit c06934993daab01ab831fa2478f1d11fb298afd5
|
|
Author: davidsansome <davidsansome@94c5599e-fc6c-11de-b061-8119ef04aefe>
|
|
Date: Mon May 30 14:53:59 2011 +0000
|
|
|
|
Remember any signals that are connected to Python objects and disconnect them when the script is unloaded so the references to those objects can be dropped
|
|
|
|
git-svn-id: https://clementine-player.googlecode.com/svn/trunk@3344 94c5599e-fc6c-11de-b061-8119ef04aefe
|
|
|
|
diff --git a/3rdparty/pythonqt/src/PythonQt.h b/3rdparty/pythonqt/src/PythonQt.h
|
|
index 050dadc..9a7c29f 100644
|
|
--- a/3rdparty/pythonqt/src/PythonQt.h
|
|
+++ b/3rdparty/pythonqt/src/PythonQt.h
|
|
@@ -453,6 +453,10 @@ signals:
|
|
//! emitted when help() is called on a PythonQt object and \c ExternalHelp is enabled
|
|
void pythonHelpRequest(const QByteArray& cppClassName);
|
|
|
|
+ //! emitted when a signal is connected to a Python object
|
|
+ void signalConnectedToPython(PythonQtSignalReceiver* receiver, int signal_id,
|
|
+ PyObject* callable);
|
|
+
|
|
private:
|
|
void initPythonQtModule(bool redirectStdOut, const QByteArray& pythonQtModuleName);
|
|
|
|
@@ -472,6 +476,7 @@ private:
|
|
|
|
PythonQtPrivate* _p;
|
|
|
|
+ friend class PythonQtSignalReceiver;
|
|
};
|
|
|
|
//! internal PythonQt details
|
|
diff --git a/3rdparty/pythonqt/src/PythonQtSignalReceiver.cpp b/3rdparty/pythonqt/src/PythonQtSignalReceiver.cpp
|
|
index d4074b1..7bb9dfc 100644
|
|
--- a/3rdparty/pythonqt/src/PythonQtSignalReceiver.cpp
|
|
+++ b/3rdparty/pythonqt/src/PythonQtSignalReceiver.cpp
|
|
@@ -170,22 +170,26 @@ bool PythonQtSignalReceiver::addSignalHandler(const char* signal, PyObject* call
|
|
|
|
_slotCount++;
|
|
flag = true;
|
|
+
|
|
+ PythonQt::self()->signalConnectedToPython(this, sigId, callable);
|
|
}
|
|
return flag;
|
|
}
|
|
|
|
bool PythonQtSignalReceiver::removeSignalHandler(const char* signal, PyObject* callable)
|
|
{
|
|
+ return removeSignalHandler(getSignalIndex(signal), callable);
|
|
+}
|
|
+
|
|
+bool PythonQtSignalReceiver::removeSignalHandler(int sigId, PyObject* callable)
|
|
+{
|
|
bool found = false;
|
|
- int sigId = getSignalIndex(signal);
|
|
- if (sigId>=0) {
|
|
- QMutableListIterator<PythonQtSignalTarget> i(_targets);
|
|
- while (i.hasNext()) {
|
|
- if (i.next().isSame(sigId, callable)) {
|
|
- i.remove();
|
|
- found = true;
|
|
- break;
|
|
- }
|
|
+ QMutableListIterator<PythonQtSignalTarget> i(_targets);
|
|
+ while (i.hasNext()) {
|
|
+ if (i.next().isSame(sigId, callable)) {
|
|
+ i.remove();
|
|
+ found = true;
|
|
+ break;
|
|
}
|
|
}
|
|
return found;
|
|
diff --git a/3rdparty/pythonqt/src/PythonQtSignalReceiver.h b/3rdparty/pythonqt/src/PythonQtSignalReceiver.h
|
|
index dfbcbc6..028b853 100644
|
|
--- a/3rdparty/pythonqt/src/PythonQtSignalReceiver.h
|
|
+++ b/3rdparty/pythonqt/src/PythonQtSignalReceiver.h
|
|
@@ -119,6 +119,7 @@ public:
|
|
|
|
//! remove a signal handler
|
|
bool removeSignalHandler(const char* signal, PyObject* callable);
|
|
+ bool removeSignalHandler(int sigId, PyObject* callable);
|
|
|
|
//! remove all signal handlers
|
|
void removeSignalHandlers();
|