]> git.lizzy.rs Git - zlib.git/commit
Allow gzread() and related to continue after gzclearerr().
authorMark Adler <madler@alumni.caltech.edu>
Mon, 26 Sep 2011 07:57:26 +0000 (00:57 -0700)
committerMark Adler <madler@alumni.caltech.edu>
Mon, 26 Sep 2011 07:57:26 +0000 (00:57 -0700)
commit5ad116abdad08c49b9ab20d748550eecd2c1d96d
tree2aace8e541c2332df89f6161d98912258f23a637
parenta9ae24b6538a8c75b13826ef8a2547344fd2e08c
Allow gzread() and related to continue after gzclearerr().

Before this fix, gzread() would lose data if a premature end of file
was encountered.  This prevented gzread() from being used on a file
that was being written concurrently.  Now gzread() returns all of the
data it has available before indicating a premature end of file.

This also changes the error returned on a premature end of file from
Z_DATA_ERROR to Z_BUF_ERROR.  This allows the user to determine if
the error is recoverable, which it is if Z_BUF_ERROR is returned.  If
a Z_DATA_ERROR is returned, then the error is not recoverable.

This patch replaces the functionality of a previous patch that fixed
reading through an empty gzip stream in a concatenation of gzip
streams.

To implement this fix, a noticeable rewrite of gzread.c was needed.
The patch has the added advantage of using inflate's gzip processing
instead of replicating the functionality in gzread.c.  This makes the
gz code a little simpler.
gzlib.c
gzread.c