diff options
author | Tim Peters <tim.peters@gmail.com> | 2003-05-21 21:29:48 (GMT) |
---|---|---|
committer | Tim Peters <tim.peters@gmail.com> | 2003-05-21 21:29:48 (GMT) |
commit | 3cfe75470d1f77468be01002d09d884c3a431827 (patch) | |
tree | c788b7ba4ecea492c834d78a16e574a96049ae43 /Misc | |
parent | 4d508adae3101434ae62be1c140e9877673dc257 (diff) | |
download | cpython-3cfe75470d1f77468be01002d09d884c3a431827.zip cpython-3cfe75470d1f77468be01002d09d884c3a431827.tar.gz cpython-3cfe75470d1f77468be01002d09d884c3a431827.tar.bz2 |
PyType_Ready(): Complain if the type is a base type, and gc'able, and
tp_free is NULL or PyObject_Del at the end. Because it's a base type
it must call tp_free in its dealloc function, and because it's gc'able
it must not call PyObject_Del.
inherit_slots(): Don't inherit tp_free unless the type and its base
agree about whether they're gc'able. If the type is gc'able and the
base is not, and the base uses the default PyObject_Del for its
tp_free, give the type PyObject_GC_Del for its tp_free (the appropriate
default for a gc'able type).
cPickle.c: The Pickler and Unpickler types claim to be base classes
and gc'able, but their dealloc functions didn't call tp_free.
Repaired that. Also call PyType_Ready() on these typeobjects, so
that the correct (PyObject_GC_Del) default memory-freeing function
gets plugged into these types' tp_free slots.
Diffstat (limited to 'Misc')
-rw-r--r-- | Misc/NEWS | 11 |
1 files changed, 11 insertions, 0 deletions
@@ -75,6 +75,17 @@ Build C API ----- +- PyType_Ready(): If a type declares that it participates in gc + (Py_TPFLAGS_HAVE_GC), and its base class does not, and its base class's + tp_free slot is the default _PyObject_Del, and type does not define + a tp_free slot itself, _PyObject_GC_Del is assigned to type->tp_free. + Previously _PyObject_Del was inherited, which could at best lead to a + segfault. In addition, if even after this magic the type's tp_free + slot is _PyObject_Del or NULL, and the type is a base type + (Py_TPFLAGS_BASETYPE), TypeError is raised: since the type is a base + type, its dealloc function must call type->tp_free, and since the type + is gc'able, tp_free must not be NULL or _PyObject_Del. + New platforms ------------- |