1. 14 1月, 2012 1 次提交
    • M
      Insert the first two strings in the hash table after a flush. · 4f5779a8
      Mark Adler 提交于
      This allows deflate to generate the same output when continuing after
      a Z_SYNC_FLUSH vs. using deflateSetDictionary() after a Z_FULL_FLUSH
      or a deflateReset().  It also slightly improves compression when
      flushing by providing two more strings to possibly match at the start
      of the new block.
      4f5779a8
  2. 08 1月, 2012 3 次提交
    • M
      Write out all of the available bits when using Z_BLOCK. · 0b828b4a
      Mark Adler 提交于
      Previously, the bit buffer would hold 1 to 16 bits after "all" of the
      output is provided after a Z_BLOCK deflate() call.  Now at most seven
      bits remain in the output buffer after Z_BLOCK.  flush_pending() now
      flushes the bit buffer before copying out the byte buffer, in order
      for it to really flush as much as possible.
      0b828b4a
    • M
      Remove second empty static block for Z_PARTIAL_FLUSH. · 8f5eceef
      Mark Adler 提交于
      Z_PARTIAL_FLUSH would sometimes emit two empty static blocks instead
      of one in order to provide enough lookahead for inflate to be able
      to decode what was last compressed.  inflate no longer needs that
      much lookahead, so this removes the possibility of emitting the
      second empty static block.  Z_PARTIAL_FLUSH will now emit only one
      empty static block.
      8f5eceef
    • M
      Allow deflatePrime() to insert bits in the middle of a stream. · 263b1a05
      Mark Adler 提交于
      This allows the insertion of multiple empty static blocks for the
      purpose of efficiently bringing a stream to a byte boundary.
      263b1a05
  3. 29 12月, 2011 3 次提交
    • M
      Permit Z_NULL arguments to deflatePending. · 19761b85
      Mark Adler 提交于
      This avoids having to create useless variables for return values
      that aren't needed.
      19761b85
    • M
      Avoid extraneous empty blocks when doing empty flushes. · 9d55abc9
      Mark Adler 提交于
      Previously when doing an empty flush, a extra static or stored block
      could be emitted before the requested empty static or stored block.
      This patch prevents the emission of empty blocks by the deflate_*
      functions.
      9d55abc9
    • M
      Permit stronger flushes after Z_BLOCK flushes. · f1ebdd6a
      Mark Adler 提交于
      The incorporation of the Z_BLOCK flush did not update the rejection
      of lower ranked flushes immediately after higher ranked flushes with
      no more input data.  This prevented an empty Z_SYNC_FLUSH right after
      a Z_BLOCK flush, which would be desired to bring the deflate stream
      to a byte boundary conditionally on whether or not it was already at
      a byte boundary.  This patch re-ranks Z_BLOCK above Z_NO_FLUSH but
      below Z_PARTIAL_FLUSH, allowing stronger empty flushes to follow a
      Z_BLOCK flush.
      f1ebdd6a
  4. 24 12月, 2011 1 次提交
  5. 20 12月, 2011 1 次提交
  6. 19 12月, 2011 6 次提交
  7. 18 12月, 2011 1 次提交
  8. 14 12月, 2011 2 次提交
  9. 12 12月, 2011 2 次提交
  10. 11 12月, 2011 3 次提交
  11. 08 12月, 2011 1 次提交
    • M
      Enable dictionary setting in middle of stream, and keeping the dictionary. · afe7cf78
      Mark Adler 提交于
      This patch adds the deflateResetKeep() function to retain the sliding
      window for the next deflate operation, and fixes an inflateResetKeep()
      problem that came from inflate() not updating the window when the
      stream completed.  This enables constructing and decompressing a series
      of concatenated deflate streams where each can depend on the history of
      uncompressed data that precedes it.
      
      This generalizes deflateSetDictionary() and inflateSetDictionary() to
      permit setting the dictionary in the middle of a stream for raw deflate
      and inflate.  This in combination with the Keep functions enables a
      scheme for updating files block by block with the transmission of
      compressed data, where blocks are sent with deflateResetKeep() to
      retain history for better compression, and deflateSetDictionary() is
      used for blocks already present at the receiver to skip compression but
      insert that data in the history, again for better compression.  The
      corresponding inflate calls are done on the receiver side.
      afe7cf78
  12. 01 12月, 2011 1 次提交
  13. 28 11月, 2011 4 次提交
  14. 22 11月, 2011 1 次提交
  15. 20 11月, 2011 1 次提交
  16. 14 11月, 2011 3 次提交
  17. 24 10月, 2011 1 次提交
  18. 21 10月, 2011 1 次提交
    • M
      Add comment to gzdopen() in zlib.h to use dup() when using fileno(). · 6dbf1d10
      Mark Adler 提交于
      A problem surfaced in a multi-threaded application where fileno() was
      used to get a file descriptor from an fopen(), which was then fed to
      gzdopen().  The problem occurred when the gzclose() followed by the
      fclose() tried to close the same file descriptor twice.  If fclose()
      were not done, there would be a memory leak.  The only way out is to
      dup() the file descriptor so that gzclose() closes the duplicated
      file descriptor, and fclose() closes the original file descriptor.
      6dbf1d10
  19. 19 10月, 2011 1 次提交
    • M
      Add #define ZLIB_CONST option to use const in the z_stream interface. · 5ab9f477
      Mark Adler 提交于
      This permits compilers to check for the proper treatment of next_in and
      msg in the z_stream structure.  This is an option instead of the default
      in order to preserve backward compatibility.  Some applications make use
      of the z_stream structure outside of zlib, and perform operations such
      as free(strm->next_in), which would not be permitted when next_in is
      const.  The #define ZLIB_CONST needs to precede the #include "zlib.h">,
      in order to make next_in and msg const pointers in the z_stream type.
      5ab9f477
  20. 10 10月, 2011 3 次提交