From 7d7ca8ee2eaae704989a1552ad429794d402f550 Mon Sep 17 00:00:00 2001 From: Andreas Monzner Date: Thu, 23 Nov 2006 16:31:19 +0000 Subject: add PyObject refcount debugging code --- lib/python/python.cpp | 39 ++++++++++++++++++++++++++++++++++++++- 1 file changed, 38 insertions(+), 1 deletion(-) (limited to 'lib/python/python.cpp') diff --git a/lib/python/python.cpp b/lib/python/python.cpp index 119bff1c..2636a3d5 100644 --- a/lib/python/python.cpp +++ b/lib/python/python.cpp @@ -1,4 +1,3 @@ -#include #include /* avoid warnigs :) */ #undef _POSIX_C_SOURCE @@ -8,6 +7,44 @@ extern "C" void init_enigma(); extern void bsodFatal(); +void Impl_Py_DECREF(const char* file, int line, PyObject *obj) +{ + if (!obj) + { + eDebug("decref python object null pointer %s %d!!!", + file, line); + bsodFatal(); + } + if (obj->ob_refcnt <= 0) + { + eDebug("decref python object with refcounting value %d (%s %d)!!!", obj->ob_refcnt, file, line); + bsodFatal(); + } + Py_DECREF(obj); +} + +void Impl_Py_INCREF(const char* file, int line, PyObject *obj) +{ + if (!obj) + { + eDebug("incref python object null pointer %s %d!!!", file, line); + bsodFatal(); + } + if (obj->ob_refcnt <= 0) + { + eDebug("incref python object with refcounting value %d (%s %d)!!!", obj->ob_refcnt, file, line); + bsodFatal(); + } + if (obj->ob_refcnt == 0x7FFFFFFF) + { + eDebug("incref python object with refcounting value %d (MAX_INT!!!) (%s %d)!!!", obj->ob_refcnt, file, line); + bsodFatal(); + } + Py_INCREF(obj); +} + +#include + DEFINE_REF(TestObj); TestObj::TestObj() -- cgit v1.2.3