X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=blobdiff_plain;f=lib%2Fpython%2Fconnections.h;h=b4cd1c7996452d09cdd3700861ce1458130a2129;hp=d24bb42f9660506d1c19453dc1538600a3e88543;hb=ba5fcab217438b995c1f903e0294b71d1411668b;hpb=6dcb75c26bbfec04b381bb99d75404f9fe50635d diff --git a/lib/python/connections.h b/lib/python/connections.h index d24bb42..b4cd1c7 100644 --- a/lib/python/connections.h +++ b/lib/python/connections.h @@ -3,20 +3,19 @@ #include - /* avoid warnigs :) */ -#include -#undef _POSIX_C_SOURCE -#define _POSIX_C_SOURCE 200112L - #include class PSignal { +protected: ePyObject m_list; public: PSignal(); ~PSignal(); void callPython(SWIG_PYOBJECT(ePyObject) tuple); +#ifndef SWIG + PyObject *getSteal(bool clear=false); +#endif PyObject *get(); }; @@ -36,9 +35,12 @@ class PSignal0: public PSignal, public Signal0 public: R operator()() { - PyObject *pArgs = PyTuple_New(0); - callPython(pArgs); - Org_Py_DECREF(pArgs); + if (m_list) + { + PyObject *pArgs = PyTuple_New(0); + callPython(pArgs); + Org_Py_DECREF(pArgs); + } return Signal0::operator()(); } }; @@ -49,10 +51,13 @@ class PSignal1: public PSignal, public Signal1 public: R operator()(V0 a0) { - PyObject *pArgs = PyTuple_New(1); - PyTuple_SET_ITEM(pArgs, 0, PyFrom(a0)); - callPython(pArgs); - Org_Py_DECREF(pArgs); + if (m_list) + { + PyObject *pArgs = PyTuple_New(1); + PyTuple_SET_ITEM(pArgs, 0, PyFrom(a0)); + callPython(pArgs); + Org_Py_DECREF(pArgs); + } return Signal1::operator()(a0); } }; @@ -63,11 +68,14 @@ class PSignal2: public PSignal, public Signal2 public: R operator()(V0 a0, V1 a1) { - PyObject *pArgs = PyTuple_New(2); - PyTuple_SET_ITEM(pArgs, 0, PyFrom(a0)); - PyTuple_SET_ITEM(pArgs, 1, PyFrom(a1)); - callPython(pArgs); - Org_Py_DECREF(pArgs); + if (m_list) + { + PyObject *pArgs = PyTuple_New(2); + PyTuple_SET_ITEM(pArgs, 0, PyFrom(a0)); + PyTuple_SET_ITEM(pArgs, 1, PyFrom(a1)); + callPython(pArgs); + Org_Py_DECREF(pArgs); + } return Signal2::operator()(a0, a1); } };