aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreas Monzner <andreas.monzner@multimedia-labs.de>2008-10-23 23:57:36 +0000
committerAndreas Monzner <andreas.monzner@multimedia-labs.de>2008-10-23 23:57:36 +0000
commitec5a129c62b75f939830c0585780bdedf7c78460 (patch)
tree0654ed5b36d884ab90977b51591761add5c4684d
parenta367a550862868926f84e845940ce2391be415fd (diff)
downloadenigma2-ec5a129c62b75f939830c0585780bdedf7c78460.tar.gz
enigma2-ec5a129c62b75f939830c0585780bdedf7c78460.zip
fix garbage collection (Modules/gcmodule.c:380: move_unreachable: Assertion
`gc->gc.gc_refs > 0`)
-rw-r--r--lib/base/ebase.cpp21
-rw-r--r--lib/python/connections.cpp10
-rw-r--r--lib/python/connections.h2
3 files changed, 20 insertions, 13 deletions
diff --git a/lib/base/ebase.cpp b/lib/base/ebase.cpp
index 62746f4b..bcfab61c 100644
--- a/lib/base/ebase.cpp
+++ b/lib/base/ebase.cpp
@@ -368,16 +368,19 @@ struct eTimerPy
static int
eTimerPy_traverse(eTimerPy *self, visitproc visit, void *arg)
{
- PyObject *obj = self->tm->timeout.get();
- Py_VISIT(obj);
+ PyObject *obj = self->tm->timeout.get(true);
+ if (obj) {
+ Py_VISIT(obj);
+ }
return 0;
}
static int
eTimerPy_clear(eTimerPy *self)
{
- PyObject *obj = self->tm->timeout.get();
- Py_CLEAR(obj);
+ PyObject *obj = self->tm->timeout.get(true);
+ if (obj)
+ Py_CLEAR(obj);
return 0;
}
@@ -572,16 +575,18 @@ struct eSocketNotifierPy
static int
eSocketNotifierPy_traverse(eSocketNotifierPy *self, visitproc visit, void *arg)
{
- PyObject *obj = self->sn->activated.get();
- Py_VISIT(obj);
+ PyObject *obj = self->sn->activated.get(true);
+ if (obj)
+ Py_VISIT(obj);
return 0;
}
static int
eSocketNotifierPy_clear(eSocketNotifierPy *self)
{
- PyObject *obj = self->sn->activated.get();
- Py_CLEAR(obj);
+ PyObject *obj = self->sn->activated.get(true);
+ if (obj)
+ Py_CLEAR(obj);
return 0;
}
diff --git a/lib/python/connections.cpp b/lib/python/connections.cpp
index 00f33f71..864e5524 100644
--- a/lib/python/connections.cpp
+++ b/lib/python/connections.cpp
@@ -20,10 +20,12 @@ void PSignal::callPython(ePyObject tuple)
}
}
-PyObject *PSignal::get()
+PyObject *PSignal::get(bool steal)
{
- if (!m_list)
- m_list = PyList_New(0);
- Py_INCREF(m_list);
+ if (!steal) {
+ if (!m_list)
+ m_list = PyList_New(0);
+ Py_INCREF(m_list);
+ }
return m_list;
}
diff --git a/lib/python/connections.h b/lib/python/connections.h
index 8ff3a620..76859e7d 100644
--- a/lib/python/connections.h
+++ b/lib/python/connections.h
@@ -18,7 +18,7 @@ public:
PSignal();
~PSignal();
void callPython(SWIG_PYOBJECT(ePyObject) tuple);
- PyObject *get();
+ PyObject *get(bool steal=false);
};
inline PyObject *PyFrom(int v)