Commit 5a9112c0 authored by Antoine Pitrou's avatar Antoine Pitrou

Issue #2846: Add support for gzip.GzipFile reading zero-padded files.

Patch by Brian Curtin.
parent 10042922
......@@ -72,6 +72,9 @@ The module defines the following items:
.. versionchanged:: 2.7
Support for the :keyword:`with` statement was added.
.. versionchanged:: 2.7
Support for zero-padded files was added.
.. function:: open(filename[, mode[, compresslevel]])
......
......@@ -330,6 +330,15 @@ class GzipFile(io.BufferedIOBase):
elif isize != (self.size & 0xffffffffL):
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
def closed(self):
return self.fileobj is None
......
......@@ -252,6 +252,18 @@ class TestGzip(unittest.TestCase):
else:
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):
test_support.run_unittest(TestGzip)
......
......@@ -32,6 +32,9 @@ Core and Builtins
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
by Matt Giuca.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment