Commit 1c873bf7 authored by Benjamin Peterson's avatar Benjamin Peterson

clear BufferedRWPair weakrefs on deallocation (closes #22517)

parent f8c4b3a7
...@@ -1474,6 +1474,12 @@ class BufferedRWPairTest(unittest.TestCase): ...@@ -1474,6 +1474,12 @@ class BufferedRWPairTest(unittest.TestCase):
pair = self.tp(SelectableIsAtty(True), SelectableIsAtty(True)) pair = self.tp(SelectableIsAtty(True), SelectableIsAtty(True))
self.assertTrue(pair.isatty()) self.assertTrue(pair.isatty())
def test_weakref_clearing(self):
brw = self.tp(self.MockRawIO(), self.MockRawIO())
ref = weakref.ref(brw)
brw = None
ref = None # Shouldn't segfault.
class CBufferedRWPairTest(BufferedRWPairTest): class CBufferedRWPairTest(BufferedRWPairTest):
tp = io.BufferedRWPair tp = io.BufferedRWPair
......
...@@ -29,6 +29,9 @@ Core and Builtins ...@@ -29,6 +29,9 @@ Core and Builtins
Library Library
------- -------
- Issue #22517: When a io.BufferedRWPair object is deallocated, clear its
weakrefs.
- Issue #10510: distutils register and upload methods now use HTML standards - Issue #10510: distutils register and upload methods now use HTML standards
compliant CRLF line endings. compliant CRLF line endings.
......
...@@ -2120,6 +2120,8 @@ static void ...@@ -2120,6 +2120,8 @@ static void
bufferedrwpair_dealloc(rwpair *self) bufferedrwpair_dealloc(rwpair *self)
{ {
_PyObject_GC_UNTRACK(self); _PyObject_GC_UNTRACK(self);
if (self->weakreflist != NULL)
PyObject_ClearWeakRefs((PyObject *)self);
Py_CLEAR(self->reader); Py_CLEAR(self->reader);
Py_CLEAR(self->writer); Py_CLEAR(self->writer);
Py_CLEAR(self->dict); Py_CLEAR(self->dict);
......
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