diff options
author | Fred Drake <fdrake@acm.org> | 2001-03-23 04:19:27 (GMT) |
---|---|---|
committer | Fred Drake <fdrake@acm.org> | 2001-03-23 04:19:27 (GMT) |
commit | db81e8ddf8953359e8c2ed9569dd2e774d78ae95 (patch) | |
tree | ee907202cd30873818f01817b57f1652631af918 | |
parent | 6a1c87ddf9033570bb773ffec5190d44e70bd5a1 (diff) | |
download | cpython-db81e8ddf8953359e8c2ed9569dd2e774d78ae95.zip cpython-db81e8ddf8953359e8c2ed9569dd2e774d78ae95.tar.gz cpython-db81e8ddf8953359e8c2ed9569dd2e774d78ae95.tar.bz2 |
Add support for weak references to the function and method types.
-rw-r--r-- | Objects/classobject.c | 7 | ||||
-rw-r--r-- | Objects/funcobject.c | 9 |
2 files changed, 13 insertions, 3 deletions
diff --git a/Objects/classobject.c b/Objects/classobject.c index d7b4c1e..fa71c4e 100644 --- a/Objects/classobject.c +++ b/Objects/classobject.c @@ -1805,6 +1805,7 @@ PyMethod_New(PyObject *func, PyObject *self, PyObject *class) if (im == NULL) return NULL; } + im->im_weakreflist = NULL; Py_INCREF(func); im->im_func = func; Py_XINCREF(self); @@ -1902,6 +1903,7 @@ instancemethod_getattro(register PyMethodObject *im, PyObject *name) static void instancemethod_dealloc(register PyMethodObject *im) { + PyObject_ClearWeakRefs((PyObject *)im); PyObject_GC_Fini(im); Py_DECREF(im->im_func); Py_XDECREF(im->im_self); @@ -2019,9 +2021,12 @@ PyTypeObject PyMethod_Type = { (getattrofunc)instancemethod_getattro, /* tp_getattro */ (setattrofunc)instancemethod_setattro, /* tp_setattro */ 0, /* tp_as_buffer */ - Py_TPFLAGS_DEFAULT | Py_TPFLAGS_GC, /* tp_flags */ + Py_TPFLAGS_DEFAULT | Py_TPFLAGS_GC | Py_TPFLAGS_HAVE_WEAKREFS, 0, /* tp_doc */ (traverseproc)instancemethod_traverse, /* tp_traverse */ + 0, /* tp_clear */ + 0, /* tp_richcompare */ + offsetof(PyMethodObject, im_weakreflist) /* tp_weaklistoffset */ }; /* Clear out the free list */ diff --git a/Objects/funcobject.c b/Objects/funcobject.c index 8871e0a..78c968c 100644 --- a/Objects/funcobject.c +++ b/Objects/funcobject.c @@ -13,6 +13,7 @@ PyFunction_New(PyObject *code, PyObject *globals) if (op != NULL) { PyObject *doc; PyObject *consts; + op->func_weakreflist = NULL; Py_INCREF(code); op->func_code = code; Py_INCREF(globals); @@ -245,6 +246,7 @@ func_setattro(PyFunctionObject *op, PyObject *name, PyObject *value) static void func_dealloc(PyFunctionObject *op) { + PyObject_ClearWeakRefs((PyObject *) op); PyObject_GC_Fini(op); Py_DECREF(op->func_code); Py_DECREF(op->func_globals); @@ -327,13 +329,16 @@ PyTypeObject PyFunction_Type = { 0, /*tp_as_number*/ 0, /*tp_as_sequence*/ 0, /*tp_as_mapping*/ - 0, /*tp_hash*/ + 0, /*tp_hash*/ 0, /*tp_call*/ 0, /*tp_str*/ (getattrofunc)func_getattro, /*tp_getattro*/ (setattrofunc)func_setattro, /*tp_setattro*/ 0, /* tp_as_buffer */ - Py_TPFLAGS_DEFAULT | Py_TPFLAGS_GC, /*tp_flags*/ + Py_TPFLAGS_DEFAULT | Py_TPFLAGS_GC | Py_TPFLAGS_HAVE_WEAKREFS, 0, /* tp_doc */ (traverseproc)func_traverse, /* tp_traverse */ + 0, /* tp_clear */ + 0, /* tp_richcompare */ + offsetof(PyFunctionObject, func_weakreflist), /* tp_weaklistoffset */ }; |