diff options
author | Charles-François Natali <neologix@free.fr> | 2011-10-05 17:55:56 (GMT) |
---|---|---|
committer | Charles-François Natali <neologix@free.fr> | 2011-10-05 17:55:56 (GMT) |
commit | b619bb27edba24c9c1ca08b682e08afd33e9ea0f (patch) | |
tree | 658c477f2d04e11d99fd7a9b67ac6f2b61f3dc88 | |
parent | bb10a1f7597e3976eda0797b23f5aece3b2ff248 (diff) | |
parent | 42c28cdd1dbebbf241c1828ffceabf7978ddf566 (diff) | |
download | cpython-b619bb27edba24c9c1ca08b682e08afd33e9ea0f.zip cpython-b619bb27edba24c9c1ca08b682e08afd33e9ea0f.tar.gz cpython-b619bb27edba24c9c1ca08b682e08afd33e9ea0f.tar.bz2 |
Issue #13070: Fix a crash when a TextIOWrapper caught in a reference cycle
would be finalized after the reference to its underlying BufferedRWPair's
writer got cleared by the GC.
-rw-r--r-- | Lib/test/test_io.py | 15 | ||||
-rw-r--r-- | Misc/NEWS | 4 | ||||
-rw-r--r-- | Modules/_io/bufferedio.c | 5 |
3 files changed, 24 insertions, 0 deletions
diff --git a/Lib/test/test_io.py b/Lib/test/test_io.py index 455eda3..a9e3c37 100644 --- a/Lib/test/test_io.py +++ b/Lib/test/test_io.py @@ -2421,6 +2421,21 @@ class CTextIOWrapperTest(TextIOWrapperTest): with self.open(support.TESTFN, "rb") as f: self.assertEqual(f.read(), b"456def") + def test_rwpair_cleared_before_textio(self): + # Issue 13070: TextIOWrapper's finalization would crash when called + # after the reference to the underlying BufferedRWPair's writer got + # cleared by the GC. + for i in range(1000): + b1 = self.BufferedRWPair(self.MockRawIO(), self.MockRawIO()) + t1 = self.TextIOWrapper(b1, encoding="ascii") + b2 = self.BufferedRWPair(self.MockRawIO(), self.MockRawIO()) + t2 = self.TextIOWrapper(b2, encoding="ascii") + # circular references + t1.buddy = t2 + t2.buddy = t1 + support.gc_collect() + + class PyTextIOWrapperTest(TextIOWrapperTest): pass @@ -1314,6 +1314,10 @@ Tools/Demos Extension Modules ----------------- +- Issue #13070: Fix a crash when a TextIOWrapper caught in a reference cycle + would be finalized after the reference to its underlying BufferedRWPair's + writer got cleared by the GC. + - Issue #12881: ctypes: Fix segfault with large structure field names. - Issue #13058: ossaudiodev: fix a file descriptor leak on error. Patch by diff --git a/Modules/_io/bufferedio.c b/Modules/_io/bufferedio.c index b8043d4..86f7412 100644 --- a/Modules/_io/bufferedio.c +++ b/Modules/_io/bufferedio.c @@ -2307,6 +2307,11 @@ bufferedrwpair_isatty(rwpair *self, PyObject *args) static PyObject * bufferedrwpair_closed_get(rwpair *self, void *context) { + if (self->writer == NULL) { + PyErr_SetString(PyExc_RuntimeError, + "the BufferedRWPair object is being garbage-collected"); + return NULL; + } return PyObject_GetAttr((PyObject *) self->writer, _PyIO_str_closed); } |