Commit d91d4de3 authored by Victor Stinner's avatar Victor Stinner Committed by GitHub

bpo-38070: visit_decref() calls _PyObject_IsFreed() (GH-15782)

In debug mode, visit_decref() now calls _PyObject_IsFreed() to ensure
that the object is not freed. If it's freed, the program fails with
an assertion error and Python dumps informations about the freed
object.
parent 3cbc23aa
...@@ -376,6 +376,8 @@ static int ...@@ -376,6 +376,8 @@ static int
visit_decref(PyObject *op, void *data) visit_decref(PyObject *op, void *data)
{ {
assert(op != NULL); assert(op != NULL);
_PyObject_ASSERT(op, !_PyObject_IsFreed(op));
if (PyObject_IS_GC(op)) { if (PyObject_IS_GC(op)) {
PyGC_Head *gc = AS_GC(op); PyGC_Head *gc = AS_GC(op);
/* We're only interested in gc_refs for objects in the /* We're only interested in gc_refs for objects in the
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment