From: Andreas Monzner Date: Mon, 27 Oct 2008 11:14:31 +0000 (+0000) Subject: add workaround X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=commitdiff_plain;h=7542f853b1a682ad9bf21b592f26e31e3b64521c;hp=636b9f54ca8b7e51fadfac03cf9703648106c548 add workaround --- diff --git a/lib/python/connections.cpp b/lib/python/connections.cpp index 864e552..b54c07b 100644 --- a/lib/python/connections.cpp +++ b/lib/python/connections.cpp @@ -1,11 +1,14 @@ #include PSignal::PSignal() + :m_destroyed(0) { } PSignal::~PSignal() { + if (m_destroyed) + *m_destroyed = true; Py_XDECREF(m_list); } diff --git a/lib/python/connections.h b/lib/python/connections.h index 76859e7..ab12313 100644 --- a/lib/python/connections.h +++ b/lib/python/connections.h @@ -14,6 +14,7 @@ class PSignal { protected: ePyObject m_list; + bool *m_destroyed; public: PSignal(); ~PSignal(); @@ -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); + } } };