diff options
author | Serhiy Storchaka <storchaka@gmail.com> | 2013-09-27 19:11:57 (GMT) |
---|---|---|
committer | Serhiy Storchaka <storchaka@gmail.com> | 2013-09-27 19:11:57 (GMT) |
commit | d2c07a58affecc3fb049652ee7a435c382e3a4d0 (patch) | |
tree | 07a07c8b2115e859192c8b0d18eb116e71bcb3ed /Lib/zipfile.py | |
parent | 1f09c663add7edc6af0093d1eb3eca02bd0864b9 (diff) | |
download | cpython-d2c07a58affecc3fb049652ee7a435c382e3a4d0.zip cpython-d2c07a58affecc3fb049652ee7a435c382e3a4d0.tar.gz cpython-d2c07a58affecc3fb049652ee7a435c382e3a4d0.tar.bz2 |
Issue #19053: ZipExtFile.read1() with non-zero argument no more returns empty
bytes until end of data.
Diffstat (limited to 'Lib/zipfile.py')
-rw-r--r-- | Lib/zipfile.py | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/Lib/zipfile.py b/Lib/zipfile.py index 3448c61..92c98ab 100644 --- a/Lib/zipfile.py +++ b/Lib/zipfile.py @@ -785,8 +785,11 @@ class ZipExtFile(io.BufferedIOBase): buf = self._readbuffer[self._offset:] self._readbuffer = b'' self._offset = 0 - data = self._read1(self.MAX_N) - buf += data + while not self._eof: + data = self._read1(self.MAX_N) + if data: + buf += data + break return buf end = n + self._offset @@ -800,12 +803,16 @@ class ZipExtFile(io.BufferedIOBase): self._readbuffer = b'' self._offset = 0 if n > 0: - data = self._read1(n) - if n < len(data): - self._readbuffer = data - self._offset = n - data = data[:n] - buf += data + while not self._eof: + data = self._read1(n) + if n < len(data): + self._readbuffer = data + self._offset = n + buf += data[:n] + break + if data: + buf += data + break return buf def _read1(self, n): |