mirror of
https://github.com/python/cpython.git
synced 2025-08-01 07:33:08 +00:00
Issue #2846: Add support for gzip.GzipFile reading zero-padded files.
Patch by Brian Curtin.
This commit is contained in:
parent
10042922d9
commit
5a9112c0cc
4 changed files with 27 additions and 0 deletions
|
@ -72,6 +72,9 @@ The module defines the following items:
|
||||||
.. versionchanged:: 2.7
|
.. versionchanged:: 2.7
|
||||||
Support for the :keyword:`with` statement was added.
|
Support for the :keyword:`with` statement was added.
|
||||||
|
|
||||||
|
.. versionchanged:: 2.7
|
||||||
|
Support for zero-padded files was added.
|
||||||
|
|
||||||
|
|
||||||
.. function:: open(filename[, mode[, compresslevel]])
|
.. function:: open(filename[, mode[, compresslevel]])
|
||||||
|
|
||||||
|
|
|
@ -330,6 +330,15 @@ class GzipFile(io.BufferedIOBase):
|
||||||
elif isize != (self.size & 0xffffffffL):
|
elif isize != (self.size & 0xffffffffL):
|
||||||
raise IOError, "Incorrect length of data produced"
|
raise IOError, "Incorrect length of data produced"
|
||||||
|
|
||||||
|
# Gzip files can be padded with zeroes and still have archives.
|
||||||
|
# Consume all zero bytes and set the file position to the first
|
||||||
|
# non-zero byte. See http://www.gzip.org/#faq8
|
||||||
|
c = "\x00"
|
||||||
|
while c == "\x00":
|
||||||
|
c = self.fileobj.read(1)
|
||||||
|
if c:
|
||||||
|
self.fileobj.seek(-1, 1)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def closed(self):
|
def closed(self):
|
||||||
return self.fileobj is None
|
return self.fileobj is None
|
||||||
|
|
|
@ -252,6 +252,18 @@ class TestGzip(unittest.TestCase):
|
||||||
else:
|
else:
|
||||||
self.fail("1/0 didn't raise an exception")
|
self.fail("1/0 didn't raise an exception")
|
||||||
|
|
||||||
|
def test_zero_padded_file(self):
|
||||||
|
with gzip.GzipFile(self.filename, "wb") as f:
|
||||||
|
f.write(data1 * 50)
|
||||||
|
|
||||||
|
# Pad the file with zeroes
|
||||||
|
with open(self.filename, "ab") as f:
|
||||||
|
f.write("\x00" * 50)
|
||||||
|
|
||||||
|
with gzip.GzipFile(self.filename, "rb") as f:
|
||||||
|
d = f.read()
|
||||||
|
self.assertEqual(d, data1 * 50, "Incorrect data in file")
|
||||||
|
|
||||||
def test_main(verbose=None):
|
def test_main(verbose=None):
|
||||||
test_support.run_unittest(TestGzip)
|
test_support.run_unittest(TestGzip)
|
||||||
|
|
||||||
|
|
|
@ -32,6 +32,9 @@ Core and Builtins
|
||||||
Library
|
Library
|
||||||
-------
|
-------
|
||||||
|
|
||||||
|
- Issue #2846: Add support for gzip.GzipFile reading zero-padded files.
|
||||||
|
Patch by Brian Curtin.
|
||||||
|
|
||||||
- Issue #5827: Make sure that normpath preserves unicode. Initial patch
|
- Issue #5827: Make sure that normpath preserves unicode. Initial patch
|
||||||
by Matt Giuca.
|
by Matt Giuca.
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue