changeset: 92027:87f940e85cb0 user: Antoine Pitrou date: Wed Aug 06 19:31:40 2014 -0400 files: Include/methodobject.h Lib/test/test_sys.py Lib/test/test_weakref.py Misc/ACKS Misc/NEWS Modules/_testcapimodule.c Objects/methodobject.c description: Issue #22116: C functions and methods (of the 'builtin_function_or_method' type) can now be weakref'ed. Patch by Wei Wu. diff -r a47996c10579 -r 87f940e85cb0 Include/methodobject.h --- a/Include/methodobject.h Wed Aug 06 18:55:54 2014 +0300 +++ b/Include/methodobject.h Wed Aug 06 19:31:40 2014 -0400 @@ -77,6 +77,7 @@ PyMethodDef *m_ml; /* Description of the C function to call */ PyObject *m_self; /* Passed as 'self' arg to the C func, can be NULL */ PyObject *m_module; /* The __module__ attribute, can be anything */ + PyObject *m_weakreflist; /* List of weak references */ } PyCFunctionObject; #endif diff -r a47996c10579 -r 87f940e85cb0 Lib/test/test_sys.py --- a/Lib/test/test_sys.py Wed Aug 06 18:55:54 2014 +0300 +++ b/Lib/test/test_sys.py Wed Aug 06 19:31:40 2014 -0400 @@ -784,7 +784,7 @@ # buffer # XXX # builtin_function_or_method - check(len, size('3P')) # XXX check layout + check(len, size('4P')) # XXX check layout # bytearray samples = [b'', b'u'*100000] for sample in samples: diff -r a47996c10579 -r 87f940e85cb0 Lib/test/test_weakref.py --- a/Lib/test/test_weakref.py Wed Aug 06 18:55:54 2014 +0300 +++ b/Lib/test/test_weakref.py Wed Aug 06 19:31:40 2014 -0400 @@ -92,6 +92,18 @@ self.check_basic_callback(create_function) self.check_basic_callback(create_bound_method) + @support.cpython_only + def test_cfunction(self): + import _testcapi + create_cfunction = _testcapi.create_cfunction + f = create_cfunction() + wr = weakref.ref(f) + self.assertIs(wr(), f) + del f + self.assertIsNone(wr()) + self.check_basic_ref(create_cfunction) + self.check_basic_callback(create_cfunction) + def test_multiple_callbacks(self): o = C() ref1 = weakref.ref(o, self.callback) diff -r a47996c10579 -r 87f940e85cb0 Misc/ACKS --- a/Misc/ACKS Wed Aug 06 18:55:54 2014 +0300 +++ b/Misc/ACKS Wed Aug 06 19:31:40 2014 -0400 @@ -1484,6 +1484,7 @@ Darren Worrall Thomas Wouters Daniel Wozniak +Wei Wu Heiko Wundram Doug Wyatt Robert Xiao diff -r a47996c10579 -r 87f940e85cb0 Misc/NEWS --- a/Misc/NEWS Wed Aug 06 18:55:54 2014 +0300 +++ b/Misc/NEWS Wed Aug 06 19:31:40 2014 -0400 @@ -10,6 +10,9 @@ Core and Builtins ----------------- +- Issue #22116: C functions and methods (of the 'builtin_function_or_method' + type) can now be weakref'ed. Patch by Wei Wu. + - Issue #22077: Improve index error messages for bytearrays, bytes, lists, and tuples by adding 'or slices'. Added ', not m_weakreflist = NULL; op->m_ml = ml; Py_XINCREF(self); op->m_self = self; @@ -147,6 +148,9 @@ meth_dealloc(PyCFunctionObject *m) { _PyObject_GC_UNTRACK(m); + if (m->m_weakreflist != NULL) { + PyObject_ClearWeakRefs((PyObject*) m); + } Py_XDECREF(m->m_self); Py_XDECREF(m->m_module); if (numfree < PyCFunction_MAXFREELIST) { @@ -352,7 +356,7 @@ (traverseproc)meth_traverse, /* tp_traverse */ 0, /* tp_clear */ meth_richcompare, /* tp_richcompare */ - 0, /* tp_weaklistoffset */ + offsetof(PyCFunctionObject, m_weakreflist), /* tp_weaklistoffset */ 0, /* tp_iter */ 0, /* tp_iternext */ meth_methods, /* tp_methods */