From: Fred Drake Date: Thu, 22 Mar 2001 18:26:47 +0000 (+0000) Subject: A small change to the C API for weakly-referencable types: Such types X-Git-Tag: v2.1b2~63 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=4e262a963190b201578b0b5d972035b1637f6bd5;p=thirdparty%2FPython%2Fcpython.git A small change to the C API for weakly-referencable types: Such types must now initialize the extra field used by the weak-ref machinery to NULL themselves, to avoid having to require PyObject_INIT() to check if the type supports weak references and do it there. This causes less work to be done for all objects (the type object does not need to be consulted to check for the Py_TPFLAGS_HAVE_WEAKREFS bit). --- diff --git a/Include/objimpl.h b/Include/objimpl.h index 4197bde3e18b..4aa38d5673d4 100644 --- a/Include/objimpl.h +++ b/Include/objimpl.h @@ -167,11 +167,7 @@ extern DL_IMPORT(void) _PyObject_Del(PyObject *); /* Macros trading binary compatibility for speed. See also pymem.h. Note that these macros expect non-NULL object pointers.*/ #define PyObject_INIT(op, typeobj) \ - ((op)->ob_type = (typeobj), _Py_NewReference((PyObject *)(op)), \ - (PyType_SUPPORTS_WEAKREFS((typeobj)) \ - ? *(PyObject_GET_WEAKREFS_LISTPTR(op)) = NULL \ - : NULL), \ - (op)) + ( (op)->ob_type = (typeobj), _Py_NewReference((PyObject *)(op)), (op) ) #define PyObject_INIT_VAR(op, typeobj, size) \ ( (op)->ob_size = (size), PyObject_INIT((op), (typeobj)) ) diff --git a/Misc/NEWS b/Misc/NEWS index a1cf72a49831..ac755a2ac729 100644 --- a/Misc/NEWS +++ b/Misc/NEWS @@ -61,6 +61,12 @@ Python/C API - Py_BuildValue() now has a "D" conversion to create a Python complex number from a Py_complex C value. +- Extensions types which support weak references must now set the + field allocated for the weak reference machinery to NULL themselves; + this is done to avoid the cost of checking each object for having a + weakly referencable type in PyObject_INIT(), since most types are + not weakly referencable. + Distutils - the sdist command now writes a PKG-INFO file, as described in PEP 241, diff --git a/Objects/classobject.c b/Objects/classobject.c index 00cfdde62725..d7b4c1e5a6c4 100644 --- a/Objects/classobject.c +++ b/Objects/classobject.c @@ -453,6 +453,7 @@ PyInstance_NewRaw(PyObject *klass, PyObject *dict) Py_DECREF(dict); return NULL; } + inst->in_weakreflist = NULL; Py_INCREF(klass); inst->in_class = (PyClassObject *)klass; inst->in_dict = dict;