changeset: 98926:4f0e293e6eb0 parent: 98923:bd6bfa5fe203 parent: 98925:321b34824020 user: Serhiy Storchaka date: Sun Nov 01 16:45:54 2015 +0200 files: Misc/NEWS description: Issue #25510: fileinput.FileInput.readline() now returns b'' instead of '' at the end if the FileInput was opened with binary mode. Patch by Ryosuke Ito. diff -r bd6bfa5fe203 -r 4f0e293e6eb0 Lib/fileinput.py --- a/Lib/fileinput.py Sun Nov 01 16:13:45 2015 +0200 +++ b/Lib/fileinput.py Sun Nov 01 16:45:54 2015 +0200 @@ -315,7 +315,10 @@ return line if not self._file: if not self._files: - return "" + if 'b' in self._mode: + return b'' + else: + return '' self._filename = self._files[0] self._files = self._files[1:] self._filelineno = 0 diff -r bd6bfa5fe203 -r 4f0e293e6eb0 Lib/test/test_fileinput.py --- a/Lib/test/test_fileinput.py Sun Nov 01 16:13:45 2015 +0200 +++ b/Lib/test/test_fileinput.py Sun Nov 01 16:45:54 2015 +0200 @@ -288,6 +288,21 @@ with self.assertRaises(UnicodeDecodeError): # Read to the end of file. list(fi) + self.assertEqual(fi.readline(), '') + self.assertEqual(fi.readline(), '') + + def test_readline_binary_mode(self): + with open(TESTFN, 'wb') as f: + f.write(b'A\nB\r\nC\rD') + self.addCleanup(safe_unlink, TESTFN) + + with FileInput(files=TESTFN, mode='rb') as fi: + self.assertEqual(fi.readline(), b'A\n') + self.assertEqual(fi.readline(), b'B\r\n') + self.assertEqual(fi.readline(), b'C\rD') + # Read to the end of file. + self.assertEqual(fi.readline(), b'') + self.assertEqual(fi.readline(), b'') def test_context_manager(self): try: diff -r bd6bfa5fe203 -r 4f0e293e6eb0 Misc/NEWS --- a/Misc/NEWS Sun Nov 01 16:13:45 2015 +0200 +++ b/Misc/NEWS Sun Nov 01 16:45:54 2015 +0200 @@ -66,6 +66,10 @@ Library ------- +- Issue #25510: fileinput.FileInput.readline() now returns b'' instead of '' + at the end if the FileInput was opened with binary mode. + Patch by Ryosuke Ito. + - Issue #25503: Fixed inspect.getdoc() for inherited docstrings of properties. Original patch by John Mark Vandenberg.