X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/26ff43bdf1eb6fe4da12db2c61a63c0dcd9612c8..6bb94cd5b0d8fd3608afe84e8d76aef554a4b401:/lib/python/connections.h diff --git a/lib/python/connections.h b/lib/python/connections.h index 8ff3a620..ab123137 100644 --- a/lib/python/connections.h +++ b/lib/python/connections.h @@ -14,11 +14,12 @@ class PSignal { protected: ePyObject m_list; + bool *m_destroyed; public: PSignal(); ~PSignal(); void callPython(SWIG_PYOBJECT(ePyObject) tuple); - PyObject *get(); + PyObject *get(bool steal=false); }; inline PyObject *PyFrom(int v) @@ -37,13 +38,18 @@ class PSignal0: public PSignal, public Signal0 public: R operator()() { + bool destroyed=false; + m_destroyed = &destroyed; if (m_list) { PyObject *pArgs = PyTuple_New(0); callPython(pArgs); Org_Py_DECREF(pArgs); } - return Signal0::operator()(); + if (!destroyed) { + m_destroyed = 0; + return Signal0::operator()(); + } } }; @@ -53,6 +59,8 @@ class PSignal1: public PSignal, public Signal1 public: R operator()(V0 a0) { + bool destroyed=false; + m_destroyed = &destroyed; if (m_list) { PyObject *pArgs = PyTuple_New(1); @@ -60,7 +68,10 @@ public: callPython(pArgs); Org_Py_DECREF(pArgs); } - return Signal1::operator()(a0); + if (!destroyed) { + m_destroyed = 0; + return Signal1::operator()(a0); + } } }; @@ -70,6 +81,8 @@ class PSignal2: public PSignal, public Signal2 public: R operator()(V0 a0, V1 a1) { + bool destroyed=false; + m_destroyed = &destroyed; if (m_list) { PyObject *pArgs = PyTuple_New(2); @@ -78,7 +91,10 @@ public: callPython(pArgs); Org_Py_DECREF(pArgs); } - return Signal2::operator()(a0, a1); + if (!destroyed) { + m_destroyed = 0; + return Signal2::operator()(a0, a1); + } } };