diff options
author | Zackery Spytz <zspytz@gmail.com> | 2018-06-29 20:07:13 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2018-06-29 20:07:13 (GMT) |
commit | 0464de0f9a226cfa32b803e0326c12b2432aba26 (patch) | |
tree | d4c456790417ad6aeed6f5fd732546d3d3dbc001 | |
parent | 11ba050986b96701f72f1356d22adde8c7dbf211 (diff) | |
download | cpython-0464de0f9a226cfa32b803e0326c12b2432aba26.zip cpython-0464de0f9a226cfa32b803e0326c12b2432aba26.tar.gz cpython-0464de0f9a226cfa32b803e0326c12b2432aba26.tar.bz2 |
[2.7] bpo-25862: Fix assertion failures in io.TextIOWrapper.tell(). (GH-3918). (GH-8013)
(cherry picked from commit 23db935bcf258657682e66464bf8512def8af830)
Co-authored-by: Zackery Spytz <zspytz@gmail.com>
-rw-r--r-- | Lib/_pyio.py | 1 | ||||
-rw-r--r-- | Lib/test/test_io.py | 11 | ||||
-rw-r--r-- | Misc/NEWS.d/next/Core and Builtins/2017-10-07-10-13-15.bpo-25862.FPYBA5.rst | 2 | ||||
-rw-r--r-- | Modules/_io/textio.c | 4 |
4 files changed, 18 insertions, 0 deletions
diff --git a/Lib/_pyio.py b/Lib/_pyio.py index f022a4e..98c2d58 100644 --- a/Lib/_pyio.py +++ b/Lib/_pyio.py @@ -1619,6 +1619,7 @@ class TextIOWrapper(TextIOBase): self.buffer.write(b) if self._line_buffering and (haslf or "\r" in s): self.flush() + self._set_decoded_chars('') self._snapshot = None if self._decoder: self._decoder.reset() diff --git a/Lib/test/test_io.py b/Lib/test/test_io.py index a725711..ebaf796 100644 --- a/Lib/test/test_io.py +++ b/Lib/test/test_io.py @@ -2741,6 +2741,17 @@ class TextIOWrapperTest(unittest.TestCase): with self.maybeRaises(TypeError): t.read(42) + def test_issue25862(self): + # Assertion failures occurred in tell() after read() and write(). + t = self.TextIOWrapper(self.BytesIO(b'test'), encoding='ascii') + t.read(1) + t.read() + t.tell() + t = self.TextIOWrapper(self.BytesIO(b'test'), encoding='ascii') + t.read(1) + t.write('x') + t.tell() + class CTextIOWrapperTest(TextIOWrapperTest): diff --git a/Misc/NEWS.d/next/Core and Builtins/2017-10-07-10-13-15.bpo-25862.FPYBA5.rst b/Misc/NEWS.d/next/Core and Builtins/2017-10-07-10-13-15.bpo-25862.FPYBA5.rst new file mode 100644 index 0000000..7871636 --- /dev/null +++ b/Misc/NEWS.d/next/Core and Builtins/2017-10-07-10-13-15.bpo-25862.FPYBA5.rst @@ -0,0 +1,2 @@ +Fix assertion failures in the ``tell()`` method of ``io.TextIOWrapper``. +Patch by Zackery Spytz. diff --git a/Modules/_io/textio.c b/Modules/_io/textio.c index bf37f72..1979539 100644 --- a/Modules/_io/textio.c +++ b/Modules/_io/textio.c @@ -707,6 +707,8 @@ typedef struct PyObject *dict; } textio; +static void +textiowrapper_set_decoded_chars(textio *self, PyObject *chars); /* A couple of specialized cases in order to bypass the slow incremental encoding methods for the most popular encodings. */ @@ -1329,6 +1331,7 @@ textiowrapper_write(textio *self, PyObject *args) Py_DECREF(ret); } + textiowrapper_set_decoded_chars(self, NULL); Py_CLEAR(self->snapshot); if (self->decoder) { @@ -1534,6 +1537,7 @@ textiowrapper_read(textio *self, PyObject *args) if (final == NULL) goto fail; + textiowrapper_set_decoded_chars(self, NULL); Py_CLEAR(self->snapshot); return final; } |