From: Miss Islington (bot) <31488909+miss-islington@users.noreply.github.com> Date: Sat, 24 Feb 2018 17:39:18 +0000 (-0800) Subject: bpo-31966: Fixed WindowsConsoleIO.write() for writing empty data. (GH-5754) X-Git-Tag: v3.7.0b2~31 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e49bf0f353a968cddc4d8e6ea668b9d2d116e2ac;p=python bpo-31966: Fixed WindowsConsoleIO.write() for writing empty data. (GH-5754) (cherry picked from commit 42c35d9c0c8175332f50fbe034a001fe52f057b9) Co-authored-by: Serhiy Storchaka --- diff --git a/Lib/test/test_winconsoleio.py b/Lib/test/test_winconsoleio.py index 656483cf16..a78fa4d7d9 100644 --- a/Lib/test/test_winconsoleio.py +++ b/Lib/test/test_winconsoleio.py @@ -121,6 +121,10 @@ class WindowsConsoleIOTests(unittest.TestCase): else: self.assertNotIsInstance(f, ConIO) + def test_write_empty_data(self): + with ConIO('CONOUT$', 'w') as f: + self.assertEqual(f.write(b''), 0) + def assertStdinRoundTrip(self, text): stdin = open('CONIN$', 'r') old_stdin = sys.stdin diff --git a/Misc/NEWS.d/next/Windows/2018-02-19-13-54-42.bpo-31966._Q3HPb.rst b/Misc/NEWS.d/next/Windows/2018-02-19-13-54-42.bpo-31966._Q3HPb.rst new file mode 100644 index 0000000000..042a4d835a --- /dev/null +++ b/Misc/NEWS.d/next/Windows/2018-02-19-13-54-42.bpo-31966._Q3HPb.rst @@ -0,0 +1 @@ +Fixed WindowsConsoleIO.write() for writing empty data. diff --git a/Modules/_io/winconsoleio.c b/Modules/_io/winconsoleio.c index 30d1c767af..b85c11b340 100644 --- a/Modules/_io/winconsoleio.c +++ b/Modules/_io/winconsoleio.c @@ -964,6 +964,9 @@ _io__WindowsConsoleIO_write_impl(winconsoleio *self, Py_buffer *b) if (!self->writable) return err_mode("writing"); + if (!b->len) { + return PyLong_FromLong(0); + } if (b->len > BUFMAX) len = BUFMAX; else