summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2015-11-01 14:45:54 (GMT)
committerSerhiy Storchaka <storchaka@gmail.com>2015-11-01 14:45:54 (GMT)
commit17bdf2015d8c46d6418ad7b8742a4fb0d277a642 (patch)
tree52b5aada60471174cf331f2f5ea594354cea54b8 /Lib
parent9b69491901045bcaff15fd9de9eb4c888cc5a3bd (diff)
parent56275dc1e2a2f354620189efd751fa90af2118e1 (diff)
downloadcpython-17bdf2015d8c46d6418ad7b8742a4fb0d277a642.zip
cpython-17bdf2015d8c46d6418ad7b8742a4fb0d277a642.tar.gz
cpython-17bdf2015d8c46d6418ad7b8742a4fb0d277a642.tar.bz2
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.
Diffstat (limited to 'Lib')
-rw-r--r--Lib/fileinput.py5
-rw-r--r--Lib/test/test_fileinput.py15
2 files changed, 19 insertions, 1 deletions
diff --git a/Lib/fileinput.py b/Lib/fileinput.py
index af810d1..c41b94a 100644
--- a/Lib/fileinput.py
+++ b/Lib/fileinput.py
@@ -315,7 +315,10 @@ class FileInput:
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 --git a/Lib/test/test_fileinput.py b/Lib/test/test_fileinput.py
index 1d089f5..4765a05 100644
--- a/Lib/test/test_fileinput.py
+++ b/Lib/test/test_fileinput.py
@@ -288,6 +288,21 @@ class FileInputTests(unittest.TestCase):
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: