From: Martin v. Löwis Date: Sun, 5 Aug 2001 21:23:03 +0000 (+0000) Subject: Patch #448194: Debuging negative reference counts. X-Git-Tag: v2.2a3~804 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=64fbb330dc762fde930c83bc561deea9a64c7fcf;p=python Patch #448194: Debuging negative reference counts. --- diff --git a/Include/object.h b/Include/object.h index d81d4c20a2..1f749ec9bd 100644 --- a/Include/object.h +++ b/Include/object.h @@ -489,11 +489,12 @@ extern DL_IMPORT(long) _Py_RefTotal; #endif /* !Py_TRACE_REFS */ #define Py_INCREF(op) (_Py_RefTotal++, (op)->ob_refcnt++) -#define Py_DECREF(op) \ - if (--_Py_RefTotal, (--((op)->ob_refcnt) != 0)) \ - ; \ - else \ - _Py_Dealloc((PyObject *)(op)) + /* under Py_REF_DEBUG: also log negative ref counts after Py_DECREF() !! */ +#define Py_DECREF(op) \ + if (--_Py_RefTotal, 0 < (--((op)->ob_refcnt))) ; \ + else if (0 == (op)->ob_refcnt) _Py_Dealloc( (PyObject*)(op)); \ + else (void)fprintf( stderr, "%s:%i negative ref count %i\n", \ + __FILE__, __LINE__, (op)->ob_refcnt) #else /* !Py_REF_DEBUG */ #ifdef COUNT_ALLOCS