mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-26 02:18:04 +01:00 
			
		
		
		
	#4169: Upgrade bundled zlib to 1.3
This commit is contained in:
		| @@ -241,7 +241,11 @@ | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef Z_SOLO | #ifdef Z_SOLO | ||||||
|    typedef unsigned long z_size_t; | #  ifdef _WIN64 | ||||||
|  |      typedef unsigned long long z_size_t; | ||||||
|  | #  else | ||||||
|  |      typedef unsigned long z_size_t; | ||||||
|  | #  endif | ||||||
| #else | #else | ||||||
| #  define z_longlong long long | #  define z_longlong long long | ||||||
| #  if defined(NO_SIZE_T) | #  if defined(NO_SIZE_T) | ||||||
| @@ -520,7 +524,7 @@ typedef uLong FAR uLongf; | |||||||
| #if !defined(_WIN32) && defined(Z_LARGE64) | #if !defined(_WIN32) && defined(Z_LARGE64) | ||||||
| #  define z_off64_t off64_t | #  define z_off64_t off64_t | ||||||
| #else | #else | ||||||
| #  if defined(_WIN32) && !defined(__GNUC__) && !defined(Z_SOLO) | #  if defined(_WIN32) && !defined(__GNUC__) | ||||||
| #    define z_off64_t __int64 | #    define z_off64_t __int64 | ||||||
| #  else | #  else | ||||||
| #    define z_off64_t z_off_t | #    define z_off64_t z_off_t | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| /* zlib.h -- interface of the 'zlib' general purpose compression library | /* zlib.h -- interface of the 'zlib' general purpose compression library | ||||||
|   version 1.2.13, October 13th, 2022 |   version 1.3, August 18th, 2023 | ||||||
|  |  | ||||||
|   Copyright (C) 1995-2022 Jean-loup Gailly and Mark Adler |   Copyright (C) 1995-2023 Jean-loup Gailly and Mark Adler | ||||||
|  |  | ||||||
|   This software is provided 'as-is', without any express or implied |   This software is provided 'as-is', without any express or implied | ||||||
|   warranty.  In no event will the authors be held liable for any damages |   warranty.  In no event will the authors be held liable for any damages | ||||||
| @@ -37,11 +37,11 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #define ZLIB_VERSION "1.2.13" | #define ZLIB_VERSION "1.3" | ||||||
| #define ZLIB_VERNUM 0x12d0 | #define ZLIB_VERNUM 0x1300 | ||||||
| #define ZLIB_VER_MAJOR 1 | #define ZLIB_VER_MAJOR 1 | ||||||
| #define ZLIB_VER_MINOR 2 | #define ZLIB_VER_MINOR 3 | ||||||
| #define ZLIB_VER_REVISION 13 | #define ZLIB_VER_REVISION 0 | ||||||
| #define ZLIB_VER_SUBREVISION 0 | #define ZLIB_VER_SUBREVISION 0 | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -78,8 +78,8 @@ extern "C" { | |||||||
|   even in the case of corrupted input. |   even in the case of corrupted input. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| typedef voidpf (*alloc_func) OF((voidpf opaque, uInt items, uInt size)); | typedef voidpf (*alloc_func)(voidpf opaque, uInt items, uInt size); | ||||||
| typedef void   (*free_func)  OF((voidpf opaque, voidpf address)); | typedef void   (*free_func)(voidpf opaque, voidpf address); | ||||||
|  |  | ||||||
| struct internal_state; | struct internal_state; | ||||||
|  |  | ||||||
| @@ -217,7 +217,7 @@ typedef gz_header FAR *gz_headerp; | |||||||
|  |  | ||||||
|                         /* basic functions */ |                         /* basic functions */ | ||||||
|  |  | ||||||
| ZEXTERN const char * ZEXPORT zlibVersion OF((void)); | ZEXTERN const char * ZEXPORT zlibVersion(void); | ||||||
| /* The application can compare zlibVersion and ZLIB_VERSION for consistency. | /* The application can compare zlibVersion and ZLIB_VERSION for consistency. | ||||||
|    If the first character differs, the library code actually used is not |    If the first character differs, the library code actually used is not | ||||||
|    compatible with the zlib.h header file used by the application.  This check |    compatible with the zlib.h header file used by the application.  This check | ||||||
| @@ -225,12 +225,12 @@ ZEXTERN const char * ZEXPORT zlibVersion OF((void)); | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN int ZEXPORT deflateInit OF((z_streamp strm, int level)); | ZEXTERN int ZEXPORT deflateInit(z_streamp strm, int level); | ||||||
|  |  | ||||||
|      Initializes the internal stream state for compression.  The fields |      Initializes the internal stream state for compression.  The fields | ||||||
|    zalloc, zfree and opaque must be initialized before by the caller.  If |    zalloc, zfree and opaque must be initialized before by the caller.  If | ||||||
|    zalloc and zfree are set to Z_NULL, deflateInit updates them to use default |    zalloc and zfree are set to Z_NULL, deflateInit updates them to use default | ||||||
|    allocation functions. |    allocation functions.  total_in, total_out, adler, and msg are initialized. | ||||||
|  |  | ||||||
|      The compression level must be Z_DEFAULT_COMPRESSION, or between 0 and 9: |      The compression level must be Z_DEFAULT_COMPRESSION, or between 0 and 9: | ||||||
|    1 gives best speed, 9 gives best compression, 0 gives no compression at all |    1 gives best speed, 9 gives best compression, 0 gives no compression at all | ||||||
| @@ -247,7 +247,7 @@ ZEXTERN int ZEXPORT deflateInit OF((z_streamp strm, int level)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflate OF((z_streamp strm, int flush)); | ZEXTERN int ZEXPORT deflate(z_streamp strm, int flush); | ||||||
| /* | /* | ||||||
|     deflate compresses as much data as possible, and stops when the input |     deflate compresses as much data as possible, and stops when the input | ||||||
|   buffer becomes empty or the output buffer becomes full.  It may introduce |   buffer becomes empty or the output buffer becomes full.  It may introduce | ||||||
| @@ -320,8 +320,8 @@ ZEXTERN int ZEXPORT deflate OF((z_streamp strm, int flush)); | |||||||
|   with the same value of the flush parameter and more output space (updated |   with the same value of the flush parameter and more output space (updated | ||||||
|   avail_out), until the flush is complete (deflate returns with non-zero |   avail_out), until the flush is complete (deflate returns with non-zero | ||||||
|   avail_out).  In the case of a Z_FULL_FLUSH or Z_SYNC_FLUSH, make sure that |   avail_out).  In the case of a Z_FULL_FLUSH or Z_SYNC_FLUSH, make sure that | ||||||
|   avail_out is greater than six to avoid repeated flush markers due to |   avail_out is greater than six when the flush marker begins, in order to avoid | ||||||
|   avail_out == 0 on return. |   repeated flush markers upon calling deflate() again when avail_out == 0. | ||||||
|  |  | ||||||
|     If the parameter flush is set to Z_FINISH, pending input is processed, |     If the parameter flush is set to Z_FINISH, pending input is processed, | ||||||
|   pending output is flushed and deflate returns with Z_STREAM_END if there was |   pending output is flushed and deflate returns with Z_STREAM_END if there was | ||||||
| @@ -360,7 +360,7 @@ ZEXTERN int ZEXPORT deflate OF((z_streamp strm, int flush)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateEnd OF((z_streamp strm)); | ZEXTERN int ZEXPORT deflateEnd(z_streamp strm); | ||||||
| /* | /* | ||||||
|      All dynamically allocated data structures for this stream are freed. |      All dynamically allocated data structures for this stream are freed. | ||||||
|    This function discards any unprocessed input and does not flush any pending |    This function discards any unprocessed input and does not flush any pending | ||||||
| @@ -375,7 +375,7 @@ ZEXTERN int ZEXPORT deflateEnd OF((z_streamp strm)); | |||||||
|  |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN int ZEXPORT inflateInit OF((z_streamp strm)); | ZEXTERN int ZEXPORT inflateInit(z_streamp strm); | ||||||
|  |  | ||||||
|      Initializes the internal stream state for decompression.  The fields |      Initializes the internal stream state for decompression.  The fields | ||||||
|    next_in, avail_in, zalloc, zfree and opaque must be initialized before by |    next_in, avail_in, zalloc, zfree and opaque must be initialized before by | ||||||
| @@ -383,7 +383,8 @@ ZEXTERN int ZEXPORT inflateInit OF((z_streamp strm)); | |||||||
|    read or consumed.  The allocation of a sliding window will be deferred to |    read or consumed.  The allocation of a sliding window will be deferred to | ||||||
|    the first call of inflate (if the decompression does not complete on the |    the first call of inflate (if the decompression does not complete on the | ||||||
|    first call).  If zalloc and zfree are set to Z_NULL, inflateInit updates |    first call).  If zalloc and zfree are set to Z_NULL, inflateInit updates | ||||||
|    them to use default allocation functions. |    them to use default allocation functions.  total_in, total_out, adler, and | ||||||
|  |    msg are initialized. | ||||||
|  |  | ||||||
|      inflateInit returns Z_OK if success, Z_MEM_ERROR if there was not enough |      inflateInit returns Z_OK if success, Z_MEM_ERROR if there was not enough | ||||||
|    memory, Z_VERSION_ERROR if the zlib library version is incompatible with the |    memory, Z_VERSION_ERROR if the zlib library version is incompatible with the | ||||||
| @@ -397,7 +398,7 @@ ZEXTERN int ZEXPORT inflateInit OF((z_streamp strm)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflate OF((z_streamp strm, int flush)); | ZEXTERN int ZEXPORT inflate(z_streamp strm, int flush); | ||||||
| /* | /* | ||||||
|     inflate decompresses as much data as possible, and stops when the input |     inflate decompresses as much data as possible, and stops when the input | ||||||
|   buffer becomes empty or the output buffer becomes full.  It may introduce |   buffer becomes empty or the output buffer becomes full.  It may introduce | ||||||
| @@ -517,7 +518,7 @@ ZEXTERN int ZEXPORT inflate OF((z_streamp strm, int flush)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateEnd OF((z_streamp strm)); | ZEXTERN int ZEXPORT inflateEnd(z_streamp strm); | ||||||
| /* | /* | ||||||
|      All dynamically allocated data structures for this stream are freed. |      All dynamically allocated data structures for this stream are freed. | ||||||
|    This function discards any unprocessed input and does not flush any pending |    This function discards any unprocessed input and does not flush any pending | ||||||
| @@ -535,12 +536,12 @@ ZEXTERN int ZEXPORT inflateEnd OF((z_streamp strm)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN int ZEXPORT deflateInit2 OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateInit2(z_streamp strm, | ||||||
|                                      int  level, |                                  int level, | ||||||
|                                      int  method, |                                  int method, | ||||||
|                                      int  windowBits, |                                  int windowBits, | ||||||
|                                      int  memLevel, |                                  int memLevel, | ||||||
|                                      int  strategy)); |                                  int strategy); | ||||||
|  |  | ||||||
|      This is another version of deflateInit with more compression options.  The |      This is another version of deflateInit with more compression options.  The | ||||||
|    fields zalloc, zfree and opaque must be initialized before by the caller. |    fields zalloc, zfree and opaque must be initialized before by the caller. | ||||||
| @@ -607,9 +608,9 @@ ZEXTERN int ZEXPORT deflateInit2 OF((z_streamp strm, | |||||||
|    compression: this will be done by deflate(). |    compression: this will be done by deflate(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateSetDictionary OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateSetDictionary(z_streamp strm, | ||||||
|                                              const Bytef *dictionary, |                                          const Bytef *dictionary, | ||||||
|                                              uInt  dictLength)); |                                          uInt  dictLength); | ||||||
| /* | /* | ||||||
|      Initializes the compression dictionary from the given byte sequence |      Initializes the compression dictionary from the given byte sequence | ||||||
|    without producing any compressed output.  When using the zlib format, this |    without producing any compressed output.  When using the zlib format, this | ||||||
| @@ -651,9 +652,9 @@ ZEXTERN int ZEXPORT deflateSetDictionary OF((z_streamp strm, | |||||||
|    not perform any compression: this will be done by deflate(). |    not perform any compression: this will be done by deflate(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateGetDictionary OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateGetDictionary(z_streamp strm, | ||||||
|                                              Bytef *dictionary, |                                          Bytef *dictionary, | ||||||
|                                              uInt  *dictLength)); |                                          uInt  *dictLength); | ||||||
| /* | /* | ||||||
|      Returns the sliding dictionary being maintained by deflate.  dictLength is |      Returns the sliding dictionary being maintained by deflate.  dictLength is | ||||||
|    set to the number of bytes in the dictionary, and that many bytes are copied |    set to the number of bytes in the dictionary, and that many bytes are copied | ||||||
| @@ -673,8 +674,8 @@ ZEXTERN int ZEXPORT deflateGetDictionary OF((z_streamp strm, | |||||||
|    stream state is inconsistent. |    stream state is inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateCopy OF((z_streamp dest, | ZEXTERN int ZEXPORT deflateCopy(z_streamp dest, | ||||||
|                                     z_streamp source)); |                                 z_streamp source); | ||||||
| /* | /* | ||||||
|      Sets the destination stream as a complete copy of the source stream. |      Sets the destination stream as a complete copy of the source stream. | ||||||
|  |  | ||||||
| @@ -691,20 +692,20 @@ ZEXTERN int ZEXPORT deflateCopy OF((z_streamp dest, | |||||||
|    destination. |    destination. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateReset OF((z_streamp strm)); | ZEXTERN int ZEXPORT deflateReset(z_streamp strm); | ||||||
| /* | /* | ||||||
|      This function is equivalent to deflateEnd followed by deflateInit, but |      This function is equivalent to deflateEnd followed by deflateInit, but | ||||||
|    does not free and reallocate the internal compression state.  The stream |    does not free and reallocate the internal compression state.  The stream | ||||||
|    will leave the compression level and any other attributes that may have been |    will leave the compression level and any other attributes that may have been | ||||||
|    set unchanged. |    set unchanged.  total_in, total_out, adler, and msg are initialized. | ||||||
|  |  | ||||||
|      deflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source |      deflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source | ||||||
|    stream state was inconsistent (such as zalloc or state being Z_NULL). |    stream state was inconsistent (such as zalloc or state being Z_NULL). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateParams OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateParams(z_streamp strm, | ||||||
|                                       int level, |                                   int level, | ||||||
|                                       int strategy)); |                                   int strategy); | ||||||
| /* | /* | ||||||
|      Dynamically update the compression level and compression strategy.  The |      Dynamically update the compression level and compression strategy.  The | ||||||
|    interpretation of level and strategy is as in deflateInit2().  This can be |    interpretation of level and strategy is as in deflateInit2().  This can be | ||||||
| @@ -729,7 +730,7 @@ ZEXTERN int ZEXPORT deflateParams OF((z_streamp strm, | |||||||
|    Then no more input data should be provided before the deflateParams() call. |    Then no more input data should be provided before the deflateParams() call. | ||||||
|    If this is done, the old level and strategy will be applied to the data |    If this is done, the old level and strategy will be applied to the data | ||||||
|    compressed before deflateParams(), and the new level and strategy will be |    compressed before deflateParams(), and the new level and strategy will be | ||||||
|    applied to the the data compressed after deflateParams(). |    applied to the data compressed after deflateParams(). | ||||||
|  |  | ||||||
|      deflateParams returns Z_OK on success, Z_STREAM_ERROR if the source stream |      deflateParams returns Z_OK on success, Z_STREAM_ERROR if the source stream | ||||||
|    state was inconsistent or if a parameter was invalid, or Z_BUF_ERROR if |    state was inconsistent or if a parameter was invalid, or Z_BUF_ERROR if | ||||||
| @@ -740,11 +741,11 @@ ZEXTERN int ZEXPORT deflateParams OF((z_streamp strm, | |||||||
|    retried with more output space. |    retried with more output space. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateTune OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateTune(z_streamp strm, | ||||||
|                                     int good_length, |                                 int good_length, | ||||||
|                                     int max_lazy, |                                 int max_lazy, | ||||||
|                                     int nice_length, |                                 int nice_length, | ||||||
|                                     int max_chain)); |                                 int max_chain); | ||||||
| /* | /* | ||||||
|      Fine tune deflate's internal compression parameters.  This should only be |      Fine tune deflate's internal compression parameters.  This should only be | ||||||
|    used by someone who understands the algorithm used by zlib's deflate for |    used by someone who understands the algorithm used by zlib's deflate for | ||||||
| @@ -757,8 +758,8 @@ ZEXTERN int ZEXPORT deflateTune OF((z_streamp strm, | |||||||
|    returns Z_OK on success, or Z_STREAM_ERROR for an invalid deflate stream. |    returns Z_OK on success, or Z_STREAM_ERROR for an invalid deflate stream. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT deflateBound OF((z_streamp strm, | ZEXTERN uLong ZEXPORT deflateBound(z_streamp strm, | ||||||
|                                        uLong sourceLen)); |                                    uLong sourceLen); | ||||||
| /* | /* | ||||||
|      deflateBound() returns an upper bound on the compressed size after |      deflateBound() returns an upper bound on the compressed size after | ||||||
|    deflation of sourceLen bytes.  It must be called after deflateInit() or |    deflation of sourceLen bytes.  It must be called after deflateInit() or | ||||||
| @@ -772,9 +773,9 @@ ZEXTERN uLong ZEXPORT deflateBound OF((z_streamp strm, | |||||||
|    than Z_FINISH or Z_NO_FLUSH are used. |    than Z_FINISH or Z_NO_FLUSH are used. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflatePending OF((z_streamp strm, | ZEXTERN int ZEXPORT deflatePending(z_streamp strm, | ||||||
|                                        unsigned *pending, |                                    unsigned *pending, | ||||||
|                                        int *bits)); |                                    int *bits); | ||||||
| /* | /* | ||||||
|      deflatePending() returns the number of bytes and bits of output that have |      deflatePending() returns the number of bytes and bits of output that have | ||||||
|    been generated, but not yet provided in the available output.  The bytes not |    been generated, but not yet provided in the available output.  The bytes not | ||||||
| @@ -787,9 +788,9 @@ ZEXTERN int ZEXPORT deflatePending OF((z_streamp strm, | |||||||
|    stream state was inconsistent. |    stream state was inconsistent. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflatePrime OF((z_streamp strm, | ZEXTERN int ZEXPORT deflatePrime(z_streamp strm, | ||||||
|                                      int bits, |                                  int bits, | ||||||
|                                      int value)); |                                  int value); | ||||||
| /* | /* | ||||||
|      deflatePrime() inserts bits in the deflate output stream.  The intent |      deflatePrime() inserts bits in the deflate output stream.  The intent | ||||||
|    is that this function is used to start off the deflate output with the bits |    is that this function is used to start off the deflate output with the bits | ||||||
| @@ -804,8 +805,8 @@ ZEXTERN int ZEXPORT deflatePrime OF((z_streamp strm, | |||||||
|    source stream state was inconsistent. |    source stream state was inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateSetHeader OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateSetHeader(z_streamp strm, | ||||||
|                                          gz_headerp head)); |                                      gz_headerp head); | ||||||
| /* | /* | ||||||
|      deflateSetHeader() provides gzip header information for when a gzip |      deflateSetHeader() provides gzip header information for when a gzip | ||||||
|    stream is requested by deflateInit2().  deflateSetHeader() may be called |    stream is requested by deflateInit2().  deflateSetHeader() may be called | ||||||
| @@ -821,16 +822,17 @@ ZEXTERN int ZEXPORT deflateSetHeader OF((z_streamp strm, | |||||||
|    gzip file" and give up. |    gzip file" and give up. | ||||||
|  |  | ||||||
|      If deflateSetHeader is not used, the default gzip header has text false, |      If deflateSetHeader is not used, the default gzip header has text false, | ||||||
|    the time set to zero, and os set to 255, with no extra, name, or comment |    the time set to zero, and os set to the current operating system, with no | ||||||
|    fields.  The gzip header is returned to the default state by deflateReset(). |    extra, name, or comment fields.  The gzip header is returned to the default | ||||||
|  |    state by deflateReset(). | ||||||
|  |  | ||||||
|      deflateSetHeader returns Z_OK if success, or Z_STREAM_ERROR if the source |      deflateSetHeader returns Z_OK if success, or Z_STREAM_ERROR if the source | ||||||
|    stream state was inconsistent. |    stream state was inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN int ZEXPORT inflateInit2 OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateInit2(z_streamp strm, | ||||||
|                                      int  windowBits)); |                                  int windowBits); | ||||||
|  |  | ||||||
|      This is another version of inflateInit with an extra parameter.  The |      This is another version of inflateInit with an extra parameter.  The | ||||||
|    fields next_in, avail_in, zalloc, zfree and opaque must be initialized |    fields next_in, avail_in, zalloc, zfree and opaque must be initialized | ||||||
| @@ -883,9 +885,9 @@ ZEXTERN int ZEXPORT inflateInit2 OF((z_streamp strm, | |||||||
|    deferred until inflate() is called. |    deferred until inflate() is called. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateSetDictionary OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateSetDictionary(z_streamp strm, | ||||||
|                                              const Bytef *dictionary, |                                          const Bytef *dictionary, | ||||||
|                                              uInt  dictLength)); |                                          uInt  dictLength); | ||||||
| /* | /* | ||||||
|      Initializes the decompression dictionary from the given uncompressed byte |      Initializes the decompression dictionary from the given uncompressed byte | ||||||
|    sequence.  This function must be called immediately after a call of inflate, |    sequence.  This function must be called immediately after a call of inflate, | ||||||
| @@ -906,9 +908,9 @@ ZEXTERN int ZEXPORT inflateSetDictionary OF((z_streamp strm, | |||||||
|    inflate(). |    inflate(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateGetDictionary OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateGetDictionary(z_streamp strm, | ||||||
|                                              Bytef *dictionary, |                                          Bytef *dictionary, | ||||||
|                                              uInt  *dictLength)); |                                          uInt  *dictLength); | ||||||
| /* | /* | ||||||
|      Returns the sliding dictionary being maintained by inflate.  dictLength is |      Returns the sliding dictionary being maintained by inflate.  dictLength is | ||||||
|    set to the number of bytes in the dictionary, and that many bytes are copied |    set to the number of bytes in the dictionary, and that many bytes are copied | ||||||
| @@ -921,7 +923,7 @@ ZEXTERN int ZEXPORT inflateGetDictionary OF((z_streamp strm, | |||||||
|    stream state is inconsistent. |    stream state is inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateSync OF((z_streamp strm)); | ZEXTERN int ZEXPORT inflateSync(z_streamp strm); | ||||||
| /* | /* | ||||||
|      Skips invalid compressed data until a possible full flush point (see above |      Skips invalid compressed data until a possible full flush point (see above | ||||||
|    for the description of deflate with Z_FULL_FLUSH) can be found, or until all |    for the description of deflate with Z_FULL_FLUSH) can be found, or until all | ||||||
| @@ -940,8 +942,8 @@ ZEXTERN int ZEXPORT inflateSync OF((z_streamp strm)); | |||||||
|    input each time, until success or end of the input data. |    input each time, until success or end of the input data. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateCopy OF((z_streamp dest, | ZEXTERN int ZEXPORT inflateCopy(z_streamp dest, | ||||||
|                                     z_streamp source)); |                                 z_streamp source); | ||||||
| /* | /* | ||||||
|      Sets the destination stream as a complete copy of the source stream. |      Sets the destination stream as a complete copy of the source stream. | ||||||
|  |  | ||||||
| @@ -956,18 +958,19 @@ ZEXTERN int ZEXPORT inflateCopy OF((z_streamp dest, | |||||||
|    destination. |    destination. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateReset OF((z_streamp strm)); | ZEXTERN int ZEXPORT inflateReset(z_streamp strm); | ||||||
| /* | /* | ||||||
|      This function is equivalent to inflateEnd followed by inflateInit, |      This function is equivalent to inflateEnd followed by inflateInit, | ||||||
|    but does not free and reallocate the internal decompression state.  The |    but does not free and reallocate the internal decompression state.  The | ||||||
|    stream will keep attributes that may have been set by inflateInit2. |    stream will keep attributes that may have been set by inflateInit2. | ||||||
|  |    total_in, total_out, adler, and msg are initialized. | ||||||
|  |  | ||||||
|      inflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source |      inflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source | ||||||
|    stream state was inconsistent (such as zalloc or state being Z_NULL). |    stream state was inconsistent (such as zalloc or state being Z_NULL). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateReset2 OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateReset2(z_streamp strm, | ||||||
|                                       int windowBits)); |                                   int windowBits); | ||||||
| /* | /* | ||||||
|      This function is the same as inflateReset, but it also permits changing |      This function is the same as inflateReset, but it also permits changing | ||||||
|    the wrap and window size requests.  The windowBits parameter is interpreted |    the wrap and window size requests.  The windowBits parameter is interpreted | ||||||
| @@ -980,9 +983,9 @@ ZEXTERN int ZEXPORT inflateReset2 OF((z_streamp strm, | |||||||
|    the windowBits parameter is invalid. |    the windowBits parameter is invalid. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflatePrime OF((z_streamp strm, | ZEXTERN int ZEXPORT inflatePrime(z_streamp strm, | ||||||
|                                      int bits, |                                  int bits, | ||||||
|                                      int value)); |                                  int value); | ||||||
| /* | /* | ||||||
|      This function inserts bits in the inflate input stream.  The intent is |      This function inserts bits in the inflate input stream.  The intent is | ||||||
|    that this function is used to start inflating at a bit position in the |    that this function is used to start inflating at a bit position in the | ||||||
| @@ -1001,7 +1004,7 @@ ZEXTERN int ZEXPORT inflatePrime OF((z_streamp strm, | |||||||
|    stream state was inconsistent. |    stream state was inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN long ZEXPORT inflateMark OF((z_streamp strm)); | ZEXTERN long ZEXPORT inflateMark(z_streamp strm); | ||||||
| /* | /* | ||||||
|      This function returns two values, one in the lower 16 bits of the return |      This function returns two values, one in the lower 16 bits of the return | ||||||
|    value, and the other in the remaining upper bits, obtained by shifting the |    value, and the other in the remaining upper bits, obtained by shifting the | ||||||
| @@ -1029,8 +1032,8 @@ ZEXTERN long ZEXPORT inflateMark OF((z_streamp strm)); | |||||||
|    source stream state was inconsistent. |    source stream state was inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateGetHeader OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateGetHeader(z_streamp strm, | ||||||
|                                          gz_headerp head)); |                                      gz_headerp head); | ||||||
| /* | /* | ||||||
|      inflateGetHeader() requests that gzip header information be stored in the |      inflateGetHeader() requests that gzip header information be stored in the | ||||||
|    provided gz_header structure.  inflateGetHeader() may be called after |    provided gz_header structure.  inflateGetHeader() may be called after | ||||||
| @@ -1070,8 +1073,8 @@ ZEXTERN int ZEXPORT inflateGetHeader OF((z_streamp strm, | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN int ZEXPORT inflateBackInit OF((z_streamp strm, int windowBits, | ZEXTERN int ZEXPORT inflateBackInit(z_streamp strm, int windowBits, | ||||||
|                                         unsigned char FAR *window)); |                                     unsigned char FAR *window); | ||||||
|  |  | ||||||
|      Initialize the internal stream state for decompression using inflateBack() |      Initialize the internal stream state for decompression using inflateBack() | ||||||
|    calls.  The fields zalloc, zfree and opaque in strm must be initialized |    calls.  The fields zalloc, zfree and opaque in strm must be initialized | ||||||
| @@ -1091,13 +1094,13 @@ ZEXTERN int ZEXPORT inflateBackInit OF((z_streamp strm, int windowBits, | |||||||
|    the version of the header file. |    the version of the header file. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| typedef unsigned (*in_func) OF((void FAR *, | typedef unsigned (*in_func)(void FAR *, | ||||||
|                                 z_const unsigned char FAR * FAR *)); |                             z_const unsigned char FAR * FAR *); | ||||||
| typedef int (*out_func) OF((void FAR *, unsigned char FAR *, unsigned)); | typedef int (*out_func)(void FAR *, unsigned char FAR *, unsigned); | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateBack OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateBack(z_streamp strm, | ||||||
|                                     in_func in, void FAR *in_desc, |                                 in_func in, void FAR *in_desc, | ||||||
|                                     out_func out, void FAR *out_desc)); |                                 out_func out, void FAR *out_desc); | ||||||
| /* | /* | ||||||
|      inflateBack() does a raw inflate with a single call using a call-back |      inflateBack() does a raw inflate with a single call using a call-back | ||||||
|    interface for input and output.  This is potentially more efficient than |    interface for input and output.  This is potentially more efficient than | ||||||
| @@ -1165,7 +1168,7 @@ ZEXTERN int ZEXPORT inflateBack OF((z_streamp strm, | |||||||
|    cannot return Z_OK. |    cannot return Z_OK. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateBackEnd OF((z_streamp strm)); | ZEXTERN int ZEXPORT inflateBackEnd(z_streamp strm); | ||||||
| /* | /* | ||||||
|      All memory allocated by inflateBackInit() is freed. |      All memory allocated by inflateBackInit() is freed. | ||||||
|  |  | ||||||
| @@ -1173,7 +1176,7 @@ ZEXTERN int ZEXPORT inflateBackEnd OF((z_streamp strm)); | |||||||
|    state was inconsistent. |    state was inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT zlibCompileFlags OF((void)); | ZEXTERN uLong ZEXPORT zlibCompileFlags(void); | ||||||
| /* Return flags indicating compile-time options. | /* Return flags indicating compile-time options. | ||||||
|  |  | ||||||
|     Type sizes, two bits each, 00 = 16 bits, 01 = 32, 10 = 64, 11 = other: |     Type sizes, two bits each, 00 = 16 bits, 01 = 32, 10 = 64, 11 = other: | ||||||
| @@ -1226,8 +1229,8 @@ ZEXTERN uLong ZEXPORT zlibCompileFlags OF((void)); | |||||||
|    you need special options. |    you need special options. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT compress OF((Bytef *dest,   uLongf *destLen, | ZEXTERN int ZEXPORT compress(Bytef *dest,   uLongf *destLen, | ||||||
|                                  const Bytef *source, uLong sourceLen)); |                              const Bytef *source, uLong sourceLen); | ||||||
| /* | /* | ||||||
|      Compresses the source buffer into the destination buffer.  sourceLen is |      Compresses the source buffer into the destination buffer.  sourceLen is | ||||||
|    the byte length of the source buffer.  Upon entry, destLen is the total size |    the byte length of the source buffer.  Upon entry, destLen is the total size | ||||||
| @@ -1241,9 +1244,9 @@ ZEXTERN int ZEXPORT compress OF((Bytef *dest,   uLongf *destLen, | |||||||
|    buffer. |    buffer. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT compress2 OF((Bytef *dest,   uLongf *destLen, | ZEXTERN int ZEXPORT compress2(Bytef *dest,   uLongf *destLen, | ||||||
|                                   const Bytef *source, uLong sourceLen, |                               const Bytef *source, uLong sourceLen, | ||||||
|                                   int level)); |                               int level); | ||||||
| /* | /* | ||||||
|      Compresses the source buffer into the destination buffer.  The level |      Compresses the source buffer into the destination buffer.  The level | ||||||
|    parameter has the same meaning as in deflateInit.  sourceLen is the byte |    parameter has the same meaning as in deflateInit.  sourceLen is the byte | ||||||
| @@ -1257,15 +1260,15 @@ ZEXTERN int ZEXPORT compress2 OF((Bytef *dest,   uLongf *destLen, | |||||||
|    Z_STREAM_ERROR if the level parameter is invalid. |    Z_STREAM_ERROR if the level parameter is invalid. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT compressBound OF((uLong sourceLen)); | ZEXTERN uLong ZEXPORT compressBound(uLong sourceLen); | ||||||
| /* | /* | ||||||
|      compressBound() returns an upper bound on the compressed size after |      compressBound() returns an upper bound on the compressed size after | ||||||
|    compress() or compress2() on sourceLen bytes.  It would be used before a |    compress() or compress2() on sourceLen bytes.  It would be used before a | ||||||
|    compress() or compress2() call to allocate the destination buffer. |    compress() or compress2() call to allocate the destination buffer. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT uncompress OF((Bytef *dest,   uLongf *destLen, | ZEXTERN int ZEXPORT uncompress(Bytef *dest,   uLongf *destLen, | ||||||
|                                    const Bytef *source, uLong sourceLen)); |                                const Bytef *source, uLong sourceLen); | ||||||
| /* | /* | ||||||
|      Decompresses the source buffer into the destination buffer.  sourceLen is |      Decompresses the source buffer into the destination buffer.  sourceLen is | ||||||
|    the byte length of the source buffer.  Upon entry, destLen is the total size |    the byte length of the source buffer.  Upon entry, destLen is the total size | ||||||
| @@ -1282,8 +1285,8 @@ ZEXTERN int ZEXPORT uncompress OF((Bytef *dest,   uLongf *destLen, | |||||||
|    buffer with the uncompressed data up to that point. |    buffer with the uncompressed data up to that point. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT uncompress2 OF((Bytef *dest,   uLongf *destLen, | ZEXTERN int ZEXPORT uncompress2(Bytef *dest,   uLongf *destLen, | ||||||
|                                     const Bytef *source, uLong *sourceLen)); |                                 const Bytef *source, uLong *sourceLen); | ||||||
| /* | /* | ||||||
|      Same as uncompress, except that sourceLen is a pointer, where the |      Same as uncompress, except that sourceLen is a pointer, where the | ||||||
|    length of the source is *sourceLen.  On return, *sourceLen is the number of |    length of the source is *sourceLen.  On return, *sourceLen is the number of | ||||||
| @@ -1302,7 +1305,7 @@ ZEXTERN int ZEXPORT uncompress2 OF((Bytef *dest,   uLongf *destLen, | |||||||
| typedef struct gzFile_s *gzFile;    /* semi-opaque gzip file descriptor */ | typedef struct gzFile_s *gzFile;    /* semi-opaque gzip file descriptor */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN gzFile ZEXPORT gzopen OF((const char *path, const char *mode)); | ZEXTERN gzFile ZEXPORT gzopen(const char *path, const char *mode); | ||||||
|  |  | ||||||
|      Open the gzip (.gz) file at path for reading and decompressing, or |      Open the gzip (.gz) file at path for reading and decompressing, or | ||||||
|    compressing and writing.  The mode parameter is as in fopen ("rb" or "wb") |    compressing and writing.  The mode parameter is as in fopen ("rb" or "wb") | ||||||
| @@ -1339,7 +1342,7 @@ ZEXTERN gzFile ZEXPORT gzopen OF((const char *path, const char *mode)); | |||||||
|    file could not be opened. |    file could not be opened. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN gzFile ZEXPORT gzdopen OF((int fd, const char *mode)); | ZEXTERN gzFile ZEXPORT gzdopen(int fd, const char *mode); | ||||||
| /* | /* | ||||||
|      Associate a gzFile with the file descriptor fd.  File descriptors are |      Associate a gzFile with the file descriptor fd.  File descriptors are | ||||||
|    obtained from calls like open, dup, creat, pipe or fileno (if the file has |    obtained from calls like open, dup, creat, pipe or fileno (if the file has | ||||||
| @@ -1362,7 +1365,7 @@ ZEXTERN gzFile ZEXPORT gzdopen OF((int fd, const char *mode)); | |||||||
|    will not detect if fd is invalid (unless fd is -1). |    will not detect if fd is invalid (unless fd is -1). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzbuffer OF((gzFile file, unsigned size)); | ZEXTERN int ZEXPORT gzbuffer(gzFile file, unsigned size); | ||||||
| /* | /* | ||||||
|      Set the internal buffer size used by this library's functions for file to |      Set the internal buffer size used by this library's functions for file to | ||||||
|    size.  The default buffer size is 8192 bytes.  This function must be called |    size.  The default buffer size is 8192 bytes.  This function must be called | ||||||
| @@ -1378,7 +1381,7 @@ ZEXTERN int ZEXPORT gzbuffer OF((gzFile file, unsigned size)); | |||||||
|    too late. |    too late. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzsetparams OF((gzFile file, int level, int strategy)); | ZEXTERN int ZEXPORT gzsetparams(gzFile file, int level, int strategy); | ||||||
| /* | /* | ||||||
|      Dynamically update the compression level and strategy for file.  See the |      Dynamically update the compression level and strategy for file.  See the | ||||||
|    description of deflateInit2 for the meaning of these parameters. Previously |    description of deflateInit2 for the meaning of these parameters. Previously | ||||||
| @@ -1389,7 +1392,7 @@ ZEXTERN int ZEXPORT gzsetparams OF((gzFile file, int level, int strategy)); | |||||||
|    or Z_MEM_ERROR if there is a memory allocation error. |    or Z_MEM_ERROR if there is a memory allocation error. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzread OF((gzFile file, voidp buf, unsigned len)); | ZEXTERN int ZEXPORT gzread(gzFile file, voidp buf, unsigned len); | ||||||
| /* | /* | ||||||
|      Read and decompress up to len uncompressed bytes from file into buf.  If |      Read and decompress up to len uncompressed bytes from file into buf.  If | ||||||
|    the input file is not in gzip format, gzread copies the given number of |    the input file is not in gzip format, gzread copies the given number of | ||||||
| @@ -1419,8 +1422,8 @@ ZEXTERN int ZEXPORT gzread OF((gzFile file, voidp buf, unsigned len)); | |||||||
|    Z_STREAM_ERROR. |    Z_STREAM_ERROR. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN z_size_t ZEXPORT gzfread OF((voidp buf, z_size_t size, z_size_t nitems, | ZEXTERN z_size_t ZEXPORT gzfread(voidp buf, z_size_t size, z_size_t nitems, | ||||||
|                                      gzFile file)); |                                  gzFile file); | ||||||
| /* | /* | ||||||
|      Read and decompress up to nitems items of size size from file into buf, |      Read and decompress up to nitems items of size size from file into buf, | ||||||
|    otherwise operating as gzread() does.  This duplicates the interface of |    otherwise operating as gzread() does.  This duplicates the interface of | ||||||
| @@ -1445,14 +1448,14 @@ ZEXTERN z_size_t ZEXPORT gzfread OF((voidp buf, z_size_t size, z_size_t nitems, | |||||||
|    file, resetting and retrying on end-of-file, when size is not 1. |    file, resetting and retrying on end-of-file, when size is not 1. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzwrite OF((gzFile file, voidpc buf, unsigned len)); | ZEXTERN int ZEXPORT gzwrite(gzFile file, voidpc buf, unsigned len); | ||||||
| /* | /* | ||||||
|      Compress and write the len uncompressed bytes at buf to file. gzwrite |      Compress and write the len uncompressed bytes at buf to file. gzwrite | ||||||
|    returns the number of uncompressed bytes written or 0 in case of error. |    returns the number of uncompressed bytes written or 0 in case of error. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN z_size_t ZEXPORT gzfwrite OF((voidpc buf, z_size_t size, | ZEXTERN z_size_t ZEXPORT gzfwrite(voidpc buf, z_size_t size, | ||||||
|                                       z_size_t nitems, gzFile file)); |                                   z_size_t nitems, gzFile file); | ||||||
| /* | /* | ||||||
|      Compress and write nitems items of size size from buf to file, duplicating |      Compress and write nitems items of size size from buf to file, duplicating | ||||||
|    the interface of stdio's fwrite(), with size_t request and return types.  If |    the interface of stdio's fwrite(), with size_t request and return types.  If | ||||||
| @@ -1465,7 +1468,7 @@ ZEXTERN z_size_t ZEXPORT gzfwrite OF((voidpc buf, z_size_t size, | |||||||
|    is returned, and the error state is set to Z_STREAM_ERROR. |    is returned, and the error state is set to Z_STREAM_ERROR. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORTVA gzprintf Z_ARG((gzFile file, const char *format, ...)); | ZEXTERN int ZEXPORTVA gzprintf(gzFile file, const char *format, ...); | ||||||
| /* | /* | ||||||
|      Convert, format, compress, and write the arguments (...) to file under |      Convert, format, compress, and write the arguments (...) to file under | ||||||
|    control of the string format, as in fprintf.  gzprintf returns the number of |    control of the string format, as in fprintf.  gzprintf returns the number of | ||||||
| @@ -1480,7 +1483,7 @@ ZEXTERN int ZEXPORTVA gzprintf Z_ARG((gzFile file, const char *format, ...)); | |||||||
|    This can be determined using zlibCompileFlags(). |    This can be determined using zlibCompileFlags(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzputs OF((gzFile file, const char *s)); | ZEXTERN int ZEXPORT gzputs(gzFile file, const char *s); | ||||||
| /* | /* | ||||||
|      Compress and write the given null-terminated string s to file, excluding |      Compress and write the given null-terminated string s to file, excluding | ||||||
|    the terminating null character. |    the terminating null character. | ||||||
| @@ -1488,7 +1491,7 @@ ZEXTERN int ZEXPORT gzputs OF((gzFile file, const char *s)); | |||||||
|      gzputs returns the number of characters written, or -1 in case of error. |      gzputs returns the number of characters written, or -1 in case of error. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN char * ZEXPORT gzgets OF((gzFile file, char *buf, int len)); | ZEXTERN char * ZEXPORT gzgets(gzFile file, char *buf, int len); | ||||||
| /* | /* | ||||||
|      Read and decompress bytes from file into buf, until len-1 characters are |      Read and decompress bytes from file into buf, until len-1 characters are | ||||||
|    read, or until a newline character is read and transferred to buf, or an |    read, or until a newline character is read and transferred to buf, or an | ||||||
| @@ -1502,13 +1505,13 @@ ZEXTERN char * ZEXPORT gzgets OF((gzFile file, char *buf, int len)); | |||||||
|    buf are indeterminate. |    buf are indeterminate. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzputc OF((gzFile file, int c)); | ZEXTERN int ZEXPORT gzputc(gzFile file, int c); | ||||||
| /* | /* | ||||||
|      Compress and write c, converted to an unsigned char, into file.  gzputc |      Compress and write c, converted to an unsigned char, into file.  gzputc | ||||||
|    returns the value that was written, or -1 in case of error. |    returns the value that was written, or -1 in case of error. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzgetc OF((gzFile file)); | ZEXTERN int ZEXPORT gzgetc(gzFile file); | ||||||
| /* | /* | ||||||
|      Read and decompress one byte from file.  gzgetc returns this byte or -1 |      Read and decompress one byte from file.  gzgetc returns this byte or -1 | ||||||
|    in case of end of file or error.  This is implemented as a macro for speed. |    in case of end of file or error.  This is implemented as a macro for speed. | ||||||
| @@ -1517,7 +1520,7 @@ ZEXTERN int ZEXPORT gzgetc OF((gzFile file)); | |||||||
|    points to has been clobbered or not. |    points to has been clobbered or not. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzungetc OF((int c, gzFile file)); | ZEXTERN int ZEXPORT gzungetc(int c, gzFile file); | ||||||
| /* | /* | ||||||
|      Push c back onto the stream for file to be read as the first character on |      Push c back onto the stream for file to be read as the first character on | ||||||
|    the next read.  At least one character of push-back is always allowed. |    the next read.  At least one character of push-back is always allowed. | ||||||
| @@ -1529,7 +1532,7 @@ ZEXTERN int ZEXPORT gzungetc OF((int c, gzFile file)); | |||||||
|    gzseek() or gzrewind(). |    gzseek() or gzrewind(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzflush OF((gzFile file, int flush)); | ZEXTERN int ZEXPORT gzflush(gzFile file, int flush); | ||||||
| /* | /* | ||||||
|      Flush all pending output to file.  The parameter flush is as in the |      Flush all pending output to file.  The parameter flush is as in the | ||||||
|    deflate() function.  The return value is the zlib error number (see function |    deflate() function.  The return value is the zlib error number (see function | ||||||
| @@ -1545,8 +1548,8 @@ ZEXTERN int ZEXPORT gzflush OF((gzFile file, int flush)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN z_off_t ZEXPORT gzseek OF((gzFile file, | ZEXTERN z_off_t ZEXPORT gzseek(gzFile file, | ||||||
|                                    z_off_t offset, int whence)); |                                z_off_t offset, int whence); | ||||||
|  |  | ||||||
|      Set the starting position to offset relative to whence for the next gzread |      Set the starting position to offset relative to whence for the next gzread | ||||||
|    or gzwrite on file.  The offset represents a number of bytes in the |    or gzwrite on file.  The offset represents a number of bytes in the | ||||||
| @@ -1564,7 +1567,7 @@ ZEXTERN z_off_t ZEXPORT gzseek OF((gzFile file, | |||||||
|    would be before the current position. |    would be before the current position. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT    gzrewind OF((gzFile file)); | ZEXTERN int ZEXPORT    gzrewind(gzFile file); | ||||||
| /* | /* | ||||||
|      Rewind file. This function is supported only for reading. |      Rewind file. This function is supported only for reading. | ||||||
|  |  | ||||||
| @@ -1572,7 +1575,7 @@ ZEXTERN int ZEXPORT    gzrewind OF((gzFile file)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN z_off_t ZEXPORT    gztell OF((gzFile file)); | ZEXTERN z_off_t ZEXPORT    gztell(gzFile file); | ||||||
|  |  | ||||||
|      Return the starting position for the next gzread or gzwrite on file. |      Return the starting position for the next gzread or gzwrite on file. | ||||||
|    This position represents a number of bytes in the uncompressed data stream, |    This position represents a number of bytes in the uncompressed data stream, | ||||||
| @@ -1583,7 +1586,7 @@ ZEXTERN z_off_t ZEXPORT    gztell OF((gzFile file)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN z_off_t ZEXPORT gzoffset OF((gzFile file)); | ZEXTERN z_off_t ZEXPORT gzoffset(gzFile file); | ||||||
|  |  | ||||||
|      Return the current compressed (actual) read or write offset of file.  This |      Return the current compressed (actual) read or write offset of file.  This | ||||||
|    offset includes the count of bytes that precede the gzip stream, for example |    offset includes the count of bytes that precede the gzip stream, for example | ||||||
| @@ -1592,7 +1595,7 @@ ZEXTERN z_off_t ZEXPORT gzoffset OF((gzFile file)); | |||||||
|    be used for a progress indicator.  On error, gzoffset() returns -1. |    be used for a progress indicator.  On error, gzoffset() returns -1. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzeof OF((gzFile file)); | ZEXTERN int ZEXPORT gzeof(gzFile file); | ||||||
| /* | /* | ||||||
|      Return true (1) if the end-of-file indicator for file has been set while |      Return true (1) if the end-of-file indicator for file has been set while | ||||||
|    reading, false (0) otherwise.  Note that the end-of-file indicator is set |    reading, false (0) otherwise.  Note that the end-of-file indicator is set | ||||||
| @@ -1607,7 +1610,7 @@ ZEXTERN int ZEXPORT gzeof OF((gzFile file)); | |||||||
|    has grown since the previous end of file was detected. |    has grown since the previous end of file was detected. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzdirect OF((gzFile file)); | ZEXTERN int ZEXPORT gzdirect(gzFile file); | ||||||
| /* | /* | ||||||
|      Return true (1) if file is being copied directly while reading, or false |      Return true (1) if file is being copied directly while reading, or false | ||||||
|    (0) if file is a gzip stream being decompressed. |    (0) if file is a gzip stream being decompressed. | ||||||
| @@ -1628,7 +1631,7 @@ ZEXTERN int ZEXPORT gzdirect OF((gzFile file)); | |||||||
|    gzip file reading and decompression, which may not be desired.) |    gzip file reading and decompression, which may not be desired.) | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT    gzclose OF((gzFile file)); | ZEXTERN int ZEXPORT    gzclose(gzFile file); | ||||||
| /* | /* | ||||||
|      Flush all pending output for file, if necessary, close file and |      Flush all pending output for file, if necessary, close file and | ||||||
|    deallocate the (de)compression state.  Note that once file is closed, you |    deallocate the (de)compression state.  Note that once file is closed, you | ||||||
| @@ -1641,8 +1644,8 @@ ZEXTERN int ZEXPORT    gzclose OF((gzFile file)); | |||||||
|    last read ended in the middle of a gzip stream, or Z_OK on success. |    last read ended in the middle of a gzip stream, or Z_OK on success. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzclose_r OF((gzFile file)); | ZEXTERN int ZEXPORT gzclose_r(gzFile file); | ||||||
| ZEXTERN int ZEXPORT gzclose_w OF((gzFile file)); | ZEXTERN int ZEXPORT gzclose_w(gzFile file); | ||||||
| /* | /* | ||||||
|      Same as gzclose(), but gzclose_r() is only for use when reading, and |      Same as gzclose(), but gzclose_r() is only for use when reading, and | ||||||
|    gzclose_w() is only for use when writing or appending.  The advantage to |    gzclose_w() is only for use when writing or appending.  The advantage to | ||||||
| @@ -1653,7 +1656,7 @@ ZEXTERN int ZEXPORT gzclose_w OF((gzFile file)); | |||||||
|    zlib library. |    zlib library. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN const char * ZEXPORT gzerror OF((gzFile file, int *errnum)); | ZEXTERN const char * ZEXPORT gzerror(gzFile file, int *errnum); | ||||||
| /* | /* | ||||||
|      Return the error message for the last error which occurred on file. |      Return the error message for the last error which occurred on file. | ||||||
|    errnum is set to zlib error number.  If an error occurred in the file system |    errnum is set to zlib error number.  If an error occurred in the file system | ||||||
| @@ -1669,7 +1672,7 @@ ZEXTERN const char * ZEXPORT gzerror OF((gzFile file, int *errnum)); | |||||||
|    functions above that do not distinguish those cases in their return values. |    functions above that do not distinguish those cases in their return values. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN void ZEXPORT gzclearerr OF((gzFile file)); | ZEXTERN void ZEXPORT gzclearerr(gzFile file); | ||||||
| /* | /* | ||||||
|      Clear the error and end-of-file flags for file.  This is analogous to the |      Clear the error and end-of-file flags for file.  This is analogous to the | ||||||
|    clearerr() function in stdio.  This is useful for continuing to read a gzip |    clearerr() function in stdio.  This is useful for continuing to read a gzip | ||||||
| @@ -1686,7 +1689,7 @@ ZEXTERN void ZEXPORT gzclearerr OF((gzFile file)); | |||||||
|    library. |    library. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT adler32 OF((uLong adler, const Bytef *buf, uInt len)); | ZEXTERN uLong ZEXPORT adler32(uLong adler, const Bytef *buf, uInt len); | ||||||
| /* | /* | ||||||
|      Update a running Adler-32 checksum with the bytes buf[0..len-1] and |      Update a running Adler-32 checksum with the bytes buf[0..len-1] and | ||||||
|    return the updated checksum. An Adler-32 value is in the range of a 32-bit |    return the updated checksum. An Adler-32 value is in the range of a 32-bit | ||||||
| @@ -1706,15 +1709,15 @@ ZEXTERN uLong ZEXPORT adler32 OF((uLong adler, const Bytef *buf, uInt len)); | |||||||
|      if (adler != original_adler) error(); |      if (adler != original_adler) error(); | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT adler32_z OF((uLong adler, const Bytef *buf, | ZEXTERN uLong ZEXPORT adler32_z(uLong adler, const Bytef *buf, | ||||||
|                                     z_size_t len)); |                                 z_size_t len); | ||||||
| /* | /* | ||||||
|      Same as adler32(), but with a size_t length. |      Same as adler32(), but with a size_t length. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN uLong ZEXPORT adler32_combine OF((uLong adler1, uLong adler2, | ZEXTERN uLong ZEXPORT adler32_combine(uLong adler1, uLong adler2, | ||||||
|                                           z_off_t len2)); |                                       z_off_t len2); | ||||||
|  |  | ||||||
|      Combine two Adler-32 checksums into one.  For two sequences of bytes, seq1 |      Combine two Adler-32 checksums into one.  For two sequences of bytes, seq1 | ||||||
|    and seq2 with lengths len1 and len2, Adler-32 checksums were calculated for |    and seq2 with lengths len1 and len2, Adler-32 checksums were calculated for | ||||||
| @@ -1724,7 +1727,7 @@ ZEXTERN uLong ZEXPORT adler32_combine OF((uLong adler1, uLong adler2, | |||||||
|    negative, the result has no meaning or utility. |    negative, the result has no meaning or utility. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT crc32 OF((uLong crc, const Bytef *buf, uInt len)); | ZEXTERN uLong ZEXPORT crc32(uLong crc, const Bytef *buf, uInt len); | ||||||
| /* | /* | ||||||
|      Update a running CRC-32 with the bytes buf[0..len-1] and return the |      Update a running CRC-32 with the bytes buf[0..len-1] and return the | ||||||
|    updated CRC-32. A CRC-32 value is in the range of a 32-bit unsigned integer. |    updated CRC-32. A CRC-32 value is in the range of a 32-bit unsigned integer. | ||||||
| @@ -1742,14 +1745,14 @@ ZEXTERN uLong ZEXPORT crc32 OF((uLong crc, const Bytef *buf, uInt len)); | |||||||
|      if (crc != original_crc) error(); |      if (crc != original_crc) error(); | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT crc32_z OF((uLong crc, const Bytef *buf, | ZEXTERN uLong ZEXPORT crc32_z(uLong crc, const Bytef *buf, | ||||||
|                                   z_size_t len)); |                               z_size_t len); | ||||||
| /* | /* | ||||||
|      Same as crc32(), but with a size_t length. |      Same as crc32(), but with a size_t length. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN uLong ZEXPORT crc32_combine OF((uLong crc1, uLong crc2, z_off_t len2)); | ZEXTERN uLong ZEXPORT crc32_combine(uLong crc1, uLong crc2, z_off_t len2); | ||||||
|  |  | ||||||
|      Combine two CRC-32 check values into one.  For two sequences of bytes, |      Combine two CRC-32 check values into one.  For two sequences of bytes, | ||||||
|    seq1 and seq2 with lengths len1 and len2, CRC-32 check values were |    seq1 and seq2 with lengths len1 and len2, CRC-32 check values were | ||||||
| @@ -1759,13 +1762,13 @@ ZEXTERN uLong ZEXPORT crc32_combine OF((uLong crc1, uLong crc2, z_off_t len2)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN uLong ZEXPORT crc32_combine_gen OF((z_off_t len2)); | ZEXTERN uLong ZEXPORT crc32_combine_gen(z_off_t len2); | ||||||
|  |  | ||||||
|      Return the operator corresponding to length len2, to be used with |      Return the operator corresponding to length len2, to be used with | ||||||
|    crc32_combine_op(). |    crc32_combine_op(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT crc32_combine_op OF((uLong crc1, uLong crc2, uLong op)); | ZEXTERN uLong ZEXPORT crc32_combine_op(uLong crc1, uLong crc2, uLong op); | ||||||
| /* | /* | ||||||
|      Give the same result as crc32_combine(), using op in place of len2. op is |      Give the same result as crc32_combine(), using op in place of len2. op is | ||||||
|    is generated from len2 by crc32_combine_gen(). This will be faster than |    is generated from len2 by crc32_combine_gen(). This will be faster than | ||||||
| @@ -1778,20 +1781,20 @@ ZEXTERN uLong ZEXPORT crc32_combine_op OF((uLong crc1, uLong crc2, uLong op)); | |||||||
| /* deflateInit and inflateInit are macros to allow checking the zlib version | /* deflateInit and inflateInit are macros to allow checking the zlib version | ||||||
|  * and the compiler's view of z_stream: |  * and the compiler's view of z_stream: | ||||||
|  */ |  */ | ||||||
| ZEXTERN int ZEXPORT deflateInit_ OF((z_streamp strm, int level, | ZEXTERN int ZEXPORT deflateInit_(z_streamp strm, int level, | ||||||
|                                      const char *version, int stream_size)); |                                  const char *version, int stream_size); | ||||||
| ZEXTERN int ZEXPORT inflateInit_ OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateInit_(z_streamp strm, | ||||||
|                                      const char *version, int stream_size)); |                                  const char *version, int stream_size); | ||||||
| ZEXTERN int ZEXPORT deflateInit2_ OF((z_streamp strm, int  level, int  method, | ZEXTERN int ZEXPORT deflateInit2_(z_streamp strm, int  level, int  method, | ||||||
|                                       int windowBits, int memLevel, |                                   int windowBits, int memLevel, | ||||||
|                                       int strategy, const char *version, |                                   int strategy, const char *version, | ||||||
|                                       int stream_size)); |                                   int stream_size); | ||||||
| ZEXTERN int ZEXPORT inflateInit2_ OF((z_streamp strm, int  windowBits, | ZEXTERN int ZEXPORT inflateInit2_(z_streamp strm, int  windowBits, | ||||||
|                                       const char *version, int stream_size)); |                                   const char *version, int stream_size); | ||||||
| ZEXTERN int ZEXPORT inflateBackInit_ OF((z_streamp strm, int windowBits, | ZEXTERN int ZEXPORT inflateBackInit_(z_streamp strm, int windowBits, | ||||||
|                                          unsigned char FAR *window, |                                      unsigned char FAR *window, | ||||||
|                                          const char *version, |                                      const char *version, | ||||||
|                                          int stream_size)); |                                      int stream_size); | ||||||
| #ifdef Z_PREFIX_SET | #ifdef Z_PREFIX_SET | ||||||
| #  define z_deflateInit(strm, level) \ | #  define z_deflateInit(strm, level) \ | ||||||
|           deflateInit_((strm), (level), ZLIB_VERSION, (int)sizeof(z_stream)) |           deflateInit_((strm), (level), ZLIB_VERSION, (int)sizeof(z_stream)) | ||||||
| @@ -1836,7 +1839,7 @@ struct gzFile_s { | |||||||
|     unsigned char *next; |     unsigned char *next; | ||||||
|     z_off64_t pos; |     z_off64_t pos; | ||||||
| }; | }; | ||||||
| ZEXTERN int ZEXPORT gzgetc_ OF((gzFile file));  /* backward compatibility */ | ZEXTERN int ZEXPORT gzgetc_(gzFile file);       /* backward compatibility */ | ||||||
| #ifdef Z_PREFIX_SET | #ifdef Z_PREFIX_SET | ||||||
| #  undef z_gzgetc | #  undef z_gzgetc | ||||||
| #  define z_gzgetc(g) \ | #  define z_gzgetc(g) \ | ||||||
| @@ -1853,13 +1856,13 @@ ZEXTERN int ZEXPORT gzgetc_ OF((gzFile file));  /* backward compatibility */ | |||||||
|  * without large file support, _LFS64_LARGEFILE must also be true |  * without large file support, _LFS64_LARGEFILE must also be true | ||||||
|  */ |  */ | ||||||
| #ifdef Z_LARGE64 | #ifdef Z_LARGE64 | ||||||
|    ZEXTERN gzFile ZEXPORT gzopen64 OF((const char *, const char *)); |    ZEXTERN gzFile ZEXPORT gzopen64(const char *, const char *); | ||||||
|    ZEXTERN z_off64_t ZEXPORT gzseek64 OF((gzFile, z_off64_t, int)); |    ZEXTERN z_off64_t ZEXPORT gzseek64(gzFile, z_off64_t, int); | ||||||
|    ZEXTERN z_off64_t ZEXPORT gztell64 OF((gzFile)); |    ZEXTERN z_off64_t ZEXPORT gztell64(gzFile); | ||||||
|    ZEXTERN z_off64_t ZEXPORT gzoffset64 OF((gzFile)); |    ZEXTERN z_off64_t ZEXPORT gzoffset64(gzFile); | ||||||
|    ZEXTERN uLong ZEXPORT adler32_combine64 OF((uLong, uLong, z_off64_t)); |    ZEXTERN uLong ZEXPORT adler32_combine64(uLong, uLong, z_off64_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine64 OF((uLong, uLong, z_off64_t)); |    ZEXTERN uLong ZEXPORT crc32_combine64(uLong, uLong, z_off64_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine_gen64 OF((z_off64_t)); |    ZEXTERN uLong ZEXPORT crc32_combine_gen64(z_off64_t); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if !defined(ZLIB_INTERNAL) && defined(Z_WANT64) | #if !defined(ZLIB_INTERNAL) && defined(Z_WANT64) | ||||||
| @@ -1881,50 +1884,50 @@ ZEXTERN int ZEXPORT gzgetc_ OF((gzFile file));  /* backward compatibility */ | |||||||
| #    define crc32_combine_gen crc32_combine_gen64 | #    define crc32_combine_gen crc32_combine_gen64 | ||||||
| #  endif | #  endif | ||||||
| #  ifndef Z_LARGE64 | #  ifndef Z_LARGE64 | ||||||
|      ZEXTERN gzFile ZEXPORT gzopen64 OF((const char *, const char *)); |      ZEXTERN gzFile ZEXPORT gzopen64(const char *, const char *); | ||||||
|      ZEXTERN z_off_t ZEXPORT gzseek64 OF((gzFile, z_off_t, int)); |      ZEXTERN z_off_t ZEXPORT gzseek64(gzFile, z_off_t, int); | ||||||
|      ZEXTERN z_off_t ZEXPORT gztell64 OF((gzFile)); |      ZEXTERN z_off_t ZEXPORT gztell64(gzFile); | ||||||
|      ZEXTERN z_off_t ZEXPORT gzoffset64 OF((gzFile)); |      ZEXTERN z_off_t ZEXPORT gzoffset64(gzFile); | ||||||
|      ZEXTERN uLong ZEXPORT adler32_combine64 OF((uLong, uLong, z_off_t)); |      ZEXTERN uLong ZEXPORT adler32_combine64(uLong, uLong, z_off_t); | ||||||
|      ZEXTERN uLong ZEXPORT crc32_combine64 OF((uLong, uLong, z_off_t)); |      ZEXTERN uLong ZEXPORT crc32_combine64(uLong, uLong, z_off_t); | ||||||
|      ZEXTERN uLong ZEXPORT crc32_combine_gen64 OF((z_off_t)); |      ZEXTERN uLong ZEXPORT crc32_combine_gen64(z_off_t); | ||||||
| #  endif | #  endif | ||||||
| #else | #else | ||||||
|    ZEXTERN gzFile ZEXPORT gzopen OF((const char *, const char *)); |    ZEXTERN gzFile ZEXPORT gzopen(const char *, const char *); | ||||||
|    ZEXTERN z_off_t ZEXPORT gzseek OF((gzFile, z_off_t, int)); |    ZEXTERN z_off_t ZEXPORT gzseek(gzFile, z_off_t, int); | ||||||
|    ZEXTERN z_off_t ZEXPORT gztell OF((gzFile)); |    ZEXTERN z_off_t ZEXPORT gztell(gzFile); | ||||||
|    ZEXTERN z_off_t ZEXPORT gzoffset OF((gzFile)); |    ZEXTERN z_off_t ZEXPORT gzoffset(gzFile); | ||||||
|    ZEXTERN uLong ZEXPORT adler32_combine OF((uLong, uLong, z_off_t)); |    ZEXTERN uLong ZEXPORT adler32_combine(uLong, uLong, z_off_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine OF((uLong, uLong, z_off_t)); |    ZEXTERN uLong ZEXPORT crc32_combine(uLong, uLong, z_off_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine_gen OF((z_off_t)); |    ZEXTERN uLong ZEXPORT crc32_combine_gen(z_off_t); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #else /* Z_SOLO */ | #else /* Z_SOLO */ | ||||||
|  |  | ||||||
|    ZEXTERN uLong ZEXPORT adler32_combine OF((uLong, uLong, z_off_t)); |    ZEXTERN uLong ZEXPORT adler32_combine(uLong, uLong, z_off_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine OF((uLong, uLong, z_off_t)); |    ZEXTERN uLong ZEXPORT crc32_combine(uLong, uLong, z_off_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine_gen OF((z_off_t)); |    ZEXTERN uLong ZEXPORT crc32_combine_gen(z_off_t); | ||||||
|  |  | ||||||
| #endif /* !Z_SOLO */ | #endif /* !Z_SOLO */ | ||||||
|  |  | ||||||
| /* undocumented functions */ | /* undocumented functions */ | ||||||
| ZEXTERN const char   * ZEXPORT zError           OF((int)); | ZEXTERN const char   * ZEXPORT zError(int); | ||||||
| ZEXTERN int            ZEXPORT inflateSyncPoint OF((z_streamp)); | ZEXTERN int            ZEXPORT inflateSyncPoint(z_streamp); | ||||||
| ZEXTERN const z_crc_t FAR * ZEXPORT get_crc_table    OF((void)); | ZEXTERN const z_crc_t FAR * ZEXPORT get_crc_table(void); | ||||||
| ZEXTERN int            ZEXPORT inflateUndermine OF((z_streamp, int)); | ZEXTERN int            ZEXPORT inflateUndermine(z_streamp, int); | ||||||
| ZEXTERN int            ZEXPORT inflateValidate OF((z_streamp, int)); | ZEXTERN int            ZEXPORT inflateValidate(z_streamp, int); | ||||||
| ZEXTERN unsigned long  ZEXPORT inflateCodesUsed OF((z_streamp)); | ZEXTERN unsigned long  ZEXPORT inflateCodesUsed(z_streamp); | ||||||
| ZEXTERN int            ZEXPORT inflateResetKeep OF((z_streamp)); | ZEXTERN int            ZEXPORT inflateResetKeep(z_streamp); | ||||||
| ZEXTERN int            ZEXPORT deflateResetKeep OF((z_streamp)); | ZEXTERN int            ZEXPORT deflateResetKeep(z_streamp); | ||||||
| #if defined(_WIN32) && !defined(Z_SOLO) | #if defined(_WIN32) && !defined(Z_SOLO) | ||||||
| ZEXTERN gzFile         ZEXPORT gzopen_w OF((const wchar_t *path, | ZEXTERN gzFile         ZEXPORT gzopen_w(const wchar_t *path, | ||||||
|                                             const char *mode)); |                                         const char *mode); | ||||||
| #endif | #endif | ||||||
| #if defined(STDC) || defined(Z_HAVE_STDARG_H) | #if defined(STDC) || defined(Z_HAVE_STDARG_H) | ||||||
| #  ifndef Z_SOLO | #  ifndef Z_SOLO | ||||||
| ZEXTERN int            ZEXPORTVA gzvprintf Z_ARG((gzFile file, | ZEXTERN int            ZEXPORTVA gzvprintf(gzFile file, | ||||||
|                                                   const char *format, |                                            const char *format, | ||||||
|                                                   va_list va)); |                                            va_list va); | ||||||
| #  endif | #  endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,8 +7,6 @@ | |||||||
|  |  | ||||||
| #include "zutil.h" | #include "zutil.h" | ||||||
|  |  | ||||||
| local uLong adler32_combine_ OF((uLong adler1, uLong adler2, z_off64_t len2)); |  | ||||||
|  |  | ||||||
| #define BASE 65521U     /* largest prime smaller than 65536 */ | #define BASE 65521U     /* largest prime smaller than 65536 */ | ||||||
| #define NMAX 5552 | #define NMAX 5552 | ||||||
| /* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 */ | /* NMAX is the largest n such that 255n(n+1)/2 + (n+1)(BASE-1) <= 2^32-1 */ | ||||||
| @@ -60,11 +58,7 @@ local uLong adler32_combine_ OF((uLong adler1, uLong adler2, z_off64_t len2)); | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| uLong ZEXPORT adler32_z(adler, buf, len) | uLong ZEXPORT adler32_z(uLong adler, const Bytef *buf, z_size_t len) { | ||||||
|     uLong adler; |  | ||||||
|     const Bytef *buf; |  | ||||||
|     z_size_t len; |  | ||||||
| { |  | ||||||
|     unsigned long sum2; |     unsigned long sum2; | ||||||
|     unsigned n; |     unsigned n; | ||||||
|  |  | ||||||
| @@ -131,20 +125,12 @@ uLong ZEXPORT adler32_z(adler, buf, len) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| uLong ZEXPORT adler32(adler, buf, len) | uLong ZEXPORT adler32(uLong adler, const Bytef *buf, uInt len) { | ||||||
|     uLong adler; |  | ||||||
|     const Bytef *buf; |  | ||||||
|     uInt len; |  | ||||||
| { |  | ||||||
|     return adler32_z(adler, buf, len); |     return adler32_z(adler, buf, len); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| local uLong adler32_combine_(adler1, adler2, len2) | local uLong adler32_combine_(uLong adler1, uLong adler2, z_off64_t len2) { | ||||||
|     uLong adler1; |  | ||||||
|     uLong adler2; |  | ||||||
|     z_off64_t len2; |  | ||||||
| { |  | ||||||
|     unsigned long sum1; |     unsigned long sum1; | ||||||
|     unsigned long sum2; |     unsigned long sum2; | ||||||
|     unsigned rem; |     unsigned rem; | ||||||
| @@ -169,18 +155,10 @@ local uLong adler32_combine_(adler1, adler2, len2) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| uLong ZEXPORT adler32_combine(adler1, adler2, len2) | uLong ZEXPORT adler32_combine(uLong adler1, uLong adler2, z_off_t len2) { | ||||||
|     uLong adler1; |  | ||||||
|     uLong adler2; |  | ||||||
|     z_off_t len2; |  | ||||||
| { |  | ||||||
|     return adler32_combine_(adler1, adler2, len2); |     return adler32_combine_(adler1, adler2, len2); | ||||||
| } | } | ||||||
|  |  | ||||||
| uLong ZEXPORT adler32_combine64(adler1, adler2, len2) | uLong ZEXPORT adler32_combine64(uLong adler1, uLong adler2, z_off64_t len2) { | ||||||
|     uLong adler1; |  | ||||||
|     uLong adler2; |  | ||||||
|     z_off64_t len2; |  | ||||||
| { |  | ||||||
|     return adler32_combine_(adler1, adler2, len2); |     return adler32_combine_(adler1, adler2, len2); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -19,13 +19,8 @@ | |||||||
|    memory, Z_BUF_ERROR if there was not enough room in the output buffer, |    memory, Z_BUF_ERROR if there was not enough room in the output buffer, | ||||||
|    Z_STREAM_ERROR if the level parameter is invalid. |    Z_STREAM_ERROR if the level parameter is invalid. | ||||||
| */ | */ | ||||||
| int ZEXPORT compress2(dest, destLen, source, sourceLen, level) | int ZEXPORT compress2(Bytef *dest, uLongf *destLen, const Bytef *source, | ||||||
|     Bytef *dest; |                       uLong sourceLen, int level) { | ||||||
|     uLongf *destLen; |  | ||||||
|     const Bytef *source; |  | ||||||
|     uLong sourceLen; |  | ||||||
|     int level; |  | ||||||
| { |  | ||||||
|     z_stream stream; |     z_stream stream; | ||||||
|     int err; |     int err; | ||||||
|     const uInt max = (uInt)-1; |     const uInt max = (uInt)-1; | ||||||
| @@ -65,12 +60,8 @@ int ZEXPORT compress2(dest, destLen, source, sourceLen, level) | |||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  */ |  */ | ||||||
| int ZEXPORT compress(dest, destLen, source, sourceLen) | int ZEXPORT compress(Bytef *dest, uLongf *destLen, const Bytef *source, | ||||||
|     Bytef *dest; |                      uLong sourceLen) { | ||||||
|     uLongf *destLen; |  | ||||||
|     const Bytef *source; |  | ||||||
|     uLong sourceLen; |  | ||||||
| { |  | ||||||
|     return compress2(dest, destLen, source, sourceLen, Z_DEFAULT_COMPRESSION); |     return compress2(dest, destLen, source, sourceLen, Z_DEFAULT_COMPRESSION); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -78,9 +69,7 @@ int ZEXPORT compress(dest, destLen, source, sourceLen) | |||||||
|      If the default memLevel or windowBits for deflateInit() is changed, then |      If the default memLevel or windowBits for deflateInit() is changed, then | ||||||
|    this function needs to be updated. |    this function needs to be updated. | ||||||
|  */ |  */ | ||||||
| uLong ZEXPORT compressBound(sourceLen) | uLong ZEXPORT compressBound(uLong sourceLen) { | ||||||
|     uLong sourceLen; |  | ||||||
| { |  | ||||||
|     return sourceLen + (sourceLen >> 12) + (sourceLen >> 14) + |     return sourceLen + (sourceLen >> 12) + (sourceLen >> 14) + | ||||||
|            (sourceLen >> 25) + 13; |            (sourceLen >> 25) + 13; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -103,19 +103,6 @@ | |||||||
| #  define ARMCRC32 | #  define ARMCRC32 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| /* Local functions. */ |  | ||||||
| local z_crc_t multmodp OF((z_crc_t a, z_crc_t b)); |  | ||||||
| local z_crc_t x2nmodp OF((z_off64_t n, unsigned k)); |  | ||||||
|  |  | ||||||
| #if defined(W) && (!defined(ARMCRC32) || defined(DYNAMIC_CRC_TABLE)) |  | ||||||
|     local z_word_t byte_swap OF((z_word_t word)); |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(W) && !defined(ARMCRC32) |  | ||||||
|     local z_crc_t crc_word OF((z_word_t data)); |  | ||||||
|     local z_word_t crc_word_big OF((z_word_t data)); |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #if defined(W) && (!defined(ARMCRC32) || defined(DYNAMIC_CRC_TABLE)) | #if defined(W) && (!defined(ARMCRC32) || defined(DYNAMIC_CRC_TABLE)) | ||||||
| /* | /* | ||||||
|   Swap the bytes in a z_word_t to convert between little and big endian. Any |   Swap the bytes in a z_word_t to convert between little and big endian. Any | ||||||
| @@ -123,9 +110,7 @@ local z_crc_t x2nmodp OF((z_off64_t n, unsigned k)); | |||||||
|   instruction, if one is available. This assumes that word_t is either 32 bits |   instruction, if one is available. This assumes that word_t is either 32 bits | ||||||
|   or 64 bits. |   or 64 bits. | ||||||
|  */ |  */ | ||||||
| local z_word_t byte_swap(word) | local z_word_t byte_swap(z_word_t word) { | ||||||
|     z_word_t word; |  | ||||||
| { |  | ||||||
| #  if W == 8 | #  if W == 8 | ||||||
|     return |     return | ||||||
|         (word & 0xff00000000000000) >> 56 | |         (word & 0xff00000000000000) >> 56 | | ||||||
| @@ -146,24 +131,77 @@ local z_word_t byte_swap(word) | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | #ifdef DYNAMIC_CRC_TABLE | ||||||
|  | /* ========================================================================= | ||||||
|  |  * Table of powers of x for combining CRC-32s, filled in by make_crc_table() | ||||||
|  |  * below. | ||||||
|  |  */ | ||||||
|  |    local z_crc_t FAR x2n_table[32]; | ||||||
|  | #else | ||||||
|  | /* ========================================================================= | ||||||
|  |  * Tables for byte-wise and braided CRC-32 calculations, and a table of powers | ||||||
|  |  * of x for combining CRC-32s, all made by make_crc_table(). | ||||||
|  |  */ | ||||||
|  | #  include "crc32.h" | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /* CRC polynomial. */ | /* CRC polynomial. */ | ||||||
| #define POLY 0xedb88320         /* p(x) reflected, with x^32 implied */ | #define POLY 0xedb88320         /* p(x) reflected, with x^32 implied */ | ||||||
|  |  | ||||||
| #ifdef DYNAMIC_CRC_TABLE | /* | ||||||
|  |   Return a(x) multiplied by b(x) modulo p(x), where p(x) is the CRC polynomial, | ||||||
|  |   reflected. For speed, this requires that a not be zero. | ||||||
|  |  */ | ||||||
|  | local z_crc_t multmodp(z_crc_t a, z_crc_t b) { | ||||||
|  |     z_crc_t m, p; | ||||||
|  |  | ||||||
|  |     m = (z_crc_t)1 << 31; | ||||||
|  |     p = 0; | ||||||
|  |     for (;;) { | ||||||
|  |         if (a & m) { | ||||||
|  |             p ^= b; | ||||||
|  |             if ((a & (m - 1)) == 0) | ||||||
|  |                 break; | ||||||
|  |         } | ||||||
|  |         m >>= 1; | ||||||
|  |         b = b & 1 ? (b >> 1) ^ POLY : b >> 1; | ||||||
|  |     } | ||||||
|  |     return p; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |   Return x^(n * 2^k) modulo p(x). Requires that x2n_table[] has been | ||||||
|  |   initialized. | ||||||
|  |  */ | ||||||
|  | local z_crc_t x2nmodp(z_off64_t n, unsigned k) { | ||||||
|  |     z_crc_t p; | ||||||
|  |  | ||||||
|  |     p = (z_crc_t)1 << 31;           /* x^0 == 1 */ | ||||||
|  |     while (n) { | ||||||
|  |         if (n & 1) | ||||||
|  |             p = multmodp(x2n_table[k & 31], p); | ||||||
|  |         n >>= 1; | ||||||
|  |         k++; | ||||||
|  |     } | ||||||
|  |     return p; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | #ifdef DYNAMIC_CRC_TABLE | ||||||
|  | /* ========================================================================= | ||||||
|  |  * Build the tables for byte-wise and braided CRC-32 calculations, and a table | ||||||
|  |  * of powers of x for combining CRC-32s. | ||||||
|  |  */ | ||||||
| local z_crc_t FAR crc_table[256]; | local z_crc_t FAR crc_table[256]; | ||||||
| local z_crc_t FAR x2n_table[32]; |  | ||||||
| local void make_crc_table OF((void)); |  | ||||||
| #ifdef W | #ifdef W | ||||||
|    local z_word_t FAR crc_big_table[256]; |    local z_word_t FAR crc_big_table[256]; | ||||||
|    local z_crc_t FAR crc_braid_table[W][256]; |    local z_crc_t FAR crc_braid_table[W][256]; | ||||||
|    local z_word_t FAR crc_braid_big_table[W][256]; |    local z_word_t FAR crc_braid_big_table[W][256]; | ||||||
|    local void braid OF((z_crc_t [][256], z_word_t [][256], int, int)); |    local void braid(z_crc_t [][256], z_word_t [][256], int, int); | ||||||
| #endif | #endif | ||||||
| #ifdef MAKECRCH | #ifdef MAKECRCH | ||||||
|    local void write_table OF((FILE *, const z_crc_t FAR *, int)); |    local void write_table(FILE *, const z_crc_t FAR *, int); | ||||||
|    local void write_table32hi OF((FILE *, const z_word_t FAR *, int)); |    local void write_table32hi(FILE *, const z_word_t FAR *, int); | ||||||
|    local void write_table64 OF((FILE *, const z_word_t FAR *, int)); |    local void write_table64(FILE *, const z_word_t FAR *, int); | ||||||
| #endif /* MAKECRCH */ | #endif /* MAKECRCH */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -176,7 +214,6 @@ local void make_crc_table OF((void)); | |||||||
|  |  | ||||||
| /* Definition of once functionality. */ | /* Definition of once functionality. */ | ||||||
| typedef struct once_s once_t; | typedef struct once_s once_t; | ||||||
| local void once OF((once_t *, void (*)(void))); |  | ||||||
|  |  | ||||||
| /* Check for the availability of atomics. */ | /* Check for the availability of atomics. */ | ||||||
| #if defined(__STDC__) && __STDC_VERSION__ >= 201112L && \ | #if defined(__STDC__) && __STDC_VERSION__ >= 201112L && \ | ||||||
| @@ -196,10 +233,7 @@ struct once_s { | |||||||
|   invoke once() at the same time. The state must be a once_t initialized with |   invoke once() at the same time. The state must be a once_t initialized with | ||||||
|   ONCE_INIT. |   ONCE_INIT. | ||||||
|  */ |  */ | ||||||
| local void once(state, init) | local void once(once_t *state, void (*init)(void)) { | ||||||
|     once_t *state; |  | ||||||
|     void (*init)(void); |  | ||||||
| { |  | ||||||
|     if (!atomic_load(&state->done)) { |     if (!atomic_load(&state->done)) { | ||||||
|         if (atomic_flag_test_and_set(&state->begun)) |         if (atomic_flag_test_and_set(&state->begun)) | ||||||
|             while (!atomic_load(&state->done)) |             while (!atomic_load(&state->done)) | ||||||
| @@ -222,10 +256,7 @@ struct once_s { | |||||||
|  |  | ||||||
| /* Test and set. Alas, not atomic, but tries to minimize the period of | /* Test and set. Alas, not atomic, but tries to minimize the period of | ||||||
|    vulnerability. */ |    vulnerability. */ | ||||||
| local int test_and_set OF((int volatile *)); | local int test_and_set(int volatile *flag) { | ||||||
| local int test_and_set(flag) |  | ||||||
|     int volatile *flag; |  | ||||||
| { |  | ||||||
|     int was; |     int was; | ||||||
|  |  | ||||||
|     was = *flag; |     was = *flag; | ||||||
| @@ -234,10 +265,7 @@ local int test_and_set(flag) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* Run the provided init() function once. This is not thread-safe. */ | /* Run the provided init() function once. This is not thread-safe. */ | ||||||
| local void once(state, init) | local void once(once_t *state, void (*init)(void)) { | ||||||
|     once_t *state; |  | ||||||
|     void (*init)(void); |  | ||||||
| { |  | ||||||
|     if (!state->done) { |     if (!state->done) { | ||||||
|         if (test_and_set(&state->begun)) |         if (test_and_set(&state->begun)) | ||||||
|             while (!state->done) |             while (!state->done) | ||||||
| @@ -279,8 +307,7 @@ local once_t made = ONCE_INIT; | |||||||
|   combinations of CRC register values and incoming bytes. |   combinations of CRC register values and incoming bytes. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| local void make_crc_table() | local void make_crc_table(void) { | ||||||
| { |  | ||||||
|     unsigned i, j, n; |     unsigned i, j, n; | ||||||
|     z_crc_t p; |     z_crc_t p; | ||||||
|  |  | ||||||
| @@ -447,11 +474,7 @@ local void make_crc_table() | |||||||
|    Write the 32-bit values in table[0..k-1] to out, five per line in |    Write the 32-bit values in table[0..k-1] to out, five per line in | ||||||
|    hexadecimal separated by commas. |    hexadecimal separated by commas. | ||||||
|  */ |  */ | ||||||
| local void write_table(out, table, k) | local void write_table(FILE *out, const z_crc_t FAR *table, int k) { | ||||||
|     FILE *out; |  | ||||||
|     const z_crc_t FAR *table; |  | ||||||
|     int k; |  | ||||||
| { |  | ||||||
|     int n; |     int n; | ||||||
|  |  | ||||||
|     for (n = 0; n < k; n++) |     for (n = 0; n < k; n++) | ||||||
| @@ -464,11 +487,7 @@ local void write_table(out, table, k) | |||||||
|    Write the high 32-bits of each value in table[0..k-1] to out, five per line |    Write the high 32-bits of each value in table[0..k-1] to out, five per line | ||||||
|    in hexadecimal separated by commas. |    in hexadecimal separated by commas. | ||||||
|  */ |  */ | ||||||
| local void write_table32hi(out, table, k) | local void write_table32hi(FILE *out, const z_word_t FAR *table, int k) { | ||||||
| FILE *out; |  | ||||||
| const z_word_t FAR *table; |  | ||||||
| int k; |  | ||||||
| { |  | ||||||
|     int n; |     int n; | ||||||
|  |  | ||||||
|     for (n = 0; n < k; n++) |     for (n = 0; n < k; n++) | ||||||
| @@ -484,11 +503,7 @@ int k; | |||||||
|   bits. If not, then the type cast and format string can be adjusted |   bits. If not, then the type cast and format string can be adjusted | ||||||
|   accordingly. |   accordingly. | ||||||
|  */ |  */ | ||||||
| local void write_table64(out, table, k) | local void write_table64(FILE *out, const z_word_t FAR *table, int k) { | ||||||
|     FILE *out; |  | ||||||
|     const z_word_t FAR *table; |  | ||||||
|     int k; |  | ||||||
| { |  | ||||||
|     int n; |     int n; | ||||||
|  |  | ||||||
|     for (n = 0; n < k; n++) |     for (n = 0; n < k; n++) | ||||||
| @@ -498,8 +513,7 @@ local void write_table64(out, table, k) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* Actually do the deed. */ | /* Actually do the deed. */ | ||||||
| int main() | int main(void) { | ||||||
| { |  | ||||||
|     make_crc_table(); |     make_crc_table(); | ||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
| @@ -511,12 +525,7 @@ int main() | |||||||
|   Generate the little and big-endian braid tables for the given n and z_word_t |   Generate the little and big-endian braid tables for the given n and z_word_t | ||||||
|   size w. Each array must have room for w blocks of 256 elements. |   size w. Each array must have room for w blocks of 256 elements. | ||||||
|  */ |  */ | ||||||
| local void braid(ltl, big, n, w) | local void braid(z_crc_t ltl[][256], z_word_t big[][256], int n, int w) { | ||||||
|     z_crc_t ltl[][256]; |  | ||||||
|     z_word_t big[][256]; |  | ||||||
|     int n; |  | ||||||
|     int w; |  | ||||||
| { |  | ||||||
|     int k; |     int k; | ||||||
|     z_crc_t i, p, q; |     z_crc_t i, p, q; | ||||||
|     for (k = 0; k < w; k++) { |     for (k = 0; k < w; k++) { | ||||||
| @@ -531,69 +540,13 @@ local void braid(ltl, big, n, w) | |||||||
| } | } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #else /* !DYNAMIC_CRC_TABLE */ |  | ||||||
| /* ======================================================================== |  | ||||||
|  * Tables for byte-wise and braided CRC-32 calculations, and a table of powers |  | ||||||
|  * of x for combining CRC-32s, all made by make_crc_table(). |  | ||||||
|  */ |  | ||||||
| #include "crc32.h" |  | ||||||
| #endif /* DYNAMIC_CRC_TABLE */ | #endif /* DYNAMIC_CRC_TABLE */ | ||||||
|  |  | ||||||
| /* ======================================================================== |  | ||||||
|  * Routines used for CRC calculation. Some are also required for the table |  | ||||||
|  * generation above. |  | ||||||
|  */ |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|   Return a(x) multiplied by b(x) modulo p(x), where p(x) is the CRC polynomial, |  | ||||||
|   reflected. For speed, this requires that a not be zero. |  | ||||||
|  */ |  | ||||||
| local z_crc_t multmodp(a, b) |  | ||||||
|     z_crc_t a; |  | ||||||
|     z_crc_t b; |  | ||||||
| { |  | ||||||
|     z_crc_t m, p; |  | ||||||
|  |  | ||||||
|     m = (z_crc_t)1 << 31; |  | ||||||
|     p = 0; |  | ||||||
|     for (;;) { |  | ||||||
|         if (a & m) { |  | ||||||
|             p ^= b; |  | ||||||
|             if ((a & (m - 1)) == 0) |  | ||||||
|                 break; |  | ||||||
|         } |  | ||||||
|         m >>= 1; |  | ||||||
|         b = b & 1 ? (b >> 1) ^ POLY : b >> 1; |  | ||||||
|     } |  | ||||||
|     return p; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|   Return x^(n * 2^k) modulo p(x). Requires that x2n_table[] has been |  | ||||||
|   initialized. |  | ||||||
|  */ |  | ||||||
| local z_crc_t x2nmodp(n, k) |  | ||||||
|     z_off64_t n; |  | ||||||
|     unsigned k; |  | ||||||
| { |  | ||||||
|     z_crc_t p; |  | ||||||
|  |  | ||||||
|     p = (z_crc_t)1 << 31;           /* x^0 == 1 */ |  | ||||||
|     while (n) { |  | ||||||
|         if (n & 1) |  | ||||||
|             p = multmodp(x2n_table[k & 31], p); |  | ||||||
|         n >>= 1; |  | ||||||
|         k++; |  | ||||||
|     } |  | ||||||
|     return p; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* ========================================================================= | /* ========================================================================= | ||||||
|  * This function can be used by asm versions of crc32(), and to force the |  * This function can be used by asm versions of crc32(), and to force the | ||||||
|  * generation of the CRC tables in a threaded application. |  * generation of the CRC tables in a threaded application. | ||||||
|  */ |  */ | ||||||
| const z_crc_t FAR * ZEXPORT get_crc_table() | const z_crc_t FAR * ZEXPORT get_crc_table(void) { | ||||||
| { |  | ||||||
| #ifdef DYNAMIC_CRC_TABLE | #ifdef DYNAMIC_CRC_TABLE | ||||||
|     once(&made, make_crc_table); |     once(&made, make_crc_table); | ||||||
| #endif /* DYNAMIC_CRC_TABLE */ | #endif /* DYNAMIC_CRC_TABLE */ | ||||||
| @@ -619,11 +572,8 @@ const z_crc_t FAR * ZEXPORT get_crc_table() | |||||||
| #define Z_BATCH_ZEROS 0xa10d3d0c    /* computed from Z_BATCH = 3990 */ | #define Z_BATCH_ZEROS 0xa10d3d0c    /* computed from Z_BATCH = 3990 */ | ||||||
| #define Z_BATCH_MIN 800             /* fewest words in a final batch */ | #define Z_BATCH_MIN 800             /* fewest words in a final batch */ | ||||||
|  |  | ||||||
| unsigned long ZEXPORT crc32_z(crc, buf, len) | unsigned long ZEXPORT crc32_z(unsigned long crc, const unsigned char FAR *buf, | ||||||
|     unsigned long crc; |                               z_size_t len) { | ||||||
|     const unsigned char FAR *buf; |  | ||||||
|     z_size_t len; |  | ||||||
| { |  | ||||||
|     z_crc_t val; |     z_crc_t val; | ||||||
|     z_word_t crc1, crc2; |     z_word_t crc1, crc2; | ||||||
|     const z_word_t *word; |     const z_word_t *word; | ||||||
| @@ -723,18 +673,14 @@ unsigned long ZEXPORT crc32_z(crc, buf, len) | |||||||
|   least-significant byte of the word as the first byte of data, without any pre |   least-significant byte of the word as the first byte of data, without any pre | ||||||
|   or post conditioning. This is used to combine the CRCs of each braid. |   or post conditioning. This is used to combine the CRCs of each braid. | ||||||
|  */ |  */ | ||||||
| local z_crc_t crc_word(data) | local z_crc_t crc_word(z_word_t data) { | ||||||
|     z_word_t data; |  | ||||||
| { |  | ||||||
|     int k; |     int k; | ||||||
|     for (k = 0; k < W; k++) |     for (k = 0; k < W; k++) | ||||||
|         data = (data >> 8) ^ crc_table[data & 0xff]; |         data = (data >> 8) ^ crc_table[data & 0xff]; | ||||||
|     return (z_crc_t)data; |     return (z_crc_t)data; | ||||||
| } | } | ||||||
|  |  | ||||||
| local z_word_t crc_word_big(data) | local z_word_t crc_word_big(z_word_t data) { | ||||||
|     z_word_t data; |  | ||||||
| { |  | ||||||
|     int k; |     int k; | ||||||
|     for (k = 0; k < W; k++) |     for (k = 0; k < W; k++) | ||||||
|         data = (data << 8) ^ |         data = (data << 8) ^ | ||||||
| @@ -745,11 +691,8 @@ local z_word_t crc_word_big(data) | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| unsigned long ZEXPORT crc32_z(crc, buf, len) | unsigned long ZEXPORT crc32_z(unsigned long crc, const unsigned char FAR *buf, | ||||||
|     unsigned long crc; |                               z_size_t len) { | ||||||
|     const unsigned char FAR *buf; |  | ||||||
|     z_size_t len; |  | ||||||
| { |  | ||||||
|     /* Return initial CRC, if requested. */ |     /* Return initial CRC, if requested. */ | ||||||
|     if (buf == Z_NULL) return 0; |     if (buf == Z_NULL) return 0; | ||||||
|  |  | ||||||
| @@ -781,8 +724,8 @@ unsigned long ZEXPORT crc32_z(crc, buf, len) | |||||||
|         words = (z_word_t const *)buf; |         words = (z_word_t const *)buf; | ||||||
|  |  | ||||||
|         /* Do endian check at execution time instead of compile time, since ARM |         /* Do endian check at execution time instead of compile time, since ARM | ||||||
|            processors can change the endianess at execution time. If the |            processors can change the endianness at execution time. If the | ||||||
|            compiler knows what the endianess will be, it can optimize out the |            compiler knows what the endianness will be, it can optimize out the | ||||||
|            check and the unused branch. */ |            check and the unused branch. */ | ||||||
|         endian = 1; |         endian = 1; | ||||||
|         if (*(unsigned char *)&endian) { |         if (*(unsigned char *)&endian) { | ||||||
| @@ -1069,20 +1012,13 @@ unsigned long ZEXPORT crc32_z(crc, buf, len) | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| unsigned long ZEXPORT crc32(crc, buf, len) | unsigned long ZEXPORT crc32(unsigned long crc, const unsigned char FAR *buf, | ||||||
|     unsigned long crc; |                             uInt len) { | ||||||
|     const unsigned char FAR *buf; |  | ||||||
|     uInt len; |  | ||||||
| { |  | ||||||
|     return crc32_z(crc, buf, len); |     return crc32_z(crc, buf, len); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| uLong ZEXPORT crc32_combine64(crc1, crc2, len2) | uLong ZEXPORT crc32_combine64(uLong crc1, uLong crc2, z_off64_t len2) { | ||||||
|     uLong crc1; |  | ||||||
|     uLong crc2; |  | ||||||
|     z_off64_t len2; |  | ||||||
| { |  | ||||||
| #ifdef DYNAMIC_CRC_TABLE | #ifdef DYNAMIC_CRC_TABLE | ||||||
|     once(&made, make_crc_table); |     once(&made, make_crc_table); | ||||||
| #endif /* DYNAMIC_CRC_TABLE */ | #endif /* DYNAMIC_CRC_TABLE */ | ||||||
| @@ -1090,18 +1026,12 @@ uLong ZEXPORT crc32_combine64(crc1, crc2, len2) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| uLong ZEXPORT crc32_combine(crc1, crc2, len2) | uLong ZEXPORT crc32_combine(uLong crc1, uLong crc2, z_off_t len2) { | ||||||
|     uLong crc1; |  | ||||||
|     uLong crc2; |  | ||||||
|     z_off_t len2; |  | ||||||
| { |  | ||||||
|     return crc32_combine64(crc1, crc2, (z_off64_t)len2); |     return crc32_combine64(crc1, crc2, (z_off64_t)len2); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| uLong ZEXPORT crc32_combine_gen64(len2) | uLong ZEXPORT crc32_combine_gen64(z_off64_t len2) { | ||||||
|     z_off64_t len2; |  | ||||||
| { |  | ||||||
| #ifdef DYNAMIC_CRC_TABLE | #ifdef DYNAMIC_CRC_TABLE | ||||||
|     once(&made, make_crc_table); |     once(&made, make_crc_table); | ||||||
| #endif /* DYNAMIC_CRC_TABLE */ | #endif /* DYNAMIC_CRC_TABLE */ | ||||||
| @@ -1109,17 +1039,11 @@ uLong ZEXPORT crc32_combine_gen64(len2) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| uLong ZEXPORT crc32_combine_gen(len2) | uLong ZEXPORT crc32_combine_gen(z_off_t len2) { | ||||||
|     z_off_t len2; |  | ||||||
| { |  | ||||||
|     return crc32_combine_gen64((z_off64_t)len2); |     return crc32_combine_gen64((z_off64_t)len2); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| uLong ZEXPORT crc32_combine_op(crc1, crc2, op) | uLong ZEXPORT crc32_combine_op(uLong crc1, uLong crc2, uLong op) { | ||||||
|     uLong crc1; |  | ||||||
|     uLong crc2; |  | ||||||
|     uLong op; |  | ||||||
| { |  | ||||||
|     return multmodp(op, crc1) ^ (crc2 & 0xffffffff); |     return multmodp(op, crc1) ^ (crc2 & 0xffffffff); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| /* deflate.c -- compress data using the deflation algorithm | /* deflate.c -- compress data using the deflation algorithm | ||||||
|  * Copyright (C) 1995-2022 Jean-loup Gailly and Mark Adler |  * Copyright (C) 1995-2023 Jean-loup Gailly and Mark Adler | ||||||
|  * For conditions of distribution and use, see copyright notice in zlib.h |  * For conditions of distribution and use, see copyright notice in zlib.h | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| @@ -52,7 +52,7 @@ | |||||||
| #include "deflate.h" | #include "deflate.h" | ||||||
|  |  | ||||||
| const char deflate_copyright[] = | const char deflate_copyright[] = | ||||||
|    " deflate 1.2.13 Copyright 1995-2022 Jean-loup Gailly and Mark Adler "; |    " deflate 1.3 Copyright 1995-2023 Jean-loup Gailly and Mark Adler "; | ||||||
| /* | /* | ||||||
|   If you use the zlib library in a product, an acknowledgment is welcome |   If you use the zlib library in a product, an acknowledgment is welcome | ||||||
|   in the documentation of your product. If for some reason you cannot |   in the documentation of your product. If for some reason you cannot | ||||||
| @@ -60,9 +60,6 @@ const char deflate_copyright[] = | |||||||
|   copyright string in the executable of your product. |   copyright string in the executable of your product. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* =========================================================================== |  | ||||||
|  *  Function prototypes. |  | ||||||
|  */ |  | ||||||
| typedef enum { | typedef enum { | ||||||
|     need_more,      /* block not completed, need more input or more output */ |     need_more,      /* block not completed, need more input or more output */ | ||||||
|     block_done,     /* block flush performed */ |     block_done,     /* block flush performed */ | ||||||
| @@ -70,29 +67,16 @@ typedef enum { | |||||||
|     finish_done     /* finish done, accept no more input or output */ |     finish_done     /* finish done, accept no more input or output */ | ||||||
| } block_state; | } block_state; | ||||||
|  |  | ||||||
| typedef block_state (*compress_func) OF((deflate_state *s, int flush)); | typedef block_state (*compress_func)(deflate_state *s, int flush); | ||||||
| /* Compression function. Returns the block state after the call. */ | /* Compression function. Returns the block state after the call. */ | ||||||
|  |  | ||||||
| local int deflateStateCheck      OF((z_streamp strm)); | local block_state deflate_stored(deflate_state *s, int flush); | ||||||
| local void slide_hash     OF((deflate_state *s)); | local block_state deflate_fast(deflate_state *s, int flush); | ||||||
| local void fill_window    OF((deflate_state *s)); |  | ||||||
| local block_state deflate_stored OF((deflate_state *s, int flush)); |  | ||||||
| local block_state deflate_fast   OF((deflate_state *s, int flush)); |  | ||||||
| #ifndef FASTEST | #ifndef FASTEST | ||||||
| local block_state deflate_slow   OF((deflate_state *s, int flush)); | local block_state deflate_slow(deflate_state *s, int flush); | ||||||
| #endif |  | ||||||
| local block_state deflate_rle    OF((deflate_state *s, int flush)); |  | ||||||
| local block_state deflate_huff   OF((deflate_state *s, int flush)); |  | ||||||
| local void lm_init        OF((deflate_state *s)); |  | ||||||
| local void putShortMSB    OF((deflate_state *s, uInt b)); |  | ||||||
| local void flush_pending  OF((z_streamp strm)); |  | ||||||
| local unsigned read_buf   OF((z_streamp strm, Bytef *buf, unsigned size)); |  | ||||||
| local uInt longest_match  OF((deflate_state *s, IPos cur_match)); |  | ||||||
|  |  | ||||||
| #ifdef ZLIB_DEBUG |  | ||||||
| local  void check_match OF((deflate_state *s, IPos start, IPos match, |  | ||||||
|                             int length)); |  | ||||||
| #endif | #endif | ||||||
|  | local block_state deflate_rle(deflate_state *s, int flush); | ||||||
|  | local block_state deflate_huff(deflate_state *s, int flush); | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Local data |  * Local data | ||||||
| @@ -195,9 +179,12 @@ local const config configuration_table[10] = { | |||||||
|  * bit values at the expense of memory usage). We slide even when level == 0 to |  * bit values at the expense of memory usage). We slide even when level == 0 to | ||||||
|  * keep the hash table consistent if we switch back to level > 0 later. |  * keep the hash table consistent if we switch back to level > 0 later. | ||||||
|  */ |  */ | ||||||
| local void slide_hash(s) | #if defined(__has_feature) | ||||||
|     deflate_state *s; | #  if __has_feature(memory_sanitizer) | ||||||
| { |      __attribute__((no_sanitize("memory"))) | ||||||
|  | #  endif | ||||||
|  | #endif | ||||||
|  | local void slide_hash(deflate_state *s) { | ||||||
|     unsigned n, m; |     unsigned n, m; | ||||||
|     Posf *p; |     Posf *p; | ||||||
|     uInt wsize = s->w_size; |     uInt wsize = s->w_size; | ||||||
| @@ -221,30 +208,177 @@ local void slide_hash(s) | |||||||
| #endif | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Read a new buffer from the current input stream, update the adler32 | ||||||
|  |  * and total number of bytes read.  All deflate() input goes through | ||||||
|  |  * this function so some applications may wish to modify it to avoid | ||||||
|  |  * allocating a large strm->next_in buffer and copying from it. | ||||||
|  |  * (See also flush_pending()). | ||||||
|  |  */ | ||||||
|  | local unsigned read_buf(z_streamp strm, Bytef *buf, unsigned size) { | ||||||
|  |     unsigned len = strm->avail_in; | ||||||
|  |  | ||||||
|  |     if (len > size) len = size; | ||||||
|  |     if (len == 0) return 0; | ||||||
|  |  | ||||||
|  |     strm->avail_in  -= len; | ||||||
|  |  | ||||||
|  |     zmemcpy(buf, strm->next_in, len); | ||||||
|  |     if (strm->state->wrap == 1) { | ||||||
|  |         strm->adler = adler32(strm->adler, buf, len); | ||||||
|  |     } | ||||||
|  | #ifdef GZIP | ||||||
|  |     else if (strm->state->wrap == 2) { | ||||||
|  |         strm->adler = crc32(strm->adler, buf, len); | ||||||
|  |     } | ||||||
|  | #endif | ||||||
|  |     strm->next_in  += len; | ||||||
|  |     strm->total_in += len; | ||||||
|  |  | ||||||
|  |     return len; | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Fill the window when the lookahead becomes insufficient. | ||||||
|  |  * Updates strstart and lookahead. | ||||||
|  |  * | ||||||
|  |  * IN assertion: lookahead < MIN_LOOKAHEAD | ||||||
|  |  * OUT assertions: strstart <= window_size-MIN_LOOKAHEAD | ||||||
|  |  *    At least one byte has been read, or avail_in == 0; reads are | ||||||
|  |  *    performed for at least two bytes (required for the zip translate_eol | ||||||
|  |  *    option -- not supported here). | ||||||
|  |  */ | ||||||
|  | local void fill_window(deflate_state *s) { | ||||||
|  |     unsigned n; | ||||||
|  |     unsigned more;    /* Amount of free space at the end of the window. */ | ||||||
|  |     uInt wsize = s->w_size; | ||||||
|  |  | ||||||
|  |     Assert(s->lookahead < MIN_LOOKAHEAD, "already enough lookahead"); | ||||||
|  |  | ||||||
|  |     do { | ||||||
|  |         more = (unsigned)(s->window_size -(ulg)s->lookahead -(ulg)s->strstart); | ||||||
|  |  | ||||||
|  |         /* Deal with !@#$% 64K limit: */ | ||||||
|  |         if (sizeof(int) <= 2) { | ||||||
|  |             if (more == 0 && s->strstart == 0 && s->lookahead == 0) { | ||||||
|  |                 more = wsize; | ||||||
|  |  | ||||||
|  |             } else if (more == (unsigned)(-1)) { | ||||||
|  |                 /* Very unlikely, but possible on 16 bit machine if | ||||||
|  |                  * strstart == 0 && lookahead == 1 (input done a byte at time) | ||||||
|  |                  */ | ||||||
|  |                 more--; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |  | ||||||
|  |         /* If the window is almost full and there is insufficient lookahead, | ||||||
|  |          * move the upper half to the lower one to make room in the upper half. | ||||||
|  |          */ | ||||||
|  |         if (s->strstart >= wsize + MAX_DIST(s)) { | ||||||
|  |  | ||||||
|  |             zmemcpy(s->window, s->window + wsize, (unsigned)wsize - more); | ||||||
|  |             s->match_start -= wsize; | ||||||
|  |             s->strstart    -= wsize; /* we now have strstart >= MAX_DIST */ | ||||||
|  |             s->block_start -= (long) wsize; | ||||||
|  |             if (s->insert > s->strstart) | ||||||
|  |                 s->insert = s->strstart; | ||||||
|  |             slide_hash(s); | ||||||
|  |             more += wsize; | ||||||
|  |         } | ||||||
|  |         if (s->strm->avail_in == 0) break; | ||||||
|  |  | ||||||
|  |         /* If there was no sliding: | ||||||
|  |          *    strstart <= WSIZE+MAX_DIST-1 && lookahead <= MIN_LOOKAHEAD - 1 && | ||||||
|  |          *    more == window_size - lookahead - strstart | ||||||
|  |          * => more >= window_size - (MIN_LOOKAHEAD-1 + WSIZE + MAX_DIST-1) | ||||||
|  |          * => more >= window_size - 2*WSIZE + 2 | ||||||
|  |          * In the BIG_MEM or MMAP case (not yet supported), | ||||||
|  |          *   window_size == input_size + MIN_LOOKAHEAD  && | ||||||
|  |          *   strstart + s->lookahead <= input_size => more >= MIN_LOOKAHEAD. | ||||||
|  |          * Otherwise, window_size == 2*WSIZE so more >= 2. | ||||||
|  |          * If there was sliding, more >= WSIZE. So in all cases, more >= 2. | ||||||
|  |          */ | ||||||
|  |         Assert(more >= 2, "more < 2"); | ||||||
|  |  | ||||||
|  |         n = read_buf(s->strm, s->window + s->strstart + s->lookahead, more); | ||||||
|  |         s->lookahead += n; | ||||||
|  |  | ||||||
|  |         /* Initialize the hash value now that we have some input: */ | ||||||
|  |         if (s->lookahead + s->insert >= MIN_MATCH) { | ||||||
|  |             uInt str = s->strstart - s->insert; | ||||||
|  |             s->ins_h = s->window[str]; | ||||||
|  |             UPDATE_HASH(s, s->ins_h, s->window[str + 1]); | ||||||
|  | #if MIN_MATCH != 3 | ||||||
|  |             Call UPDATE_HASH() MIN_MATCH-3 more times | ||||||
|  | #endif | ||||||
|  |             while (s->insert) { | ||||||
|  |                 UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); | ||||||
|  | #ifndef FASTEST | ||||||
|  |                 s->prev[str & s->w_mask] = s->head[s->ins_h]; | ||||||
|  | #endif | ||||||
|  |                 s->head[s->ins_h] = (Pos)str; | ||||||
|  |                 str++; | ||||||
|  |                 s->insert--; | ||||||
|  |                 if (s->lookahead + s->insert < MIN_MATCH) | ||||||
|  |                     break; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         /* If the whole input has less than MIN_MATCH bytes, ins_h is garbage, | ||||||
|  |          * but this is not important since only literal bytes will be emitted. | ||||||
|  |          */ | ||||||
|  |  | ||||||
|  |     } while (s->lookahead < MIN_LOOKAHEAD && s->strm->avail_in != 0); | ||||||
|  |  | ||||||
|  |     /* If the WIN_INIT bytes after the end of the current data have never been | ||||||
|  |      * written, then zero those bytes in order to avoid memory check reports of | ||||||
|  |      * the use of uninitialized (or uninitialised as Julian writes) bytes by | ||||||
|  |      * the longest match routines.  Update the high water mark for the next | ||||||
|  |      * time through here.  WIN_INIT is set to MAX_MATCH since the longest match | ||||||
|  |      * routines allow scanning to strstart + MAX_MATCH, ignoring lookahead. | ||||||
|  |      */ | ||||||
|  |     if (s->high_water < s->window_size) { | ||||||
|  |         ulg curr = s->strstart + (ulg)(s->lookahead); | ||||||
|  |         ulg init; | ||||||
|  |  | ||||||
|  |         if (s->high_water < curr) { | ||||||
|  |             /* Previous high water mark below current data -- zero WIN_INIT | ||||||
|  |              * bytes or up to end of window, whichever is less. | ||||||
|  |              */ | ||||||
|  |             init = s->window_size - curr; | ||||||
|  |             if (init > WIN_INIT) | ||||||
|  |                 init = WIN_INIT; | ||||||
|  |             zmemzero(s->window + curr, (unsigned)init); | ||||||
|  |             s->high_water = curr + init; | ||||||
|  |         } | ||||||
|  |         else if (s->high_water < (ulg)curr + WIN_INIT) { | ||||||
|  |             /* High water mark at or above current data, but below current data | ||||||
|  |              * plus WIN_INIT -- zero out to current data plus WIN_INIT, or up | ||||||
|  |              * to end of window, whichever is less. | ||||||
|  |              */ | ||||||
|  |             init = (ulg)curr + WIN_INIT - s->high_water; | ||||||
|  |             if (init > s->window_size - s->high_water) | ||||||
|  |                 init = s->window_size - s->high_water; | ||||||
|  |             zmemzero(s->window + s->high_water, (unsigned)init); | ||||||
|  |             s->high_water += init; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     Assert((ulg)s->strstart <= s->window_size - MIN_LOOKAHEAD, | ||||||
|  |            "not enough room for search"); | ||||||
|  | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflateInit_(strm, level, version, stream_size) | int ZEXPORT deflateInit_(z_streamp strm, int level, const char *version, | ||||||
|     z_streamp strm; |                          int stream_size) { | ||||||
|     int level; |  | ||||||
|     const char *version; |  | ||||||
|     int stream_size; |  | ||||||
| { |  | ||||||
|     return deflateInit2_(strm, level, Z_DEFLATED, MAX_WBITS, DEF_MEM_LEVEL, |     return deflateInit2_(strm, level, Z_DEFLATED, MAX_WBITS, DEF_MEM_LEVEL, | ||||||
|                          Z_DEFAULT_STRATEGY, version, stream_size); |                          Z_DEFAULT_STRATEGY, version, stream_size); | ||||||
|     /* To do: ignore strm->next_in if we use it as window */ |     /* To do: ignore strm->next_in if we use it as window */ | ||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflateInit2_(strm, level, method, windowBits, memLevel, strategy, | int ZEXPORT deflateInit2_(z_streamp strm, int level, int method, | ||||||
|                   version, stream_size) |                           int windowBits, int memLevel, int strategy, | ||||||
|     z_streamp strm; |                           const char *version, int stream_size) { | ||||||
|     int  level; |  | ||||||
|     int  method; |  | ||||||
|     int  windowBits; |  | ||||||
|     int  memLevel; |  | ||||||
|     int  strategy; |  | ||||||
|     const char *version; |  | ||||||
|     int stream_size; |  | ||||||
| { |  | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|     int wrap = 1; |     int wrap = 1; | ||||||
|     static const char my_version[] = ZLIB_VERSION; |     static const char my_version[] = ZLIB_VERSION; | ||||||
| @@ -386,9 +520,7 @@ int ZEXPORT deflateInit2_(strm, level, method, windowBits, memLevel, strategy, | |||||||
| /* ========================================================================= | /* ========================================================================= | ||||||
|  * Check for a valid deflate stream state. Return 0 if ok, 1 if not. |  * Check for a valid deflate stream state. Return 0 if ok, 1 if not. | ||||||
|  */ |  */ | ||||||
| local int deflateStateCheck(strm) | local int deflateStateCheck(z_streamp strm) { | ||||||
|     z_streamp strm; |  | ||||||
| { |  | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|     if (strm == Z_NULL || |     if (strm == Z_NULL || | ||||||
|         strm->zalloc == (alloc_func)0 || strm->zfree == (free_func)0) |         strm->zalloc == (alloc_func)0 || strm->zfree == (free_func)0) | ||||||
| @@ -409,11 +541,8 @@ local int deflateStateCheck(strm) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflateSetDictionary(strm, dictionary, dictLength) | int ZEXPORT deflateSetDictionary(z_streamp strm, const Bytef *dictionary, | ||||||
|     z_streamp strm; |                                  uInt  dictLength) { | ||||||
|     const Bytef *dictionary; |  | ||||||
|     uInt  dictLength; |  | ||||||
| { |  | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|     uInt str, n; |     uInt str, n; | ||||||
|     int wrap; |     int wrap; | ||||||
| @@ -478,11 +607,8 @@ int ZEXPORT deflateSetDictionary(strm, dictionary, dictLength) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflateGetDictionary(strm, dictionary, dictLength) | int ZEXPORT deflateGetDictionary(z_streamp strm, Bytef *dictionary, | ||||||
|     z_streamp strm; |                                  uInt *dictLength) { | ||||||
|     Bytef *dictionary; |  | ||||||
|     uInt  *dictLength; |  | ||||||
| { |  | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|     uInt len; |     uInt len; | ||||||
|  |  | ||||||
| @@ -500,9 +626,7 @@ int ZEXPORT deflateGetDictionary(strm, dictionary, dictLength) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflateResetKeep(strm) | int ZEXPORT deflateResetKeep(z_streamp strm) { | ||||||
|     z_streamp strm; |  | ||||||
| { |  | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|  |  | ||||||
|     if (deflateStateCheck(strm)) { |     if (deflateStateCheck(strm)) { | ||||||
| @@ -537,10 +661,32 @@ int ZEXPORT deflateResetKeep(strm) | |||||||
|     return Z_OK; |     return Z_OK; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Initialize the "longest match" routines for a new zlib stream | ||||||
|  |  */ | ||||||
|  | local void lm_init(deflate_state *s) { | ||||||
|  |     s->window_size = (ulg)2L*s->w_size; | ||||||
|  |  | ||||||
|  |     CLEAR_HASH(s); | ||||||
|  |  | ||||||
|  |     /* Set the default configuration parameters: | ||||||
|  |      */ | ||||||
|  |     s->max_lazy_match   = configuration_table[s->level].max_lazy; | ||||||
|  |     s->good_match       = configuration_table[s->level].good_length; | ||||||
|  |     s->nice_match       = configuration_table[s->level].nice_length; | ||||||
|  |     s->max_chain_length = configuration_table[s->level].max_chain; | ||||||
|  |  | ||||||
|  |     s->strstart = 0; | ||||||
|  |     s->block_start = 0L; | ||||||
|  |     s->lookahead = 0; | ||||||
|  |     s->insert = 0; | ||||||
|  |     s->match_length = s->prev_length = MIN_MATCH-1; | ||||||
|  |     s->match_available = 0; | ||||||
|  |     s->ins_h = 0; | ||||||
|  | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflateReset(strm) | int ZEXPORT deflateReset(z_streamp strm) { | ||||||
|     z_streamp strm; |  | ||||||
| { |  | ||||||
|     int ret; |     int ret; | ||||||
|  |  | ||||||
|     ret = deflateResetKeep(strm); |     ret = deflateResetKeep(strm); | ||||||
| @@ -550,10 +696,7 @@ int ZEXPORT deflateReset(strm) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflateSetHeader(strm, head) | int ZEXPORT deflateSetHeader(z_streamp strm, gz_headerp head) { | ||||||
|     z_streamp strm; |  | ||||||
|     gz_headerp head; |  | ||||||
| { |  | ||||||
|     if (deflateStateCheck(strm) || strm->state->wrap != 2) |     if (deflateStateCheck(strm) || strm->state->wrap != 2) | ||||||
|         return Z_STREAM_ERROR; |         return Z_STREAM_ERROR; | ||||||
|     strm->state->gzhead = head; |     strm->state->gzhead = head; | ||||||
| @@ -561,11 +704,7 @@ int ZEXPORT deflateSetHeader(strm, head) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflatePending(strm, pending, bits) | int ZEXPORT deflatePending(z_streamp strm, unsigned *pending, int *bits) { | ||||||
|     unsigned *pending; |  | ||||||
|     int *bits; |  | ||||||
|     z_streamp strm; |  | ||||||
| { |  | ||||||
|     if (deflateStateCheck(strm)) return Z_STREAM_ERROR; |     if (deflateStateCheck(strm)) return Z_STREAM_ERROR; | ||||||
|     if (pending != Z_NULL) |     if (pending != Z_NULL) | ||||||
|         *pending = strm->state->pending; |         *pending = strm->state->pending; | ||||||
| @@ -575,11 +714,7 @@ int ZEXPORT deflatePending(strm, pending, bits) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflatePrime(strm, bits, value) | int ZEXPORT deflatePrime(z_streamp strm, int bits, int value) { | ||||||
|     z_streamp strm; |  | ||||||
|     int bits; |  | ||||||
|     int value; |  | ||||||
| { |  | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|     int put; |     int put; | ||||||
|  |  | ||||||
| @@ -602,11 +737,7 @@ int ZEXPORT deflatePrime(strm, bits, value) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflateParams(strm, level, strategy) | int ZEXPORT deflateParams(z_streamp strm, int level, int strategy) { | ||||||
|     z_streamp strm; |  | ||||||
|     int level; |  | ||||||
|     int strategy; |  | ||||||
| { |  | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|     compress_func func; |     compress_func func; | ||||||
|  |  | ||||||
| @@ -651,13 +782,8 @@ int ZEXPORT deflateParams(strm, level, strategy) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflateTune(strm, good_length, max_lazy, nice_length, max_chain) | int ZEXPORT deflateTune(z_streamp strm, int good_length, int max_lazy, | ||||||
|     z_streamp strm; |                         int nice_length, int max_chain) { | ||||||
|     int good_length; |  | ||||||
|     int max_lazy; |  | ||||||
|     int nice_length; |  | ||||||
|     int max_chain; |  | ||||||
| { |  | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|  |  | ||||||
|     if (deflateStateCheck(strm)) return Z_STREAM_ERROR; |     if (deflateStateCheck(strm)) return Z_STREAM_ERROR; | ||||||
| @@ -693,10 +819,7 @@ int ZEXPORT deflateTune(strm, good_length, max_lazy, nice_length, max_chain) | |||||||
|  * |  * | ||||||
|  * Shifts are used to approximate divisions, for speed. |  * Shifts are used to approximate divisions, for speed. | ||||||
|  */ |  */ | ||||||
| uLong ZEXPORT deflateBound(strm, sourceLen) | uLong ZEXPORT deflateBound(z_streamp strm, uLong sourceLen) { | ||||||
|     z_streamp strm; |  | ||||||
|     uLong sourceLen; |  | ||||||
| { |  | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|     uLong fixedlen, storelen, wraplen; |     uLong fixedlen, storelen, wraplen; | ||||||
|  |  | ||||||
| @@ -752,7 +875,8 @@ uLong ZEXPORT deflateBound(strm, sourceLen) | |||||||
|  |  | ||||||
|     /* if not default parameters, return one of the conservative bounds */ |     /* if not default parameters, return one of the conservative bounds */ | ||||||
|     if (s->w_bits != 15 || s->hash_bits != 8 + 7) |     if (s->w_bits != 15 || s->hash_bits != 8 + 7) | ||||||
|         return (s->w_bits <= s->hash_bits ? fixedlen : storelen) + wraplen; |         return (s->w_bits <= s->hash_bits && s->level ? fixedlen : storelen) + | ||||||
|  |                wraplen; | ||||||
|  |  | ||||||
|     /* default settings: return tight bound for that case -- ~0.03% overhead |     /* default settings: return tight bound for that case -- ~0.03% overhead | ||||||
|        plus a small constant */ |        plus a small constant */ | ||||||
| @@ -765,10 +889,7 @@ uLong ZEXPORT deflateBound(strm, sourceLen) | |||||||
|  * IN assertion: the stream state is correct and there is enough room in |  * IN assertion: the stream state is correct and there is enough room in | ||||||
|  * pending_buf. |  * pending_buf. | ||||||
|  */ |  */ | ||||||
| local void putShortMSB(s, b) | local void putShortMSB(deflate_state *s, uInt b) { | ||||||
|     deflate_state *s; |  | ||||||
|     uInt b; |  | ||||||
| { |  | ||||||
|     put_byte(s, (Byte)(b >> 8)); |     put_byte(s, (Byte)(b >> 8)); | ||||||
|     put_byte(s, (Byte)(b & 0xff)); |     put_byte(s, (Byte)(b & 0xff)); | ||||||
| } | } | ||||||
| @@ -779,9 +900,7 @@ local void putShortMSB(s, b) | |||||||
|  * applications may wish to modify it to avoid allocating a large |  * applications may wish to modify it to avoid allocating a large | ||||||
|  * strm->next_out buffer and copying into it. (See also read_buf()). |  * strm->next_out buffer and copying into it. (See also read_buf()). | ||||||
|  */ |  */ | ||||||
| local void flush_pending(strm) | local void flush_pending(z_streamp strm) { | ||||||
|     z_streamp strm; |  | ||||||
| { |  | ||||||
|     unsigned len; |     unsigned len; | ||||||
|     deflate_state *s = strm->state; |     deflate_state *s = strm->state; | ||||||
|  |  | ||||||
| @@ -812,10 +931,7 @@ local void flush_pending(strm) | |||||||
|     } while (0) |     } while (0) | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflate(strm, flush) | int ZEXPORT deflate(z_streamp strm, int flush) { | ||||||
|     z_streamp strm; |  | ||||||
|     int flush; |  | ||||||
| { |  | ||||||
|     int old_flush; /* value of flush param for previous deflate call */ |     int old_flush; /* value of flush param for previous deflate call */ | ||||||
|     deflate_state *s; |     deflate_state *s; | ||||||
|  |  | ||||||
| @@ -1127,9 +1243,7 @@ int ZEXPORT deflate(strm, flush) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* ========================================================================= */ | /* ========================================================================= */ | ||||||
| int ZEXPORT deflateEnd(strm) | int ZEXPORT deflateEnd(z_streamp strm) { | ||||||
|     z_streamp strm; |  | ||||||
| { |  | ||||||
|     int status; |     int status; | ||||||
|  |  | ||||||
|     if (deflateStateCheck(strm)) return Z_STREAM_ERROR; |     if (deflateStateCheck(strm)) return Z_STREAM_ERROR; | ||||||
| @@ -1153,11 +1267,10 @@ int ZEXPORT deflateEnd(strm) | |||||||
|  * To simplify the source, this is not supported for 16-bit MSDOS (which |  * To simplify the source, this is not supported for 16-bit MSDOS (which | ||||||
|  * doesn't have enough memory anyway to duplicate compression states). |  * doesn't have enough memory anyway to duplicate compression states). | ||||||
|  */ |  */ | ||||||
| int ZEXPORT deflateCopy(dest, source) | int ZEXPORT deflateCopy(z_streamp dest, z_streamp source) { | ||||||
|     z_streamp dest; |  | ||||||
|     z_streamp source; |  | ||||||
| { |  | ||||||
| #ifdef MAXSEG_64K | #ifdef MAXSEG_64K | ||||||
|  |     (void)dest; | ||||||
|  |     (void)source; | ||||||
|     return Z_STREAM_ERROR; |     return Z_STREAM_ERROR; | ||||||
| #else | #else | ||||||
|     deflate_state *ds; |     deflate_state *ds; | ||||||
| @@ -1205,66 +1318,6 @@ int ZEXPORT deflateCopy(dest, source) | |||||||
| #endif /* MAXSEG_64K */ | #endif /* MAXSEG_64K */ | ||||||
| } | } | ||||||
|  |  | ||||||
| /* =========================================================================== |  | ||||||
|  * Read a new buffer from the current input stream, update the adler32 |  | ||||||
|  * and total number of bytes read.  All deflate() input goes through |  | ||||||
|  * this function so some applications may wish to modify it to avoid |  | ||||||
|  * allocating a large strm->next_in buffer and copying from it. |  | ||||||
|  * (See also flush_pending()). |  | ||||||
|  */ |  | ||||||
| local unsigned read_buf(strm, buf, size) |  | ||||||
|     z_streamp strm; |  | ||||||
|     Bytef *buf; |  | ||||||
|     unsigned size; |  | ||||||
| { |  | ||||||
|     unsigned len = strm->avail_in; |  | ||||||
|  |  | ||||||
|     if (len > size) len = size; |  | ||||||
|     if (len == 0) return 0; |  | ||||||
|  |  | ||||||
|     strm->avail_in  -= len; |  | ||||||
|  |  | ||||||
|     zmemcpy(buf, strm->next_in, len); |  | ||||||
|     if (strm->state->wrap == 1) { |  | ||||||
|         strm->adler = adler32(strm->adler, buf, len); |  | ||||||
|     } |  | ||||||
| #ifdef GZIP |  | ||||||
|     else if (strm->state->wrap == 2) { |  | ||||||
|         strm->adler = crc32(strm->adler, buf, len); |  | ||||||
|     } |  | ||||||
| #endif |  | ||||||
|     strm->next_in  += len; |  | ||||||
|     strm->total_in += len; |  | ||||||
|  |  | ||||||
|     return len; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* =========================================================================== |  | ||||||
|  * Initialize the "longest match" routines for a new zlib stream |  | ||||||
|  */ |  | ||||||
| local void lm_init(s) |  | ||||||
|     deflate_state *s; |  | ||||||
| { |  | ||||||
|     s->window_size = (ulg)2L*s->w_size; |  | ||||||
|  |  | ||||||
|     CLEAR_HASH(s); |  | ||||||
|  |  | ||||||
|     /* Set the default configuration parameters: |  | ||||||
|      */ |  | ||||||
|     s->max_lazy_match   = configuration_table[s->level].max_lazy; |  | ||||||
|     s->good_match       = configuration_table[s->level].good_length; |  | ||||||
|     s->nice_match       = configuration_table[s->level].nice_length; |  | ||||||
|     s->max_chain_length = configuration_table[s->level].max_chain; |  | ||||||
|  |  | ||||||
|     s->strstart = 0; |  | ||||||
|     s->block_start = 0L; |  | ||||||
|     s->lookahead = 0; |  | ||||||
|     s->insert = 0; |  | ||||||
|     s->match_length = s->prev_length = MIN_MATCH-1; |  | ||||||
|     s->match_available = 0; |  | ||||||
|     s->ins_h = 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #ifndef FASTEST | #ifndef FASTEST | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Set match_start to the longest match starting at the given string and |  * Set match_start to the longest match starting at the given string and | ||||||
| @@ -1275,10 +1328,7 @@ local void lm_init(s) | |||||||
|  *   string (strstart) and its distance is <= MAX_DIST, and prev_length >= 1 |  *   string (strstart) and its distance is <= MAX_DIST, and prev_length >= 1 | ||||||
|  * OUT assertion: the match length is not greater than s->lookahead. |  * OUT assertion: the match length is not greater than s->lookahead. | ||||||
|  */ |  */ | ||||||
| local uInt longest_match(s, cur_match) | local uInt longest_match(deflate_state *s, IPos cur_match) { | ||||||
|     deflate_state *s; |  | ||||||
|     IPos cur_match;                             /* current match */ |  | ||||||
| { |  | ||||||
|     unsigned chain_length = s->max_chain_length;/* max hash chain length */ |     unsigned chain_length = s->max_chain_length;/* max hash chain length */ | ||||||
|     register Bytef *scan = s->window + s->strstart; /* current string */ |     register Bytef *scan = s->window + s->strstart; /* current string */ | ||||||
|     register Bytef *match;                      /* matched string */ |     register Bytef *match;                      /* matched string */ | ||||||
| @@ -1426,10 +1476,7 @@ local uInt longest_match(s, cur_match) | |||||||
| /* --------------------------------------------------------------------------- | /* --------------------------------------------------------------------------- | ||||||
|  * Optimized version for FASTEST only |  * Optimized version for FASTEST only | ||||||
|  */ |  */ | ||||||
| local uInt longest_match(s, cur_match) | local uInt longest_match(deflate_state *s, IPos cur_match) { | ||||||
|     deflate_state *s; |  | ||||||
|     IPos cur_match;                             /* current match */ |  | ||||||
| { |  | ||||||
|     register Bytef *scan = s->window + s->strstart; /* current string */ |     register Bytef *scan = s->window + s->strstart; /* current string */ | ||||||
|     register Bytef *match;                       /* matched string */ |     register Bytef *match;                       /* matched string */ | ||||||
|     register int len;                           /* length of current match */ |     register int len;                           /* length of current match */ | ||||||
| @@ -1490,11 +1537,7 @@ local uInt longest_match(s, cur_match) | |||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Check that the match at match_start is indeed a match. |  * Check that the match at match_start is indeed a match. | ||||||
|  */ |  */ | ||||||
| local void check_match(s, start, match, length) | local void check_match(deflate_state *s, IPos start, IPos match, int length) { | ||||||
|     deflate_state *s; |  | ||||||
|     IPos start, match; |  | ||||||
|     int length; |  | ||||||
| { |  | ||||||
|     /* check that the match is indeed a match */ |     /* check that the match is indeed a match */ | ||||||
|     if (zmemcmp(s->window + match, |     if (zmemcmp(s->window + match, | ||||||
|                 s->window + start, length) != EQUAL) { |                 s->window + start, length) != EQUAL) { | ||||||
| @@ -1514,137 +1557,6 @@ local void check_match(s, start, match, length) | |||||||
| #  define check_match(s, start, match, length) | #  define check_match(s, start, match, length) | ||||||
| #endif /* ZLIB_DEBUG */ | #endif /* ZLIB_DEBUG */ | ||||||
|  |  | ||||||
| /* =========================================================================== |  | ||||||
|  * Fill the window when the lookahead becomes insufficient. |  | ||||||
|  * Updates strstart and lookahead. |  | ||||||
|  * |  | ||||||
|  * IN assertion: lookahead < MIN_LOOKAHEAD |  | ||||||
|  * OUT assertions: strstart <= window_size-MIN_LOOKAHEAD |  | ||||||
|  *    At least one byte has been read, or avail_in == 0; reads are |  | ||||||
|  *    performed for at least two bytes (required for the zip translate_eol |  | ||||||
|  *    option -- not supported here). |  | ||||||
|  */ |  | ||||||
| local void fill_window(s) |  | ||||||
|     deflate_state *s; |  | ||||||
| { |  | ||||||
|     unsigned n; |  | ||||||
|     unsigned more;    /* Amount of free space at the end of the window. */ |  | ||||||
|     uInt wsize = s->w_size; |  | ||||||
|  |  | ||||||
|     Assert(s->lookahead < MIN_LOOKAHEAD, "already enough lookahead"); |  | ||||||
|  |  | ||||||
|     do { |  | ||||||
|         more = (unsigned)(s->window_size -(ulg)s->lookahead -(ulg)s->strstart); |  | ||||||
|  |  | ||||||
|         /* Deal with !@#$% 64K limit: */ |  | ||||||
|         if (sizeof(int) <= 2) { |  | ||||||
|             if (more == 0 && s->strstart == 0 && s->lookahead == 0) { |  | ||||||
|                 more = wsize; |  | ||||||
|  |  | ||||||
|             } else if (more == (unsigned)(-1)) { |  | ||||||
|                 /* Very unlikely, but possible on 16 bit machine if |  | ||||||
|                  * strstart == 0 && lookahead == 1 (input done a byte at time) |  | ||||||
|                  */ |  | ||||||
|                 more--; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         /* If the window is almost full and there is insufficient lookahead, |  | ||||||
|          * move the upper half to the lower one to make room in the upper half. |  | ||||||
|          */ |  | ||||||
|         if (s->strstart >= wsize + MAX_DIST(s)) { |  | ||||||
|  |  | ||||||
|             zmemcpy(s->window, s->window + wsize, (unsigned)wsize - more); |  | ||||||
|             s->match_start -= wsize; |  | ||||||
|             s->strstart    -= wsize; /* we now have strstart >= MAX_DIST */ |  | ||||||
|             s->block_start -= (long) wsize; |  | ||||||
|             if (s->insert > s->strstart) |  | ||||||
|                 s->insert = s->strstart; |  | ||||||
|             slide_hash(s); |  | ||||||
|             more += wsize; |  | ||||||
|         } |  | ||||||
|         if (s->strm->avail_in == 0) break; |  | ||||||
|  |  | ||||||
|         /* If there was no sliding: |  | ||||||
|          *    strstart <= WSIZE+MAX_DIST-1 && lookahead <= MIN_LOOKAHEAD - 1 && |  | ||||||
|          *    more == window_size - lookahead - strstart |  | ||||||
|          * => more >= window_size - (MIN_LOOKAHEAD-1 + WSIZE + MAX_DIST-1) |  | ||||||
|          * => more >= window_size - 2*WSIZE + 2 |  | ||||||
|          * In the BIG_MEM or MMAP case (not yet supported), |  | ||||||
|          *   window_size == input_size + MIN_LOOKAHEAD  && |  | ||||||
|          *   strstart + s->lookahead <= input_size => more >= MIN_LOOKAHEAD. |  | ||||||
|          * Otherwise, window_size == 2*WSIZE so more >= 2. |  | ||||||
|          * If there was sliding, more >= WSIZE. So in all cases, more >= 2. |  | ||||||
|          */ |  | ||||||
|         Assert(more >= 2, "more < 2"); |  | ||||||
|  |  | ||||||
|         n = read_buf(s->strm, s->window + s->strstart + s->lookahead, more); |  | ||||||
|         s->lookahead += n; |  | ||||||
|  |  | ||||||
|         /* Initialize the hash value now that we have some input: */ |  | ||||||
|         if (s->lookahead + s->insert >= MIN_MATCH) { |  | ||||||
|             uInt str = s->strstart - s->insert; |  | ||||||
|             s->ins_h = s->window[str]; |  | ||||||
|             UPDATE_HASH(s, s->ins_h, s->window[str + 1]); |  | ||||||
| #if MIN_MATCH != 3 |  | ||||||
|             Call UPDATE_HASH() MIN_MATCH-3 more times |  | ||||||
| #endif |  | ||||||
|             while (s->insert) { |  | ||||||
|                 UPDATE_HASH(s, s->ins_h, s->window[str + MIN_MATCH-1]); |  | ||||||
| #ifndef FASTEST |  | ||||||
|                 s->prev[str & s->w_mask] = s->head[s->ins_h]; |  | ||||||
| #endif |  | ||||||
|                 s->head[s->ins_h] = (Pos)str; |  | ||||||
|                 str++; |  | ||||||
|                 s->insert--; |  | ||||||
|                 if (s->lookahead + s->insert < MIN_MATCH) |  | ||||||
|                     break; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|         /* If the whole input has less than MIN_MATCH bytes, ins_h is garbage, |  | ||||||
|          * but this is not important since only literal bytes will be emitted. |  | ||||||
|          */ |  | ||||||
|  |  | ||||||
|     } while (s->lookahead < MIN_LOOKAHEAD && s->strm->avail_in != 0); |  | ||||||
|  |  | ||||||
|     /* If the WIN_INIT bytes after the end of the current data have never been |  | ||||||
|      * written, then zero those bytes in order to avoid memory check reports of |  | ||||||
|      * the use of uninitialized (or uninitialised as Julian writes) bytes by |  | ||||||
|      * the longest match routines.  Update the high water mark for the next |  | ||||||
|      * time through here.  WIN_INIT is set to MAX_MATCH since the longest match |  | ||||||
|      * routines allow scanning to strstart + MAX_MATCH, ignoring lookahead. |  | ||||||
|      */ |  | ||||||
|     if (s->high_water < s->window_size) { |  | ||||||
|         ulg curr = s->strstart + (ulg)(s->lookahead); |  | ||||||
|         ulg init; |  | ||||||
|  |  | ||||||
|         if (s->high_water < curr) { |  | ||||||
|             /* Previous high water mark below current data -- zero WIN_INIT |  | ||||||
|              * bytes or up to end of window, whichever is less. |  | ||||||
|              */ |  | ||||||
|             init = s->window_size - curr; |  | ||||||
|             if (init > WIN_INIT) |  | ||||||
|                 init = WIN_INIT; |  | ||||||
|             zmemzero(s->window + curr, (unsigned)init); |  | ||||||
|             s->high_water = curr + init; |  | ||||||
|         } |  | ||||||
|         else if (s->high_water < (ulg)curr + WIN_INIT) { |  | ||||||
|             /* High water mark at or above current data, but below current data |  | ||||||
|              * plus WIN_INIT -- zero out to current data plus WIN_INIT, or up |  | ||||||
|              * to end of window, whichever is less. |  | ||||||
|              */ |  | ||||||
|             init = (ulg)curr + WIN_INIT - s->high_water; |  | ||||||
|             if (init > s->window_size - s->high_water) |  | ||||||
|                 init = s->window_size - s->high_water; |  | ||||||
|             zmemzero(s->window + s->high_water, (unsigned)init); |  | ||||||
|             s->high_water += init; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Assert((ulg)s->strstart <= s->window_size - MIN_LOOKAHEAD, |  | ||||||
|            "not enough room for search"); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Flush the current block, with given end-of-file flag. |  * Flush the current block, with given end-of-file flag. | ||||||
|  * IN assertion: strstart is set to the end of the current match. |  * IN assertion: strstart is set to the end of the current match. | ||||||
| @@ -1687,10 +1599,7 @@ local void fill_window(s) | |||||||
|  * copied. It is most efficient with large input and output buffers, which |  * copied. It is most efficient with large input and output buffers, which | ||||||
|  * maximizes the opportunities to have a single copy from next_in to next_out. |  * maximizes the opportunities to have a single copy from next_in to next_out. | ||||||
|  */ |  */ | ||||||
| local block_state deflate_stored(s, flush) | local block_state deflate_stored(deflate_state *s, int flush) { | ||||||
|     deflate_state *s; |  | ||||||
|     int flush; |  | ||||||
| { |  | ||||||
|     /* Smallest worthy block size when not flushing or finishing. By default |     /* Smallest worthy block size when not flushing or finishing. By default | ||||||
|      * this is 32K. This can be as small as 507 bytes for memLevel == 1. For |      * this is 32K. This can be as small as 507 bytes for memLevel == 1. For | ||||||
|      * large input and output buffers, the stored block size will be larger. |      * large input and output buffers, the stored block size will be larger. | ||||||
| @@ -1874,10 +1783,7 @@ local block_state deflate_stored(s, flush) | |||||||
|  * new strings in the dictionary only for unmatched strings or for short |  * new strings in the dictionary only for unmatched strings or for short | ||||||
|  * matches. It is used only for the fast compression options. |  * matches. It is used only for the fast compression options. | ||||||
|  */ |  */ | ||||||
| local block_state deflate_fast(s, flush) | local block_state deflate_fast(deflate_state *s, int flush) { | ||||||
|     deflate_state *s; |  | ||||||
|     int flush; |  | ||||||
| { |  | ||||||
|     IPos hash_head;       /* head of the hash chain */ |     IPos hash_head;       /* head of the hash chain */ | ||||||
|     int bflush;           /* set if current block must be flushed */ |     int bflush;           /* set if current block must be flushed */ | ||||||
|  |  | ||||||
| @@ -1976,10 +1882,7 @@ local block_state deflate_fast(s, flush) | |||||||
|  * evaluation for matches: a match is finally adopted only if there is |  * evaluation for matches: a match is finally adopted only if there is | ||||||
|  * no better match at the next window position. |  * no better match at the next window position. | ||||||
|  */ |  */ | ||||||
| local block_state deflate_slow(s, flush) | local block_state deflate_slow(deflate_state *s, int flush) { | ||||||
|     deflate_state *s; |  | ||||||
|     int flush; |  | ||||||
| { |  | ||||||
|     IPos hash_head;          /* head of hash chain */ |     IPos hash_head;          /* head of hash chain */ | ||||||
|     int bflush;              /* set if current block must be flushed */ |     int bflush;              /* set if current block must be flushed */ | ||||||
|  |  | ||||||
| @@ -2107,10 +2010,7 @@ local block_state deflate_slow(s, flush) | |||||||
|  * one.  Do not maintain a hash table.  (It will be regenerated if this run of |  * one.  Do not maintain a hash table.  (It will be regenerated if this run of | ||||||
|  * deflate switches away from Z_RLE.) |  * deflate switches away from Z_RLE.) | ||||||
|  */ |  */ | ||||||
| local block_state deflate_rle(s, flush) | local block_state deflate_rle(deflate_state *s, int flush) { | ||||||
|     deflate_state *s; |  | ||||||
|     int flush; |  | ||||||
| { |  | ||||||
|     int bflush;             /* set if current block must be flushed */ |     int bflush;             /* set if current block must be flushed */ | ||||||
|     uInt prev;              /* byte at distance one to match */ |     uInt prev;              /* byte at distance one to match */ | ||||||
|     Bytef *scan, *strend;   /* scan goes up to strend for length of run */ |     Bytef *scan, *strend;   /* scan goes up to strend for length of run */ | ||||||
| @@ -2181,10 +2081,7 @@ local block_state deflate_rle(s, flush) | |||||||
|  * For Z_HUFFMAN_ONLY, do not look for matches.  Do not maintain a hash table. |  * For Z_HUFFMAN_ONLY, do not look for matches.  Do not maintain a hash table. | ||||||
|  * (It will be regenerated if this run of deflate switches away from Huffman.) |  * (It will be regenerated if this run of deflate switches away from Huffman.) | ||||||
|  */ |  */ | ||||||
| local block_state deflate_huff(s, flush) | local block_state deflate_huff(deflate_state *s, int flush) { | ||||||
|     deflate_state *s; |  | ||||||
|     int flush; |  | ||||||
| { |  | ||||||
|     int bflush;             /* set if current block must be flushed */ |     int bflush;             /* set if current block must be flushed */ | ||||||
|  |  | ||||||
|     for (;;) { |     for (;;) { | ||||||
|   | |||||||
| @@ -15,9 +15,6 @@ | |||||||
| #include "inflate.h" | #include "inflate.h" | ||||||
| #include "inffast.h" | #include "inffast.h" | ||||||
|  |  | ||||||
| /* function prototypes */ |  | ||||||
| local void fixedtables OF((struct inflate_state FAR *state)); |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|    strm provides memory allocation functions in zalloc and zfree, or |    strm provides memory allocation functions in zalloc and zfree, or | ||||||
|    Z_NULL to use the library memory allocation functions. |    Z_NULL to use the library memory allocation functions. | ||||||
| @@ -25,13 +22,9 @@ local void fixedtables OF((struct inflate_state FAR *state)); | |||||||
|    windowBits is in the range 8..15, and window is a user-supplied |    windowBits is in the range 8..15, and window is a user-supplied | ||||||
|    window and output buffer that is 2**windowBits bytes. |    window and output buffer that is 2**windowBits bytes. | ||||||
|  */ |  */ | ||||||
| int ZEXPORT inflateBackInit_(strm, windowBits, window, version, stream_size) | int ZEXPORT inflateBackInit_(z_streamp strm, int windowBits, | ||||||
| z_streamp strm; |                              unsigned char FAR *window, const char *version, | ||||||
| int windowBits; |                              int stream_size) { | ||||||
| unsigned char FAR *window; |  | ||||||
| const char *version; |  | ||||||
| int stream_size; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
|     if (version == Z_NULL || version[0] != ZLIB_VERSION[0] || |     if (version == Z_NULL || version[0] != ZLIB_VERSION[0] || | ||||||
| @@ -80,9 +73,7 @@ int stream_size; | |||||||
|    used for threaded applications, since the rewriting of the tables and virgin |    used for threaded applications, since the rewriting of the tables and virgin | ||||||
|    may not be thread-safe. |    may not be thread-safe. | ||||||
|  */ |  */ | ||||||
| local void fixedtables(state) | local void fixedtables(struct inflate_state FAR *state) { | ||||||
| struct inflate_state FAR *state; |  | ||||||
| { |  | ||||||
| #ifdef BUILDFIXED | #ifdef BUILDFIXED | ||||||
|     static int virgin = 1; |     static int virgin = 1; | ||||||
|     static code *lenfix, *distfix; |     static code *lenfix, *distfix; | ||||||
| @@ -248,13 +239,8 @@ struct inflate_state FAR *state; | |||||||
|    inflateBack() can also return Z_STREAM_ERROR if the input parameters |    inflateBack() can also return Z_STREAM_ERROR if the input parameters | ||||||
|    are not correct, i.e. strm is Z_NULL or the state was not initialized. |    are not correct, i.e. strm is Z_NULL or the state was not initialized. | ||||||
|  */ |  */ | ||||||
| int ZEXPORT inflateBack(strm, in, in_desc, out, out_desc) | int ZEXPORT inflateBack(z_streamp strm, in_func in, void FAR *in_desc, | ||||||
| z_streamp strm; |                         out_func out, void FAR *out_desc) { | ||||||
| in_func in; |  | ||||||
| void FAR *in_desc; |  | ||||||
| out_func out; |  | ||||||
| void FAR *out_desc; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|     z_const unsigned char FAR *next;    /* next input */ |     z_const unsigned char FAR *next;    /* next input */ | ||||||
|     unsigned char FAR *put;     /* next output */ |     unsigned char FAR *put;     /* next output */ | ||||||
| @@ -632,9 +618,7 @@ void FAR *out_desc; | |||||||
|     return ret; |     return ret; | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateBackEnd(strm) | int ZEXPORT inflateBackEnd(z_streamp strm) { | ||||||
| z_streamp strm; |  | ||||||
| { |  | ||||||
|     if (strm == Z_NULL || strm->state == Z_NULL || strm->zfree == (free_func)0) |     if (strm == Z_NULL || strm->state == Z_NULL || strm->zfree == (free_func)0) | ||||||
|         return Z_STREAM_ERROR; |         return Z_STREAM_ERROR; | ||||||
|     ZFREE(strm, strm->state); |     ZFREE(strm, strm->state); | ||||||
|   | |||||||
| @@ -47,10 +47,7 @@ | |||||||
|       requires strm->avail_out >= 258 for each loop to avoid checking for |       requires strm->avail_out >= 258 for each loop to avoid checking for | ||||||
|       output space. |       output space. | ||||||
|  */ |  */ | ||||||
| void ZLIB_INTERNAL inflate_fast(strm, start) | void ZLIB_INTERNAL inflate_fast(z_streamp strm, unsigned start) { | ||||||
| z_streamp strm; |  | ||||||
| unsigned start;         /* inflate()'s starting value for strm->avail_out */ |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|     z_const unsigned char FAR *in;      /* local strm->next_in */ |     z_const unsigned char FAR *in;      /* local strm->next_in */ | ||||||
|     z_const unsigned char FAR *last;    /* have enough input while in < last */ |     z_const unsigned char FAR *last;    /* have enough input while in < last */ | ||||||
|   | |||||||
| @@ -91,20 +91,7 @@ | |||||||
| #  endif | #  endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| /* function prototypes */ | local int inflateStateCheck(z_streamp strm) { | ||||||
| local int inflateStateCheck OF((z_streamp strm)); |  | ||||||
| local void fixedtables OF((struct inflate_state FAR *state)); |  | ||||||
| local int updatewindow OF((z_streamp strm, const unsigned char FAR *end, |  | ||||||
|                            unsigned copy)); |  | ||||||
| #ifdef BUILDFIXED |  | ||||||
|    void makefixed OF((void)); |  | ||||||
| #endif |  | ||||||
| local unsigned syncsearch OF((unsigned FAR *have, const unsigned char FAR *buf, |  | ||||||
|                               unsigned len)); |  | ||||||
|  |  | ||||||
| local int inflateStateCheck(strm) |  | ||||||
| z_streamp strm; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|     if (strm == Z_NULL || |     if (strm == Z_NULL || | ||||||
|         strm->zalloc == (alloc_func)0 || strm->zfree == (free_func)0) |         strm->zalloc == (alloc_func)0 || strm->zfree == (free_func)0) | ||||||
| @@ -116,9 +103,7 @@ z_streamp strm; | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateResetKeep(strm) | int ZEXPORT inflateResetKeep(z_streamp strm) { | ||||||
| z_streamp strm; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
|     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; |     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; | ||||||
| @@ -142,9 +127,7 @@ z_streamp strm; | |||||||
|     return Z_OK; |     return Z_OK; | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateReset(strm) | int ZEXPORT inflateReset(z_streamp strm) { | ||||||
| z_streamp strm; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
|     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; |     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; | ||||||
| @@ -155,10 +138,7 @@ z_streamp strm; | |||||||
|     return inflateResetKeep(strm); |     return inflateResetKeep(strm); | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateReset2(strm, windowBits) | int ZEXPORT inflateReset2(z_streamp strm, int windowBits) { | ||||||
| z_streamp strm; |  | ||||||
| int windowBits; |  | ||||||
| { |  | ||||||
|     int wrap; |     int wrap; | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
| @@ -195,12 +175,8 @@ int windowBits; | |||||||
|     return inflateReset(strm); |     return inflateReset(strm); | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateInit2_(strm, windowBits, version, stream_size) | int ZEXPORT inflateInit2_(z_streamp strm, int windowBits, | ||||||
| z_streamp strm; |                           const char *version, int stream_size) { | ||||||
| int windowBits; |  | ||||||
| const char *version; |  | ||||||
| int stream_size; |  | ||||||
| { |  | ||||||
|     int ret; |     int ret; | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
| @@ -239,22 +215,17 @@ int stream_size; | |||||||
|     return ret; |     return ret; | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateInit_(strm, version, stream_size) | int ZEXPORT inflateInit_(z_streamp strm, const char *version, | ||||||
| z_streamp strm; |                          int stream_size) { | ||||||
| const char *version; |  | ||||||
| int stream_size; |  | ||||||
| { |  | ||||||
|     return inflateInit2_(strm, DEF_WBITS, version, stream_size); |     return inflateInit2_(strm, DEF_WBITS, version, stream_size); | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflatePrime(strm, bits, value) | int ZEXPORT inflatePrime(z_streamp strm, int bits, int value) { | ||||||
| z_streamp strm; |  | ||||||
| int bits; |  | ||||||
| int value; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
|     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; |     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; | ||||||
|  |     if (bits == 0) | ||||||
|  |         return Z_OK; | ||||||
|     state = (struct inflate_state FAR *)strm->state; |     state = (struct inflate_state FAR *)strm->state; | ||||||
|     if (bits < 0) { |     if (bits < 0) { | ||||||
|         state->hold = 0; |         state->hold = 0; | ||||||
| @@ -278,9 +249,7 @@ int value; | |||||||
|    used for threaded applications, since the rewriting of the tables and virgin |    used for threaded applications, since the rewriting of the tables and virgin | ||||||
|    may not be thread-safe. |    may not be thread-safe. | ||||||
|  */ |  */ | ||||||
| local void fixedtables(state) | local void fixedtables(struct inflate_state FAR *state) { | ||||||
| struct inflate_state FAR *state; |  | ||||||
| { |  | ||||||
| #ifdef BUILDFIXED | #ifdef BUILDFIXED | ||||||
|     static int virgin = 1; |     static int virgin = 1; | ||||||
|     static code *lenfix, *distfix; |     static code *lenfix, *distfix; | ||||||
| @@ -342,7 +311,7 @@ struct inflate_state FAR *state; | |||||||
|  |  | ||||||
|     a.out > inffixed.h |     a.out > inffixed.h | ||||||
|  */ |  */ | ||||||
| void makefixed() | void makefixed(void) | ||||||
| { | { | ||||||
|     unsigned low, size; |     unsigned low, size; | ||||||
|     struct inflate_state state; |     struct inflate_state state; | ||||||
| @@ -396,11 +365,7 @@ void makefixed() | |||||||
|    output will fall in the output data, making match copies simpler and faster. |    output will fall in the output data, making match copies simpler and faster. | ||||||
|    The advantage may be dependent on the size of the processor's data caches. |    The advantage may be dependent on the size of the processor's data caches. | ||||||
|  */ |  */ | ||||||
| local int updatewindow(strm, end, copy) | local int updatewindow(z_streamp strm, const Bytef *end, unsigned copy) { | ||||||
| z_streamp strm; |  | ||||||
| const Bytef *end; |  | ||||||
| unsigned copy; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|     unsigned dist; |     unsigned dist; | ||||||
|  |  | ||||||
| @@ -622,10 +587,7 @@ unsigned copy; | |||||||
|    will return Z_BUF_ERROR if it has not reached the end of the stream. |    will return Z_BUF_ERROR if it has not reached the end of the stream. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| int ZEXPORT inflate(strm, flush) | int ZEXPORT inflate(z_streamp strm, int flush) { | ||||||
| z_streamp strm; |  | ||||||
| int flush; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|     z_const unsigned char FAR *next;    /* next input */ |     z_const unsigned char FAR *next;    /* next input */ | ||||||
|     unsigned char FAR *put;     /* next output */ |     unsigned char FAR *put;     /* next output */ | ||||||
| @@ -1301,9 +1263,7 @@ int flush; | |||||||
|     return ret; |     return ret; | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateEnd(strm) | int ZEXPORT inflateEnd(z_streamp strm) { | ||||||
| z_streamp strm; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|     if (inflateStateCheck(strm)) |     if (inflateStateCheck(strm)) | ||||||
|         return Z_STREAM_ERROR; |         return Z_STREAM_ERROR; | ||||||
| @@ -1315,11 +1275,8 @@ z_streamp strm; | |||||||
|     return Z_OK; |     return Z_OK; | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateGetDictionary(strm, dictionary, dictLength) | int ZEXPORT inflateGetDictionary(z_streamp strm, Bytef *dictionary, | ||||||
| z_streamp strm; |                                  uInt *dictLength) { | ||||||
| Bytef *dictionary; |  | ||||||
| uInt *dictLength; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
|     /* check state */ |     /* check state */ | ||||||
| @@ -1338,11 +1295,8 @@ uInt *dictLength; | |||||||
|     return Z_OK; |     return Z_OK; | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateSetDictionary(strm, dictionary, dictLength) | int ZEXPORT inflateSetDictionary(z_streamp strm, const Bytef *dictionary, | ||||||
| z_streamp strm; |                                  uInt dictLength) { | ||||||
| const Bytef *dictionary; |  | ||||||
| uInt dictLength; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|     unsigned long dictid; |     unsigned long dictid; | ||||||
|     int ret; |     int ret; | ||||||
| @@ -1373,10 +1327,7 @@ uInt dictLength; | |||||||
|     return Z_OK; |     return Z_OK; | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateGetHeader(strm, head) | int ZEXPORT inflateGetHeader(z_streamp strm, gz_headerp head) { | ||||||
| z_streamp strm; |  | ||||||
| gz_headerp head; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
|     /* check state */ |     /* check state */ | ||||||
| @@ -1401,11 +1352,8 @@ gz_headerp head; | |||||||
|    called again with more data and the *have state.  *have is initialized to |    called again with more data and the *have state.  *have is initialized to | ||||||
|    zero for the first call. |    zero for the first call. | ||||||
|  */ |  */ | ||||||
| local unsigned syncsearch(have, buf, len) | local unsigned syncsearch(unsigned FAR *have, const unsigned char FAR *buf, | ||||||
| unsigned FAR *have; |                           unsigned len) { | ||||||
| const unsigned char FAR *buf; |  | ||||||
| unsigned len; |  | ||||||
| { |  | ||||||
|     unsigned got; |     unsigned got; | ||||||
|     unsigned next; |     unsigned next; | ||||||
|  |  | ||||||
| @@ -1424,9 +1372,7 @@ unsigned len; | |||||||
|     return next; |     return next; | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateSync(strm) | int ZEXPORT inflateSync(z_streamp strm) { | ||||||
| z_streamp strm; |  | ||||||
| { |  | ||||||
|     unsigned len;               /* number of bytes to look at or looked at */ |     unsigned len;               /* number of bytes to look at or looked at */ | ||||||
|     int flags;                  /* temporary to save header status */ |     int flags;                  /* temporary to save header status */ | ||||||
|     unsigned long in, out;      /* temporary to save total_in and total_out */ |     unsigned long in, out;      /* temporary to save total_in and total_out */ | ||||||
| @@ -1482,9 +1428,7 @@ z_streamp strm; | |||||||
|    block. When decompressing, PPP checks that at the end of input packet, |    block. When decompressing, PPP checks that at the end of input packet, | ||||||
|    inflate is waiting for these length bytes. |    inflate is waiting for these length bytes. | ||||||
|  */ |  */ | ||||||
| int ZEXPORT inflateSyncPoint(strm) | int ZEXPORT inflateSyncPoint(z_streamp strm) { | ||||||
| z_streamp strm; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
|     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; |     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; | ||||||
| @@ -1492,10 +1436,7 @@ z_streamp strm; | |||||||
|     return state->mode == STORED && state->bits == 0; |     return state->mode == STORED && state->bits == 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateCopy(dest, source) | int ZEXPORT inflateCopy(z_streamp dest, z_streamp source) { | ||||||
| z_streamp dest; |  | ||||||
| z_streamp source; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|     struct inflate_state FAR *copy; |     struct inflate_state FAR *copy; | ||||||
|     unsigned char FAR *window; |     unsigned char FAR *window; | ||||||
| @@ -1539,10 +1480,7 @@ z_streamp source; | |||||||
|     return Z_OK; |     return Z_OK; | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateUndermine(strm, subvert) | int ZEXPORT inflateUndermine(z_streamp strm, int subvert) { | ||||||
| z_streamp strm; |  | ||||||
| int subvert; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
|     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; |     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; | ||||||
| @@ -1557,10 +1495,7 @@ int subvert; | |||||||
| #endif | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZEXPORT inflateValidate(strm, check) | int ZEXPORT inflateValidate(z_streamp strm, int check) { | ||||||
| z_streamp strm; |  | ||||||
| int check; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
|     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; |     if (inflateStateCheck(strm)) return Z_STREAM_ERROR; | ||||||
| @@ -1572,9 +1507,7 @@ int check; | |||||||
|     return Z_OK; |     return Z_OK; | ||||||
| } | } | ||||||
|  |  | ||||||
| long ZEXPORT inflateMark(strm) | long ZEXPORT inflateMark(z_streamp strm) { | ||||||
| z_streamp strm; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|  |  | ||||||
|     if (inflateStateCheck(strm)) |     if (inflateStateCheck(strm)) | ||||||
| @@ -1585,9 +1518,7 @@ z_streamp strm; | |||||||
|             (state->mode == MATCH ? state->was - state->length : 0)); |             (state->mode == MATCH ? state->was - state->length : 0)); | ||||||
| } | } | ||||||
|  |  | ||||||
| unsigned long ZEXPORT inflateCodesUsed(strm) | unsigned long ZEXPORT inflateCodesUsed(z_streamp strm) { | ||||||
| z_streamp strm; |  | ||||||
| { |  | ||||||
|     struct inflate_state FAR *state; |     struct inflate_state FAR *state; | ||||||
|     if (inflateStateCheck(strm)) return (unsigned long)-1; |     if (inflateStateCheck(strm)) return (unsigned long)-1; | ||||||
|     state = (struct inflate_state FAR *)strm->state; |     state = (struct inflate_state FAR *)strm->state; | ||||||
|   | |||||||
| @@ -1,5 +1,5 @@ | |||||||
| /* inftrees.c -- generate Huffman trees for efficient decoding | /* inftrees.c -- generate Huffman trees for efficient decoding | ||||||
|  * Copyright (C) 1995-2022 Mark Adler |  * Copyright (C) 1995-2023 Mark Adler | ||||||
|  * For conditions of distribution and use, see copyright notice in zlib.h |  * For conditions of distribution and use, see copyright notice in zlib.h | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| @@ -9,7 +9,7 @@ | |||||||
| #define MAXBITS 15 | #define MAXBITS 15 | ||||||
|  |  | ||||||
| const char inflate_copyright[] = | const char inflate_copyright[] = | ||||||
|    " inflate 1.2.13 Copyright 1995-2022 Mark Adler "; |    " inflate 1.3 Copyright 1995-2023 Mark Adler "; | ||||||
| /* | /* | ||||||
|   If you use the zlib library in a product, an acknowledgment is welcome |   If you use the zlib library in a product, an acknowledgment is welcome | ||||||
|   in the documentation of your product. If for some reason you cannot |   in the documentation of your product. If for some reason you cannot | ||||||
| @@ -29,14 +29,9 @@ const char inflate_copyright[] = | |||||||
|    table index bits.  It will differ if the request is greater than the |    table index bits.  It will differ if the request is greater than the | ||||||
|    longest code or if it is less than the shortest code. |    longest code or if it is less than the shortest code. | ||||||
|  */ |  */ | ||||||
| int ZLIB_INTERNAL inflate_table(type, lens, codes, table, bits, work) | int ZLIB_INTERNAL inflate_table(codetype type, unsigned short FAR *lens, | ||||||
| codetype type; |                                 unsigned codes, code FAR * FAR *table, | ||||||
| unsigned short FAR *lens; |                                 unsigned FAR *bits, unsigned short FAR *work) { | ||||||
| unsigned codes; |  | ||||||
| code FAR * FAR *table; |  | ||||||
| unsigned FAR *bits; |  | ||||||
| unsigned short FAR *work; |  | ||||||
| { |  | ||||||
|     unsigned len;               /* a code's length in bits */ |     unsigned len;               /* a code's length in bits */ | ||||||
|     unsigned sym;               /* index of code symbols */ |     unsigned sym;               /* index of code symbols */ | ||||||
|     unsigned min, max;          /* minimum and maximum code lengths */ |     unsigned min, max;          /* minimum and maximum code lengths */ | ||||||
| @@ -62,7 +57,7 @@ unsigned short FAR *work; | |||||||
|         35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0}; |         35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0}; | ||||||
|     static const unsigned short lext[31] = { /* Length codes 257..285 extra */ |     static const unsigned short lext[31] = { /* Length codes 257..285 extra */ | ||||||
|         16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18, |         16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18, | ||||||
|         19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 194, 65}; |         19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 198, 203}; | ||||||
|     static const unsigned short dbase[32] = { /* Distance codes 0..29 base */ |     static const unsigned short dbase[32] = { /* Distance codes 0..29 base */ | ||||||
|         1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, |         1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193, | ||||||
|         257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, |         257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, | ||||||
|   | |||||||
| @@ -122,39 +122,116 @@ struct static_tree_desc_s { | |||||||
|     int     max_length;          /* max bit length for the codes */ |     int     max_length;          /* max bit length for the codes */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
| local const static_tree_desc  static_l_desc = | #ifdef NO_INIT_GLOBAL_POINTERS | ||||||
|  | #  define TCONST | ||||||
|  | #else | ||||||
|  | #  define TCONST const | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | local TCONST static_tree_desc static_l_desc = | ||||||
| {static_ltree, extra_lbits, LITERALS+1, L_CODES, MAX_BITS}; | {static_ltree, extra_lbits, LITERALS+1, L_CODES, MAX_BITS}; | ||||||
|  |  | ||||||
| local const static_tree_desc  static_d_desc = | local TCONST static_tree_desc static_d_desc = | ||||||
| {static_dtree, extra_dbits, 0,          D_CODES, MAX_BITS}; | {static_dtree, extra_dbits, 0,          D_CODES, MAX_BITS}; | ||||||
|  |  | ||||||
| local const static_tree_desc  static_bl_desc = | local TCONST static_tree_desc static_bl_desc = | ||||||
| {(const ct_data *)0, extra_blbits, 0,   BL_CODES, MAX_BL_BITS}; | {(const ct_data *)0, extra_blbits, 0,   BL_CODES, MAX_BL_BITS}; | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Local (static) routines in this file. |  * Output a short LSB first on the stream. | ||||||
|  |  * IN assertion: there is enough room in pendingBuf. | ||||||
|  */ |  */ | ||||||
|  | #define put_short(s, w) { \ | ||||||
|  |     put_byte(s, (uch)((w) & 0xff)); \ | ||||||
|  |     put_byte(s, (uch)((ush)(w) >> 8)); \ | ||||||
|  | } | ||||||
|  |  | ||||||
| local void tr_static_init OF((void)); | /* =========================================================================== | ||||||
| local void init_block     OF((deflate_state *s)); |  * Reverse the first len bits of a code, using straightforward code (a faster | ||||||
| local void pqdownheap     OF((deflate_state *s, ct_data *tree, int k)); |  * method would use a table) | ||||||
| local void gen_bitlen     OF((deflate_state *s, tree_desc *desc)); |  * IN assertion: 1 <= len <= 15 | ||||||
| local void gen_codes      OF((ct_data *tree, int max_code, ushf *bl_count)); |  */ | ||||||
| local void build_tree     OF((deflate_state *s, tree_desc *desc)); | local unsigned bi_reverse(unsigned code, int len) { | ||||||
| local void scan_tree      OF((deflate_state *s, ct_data *tree, int max_code)); |     register unsigned res = 0; | ||||||
| local void send_tree      OF((deflate_state *s, ct_data *tree, int max_code)); |     do { | ||||||
| local int  build_bl_tree  OF((deflate_state *s)); |         res |= code & 1; | ||||||
| local void send_all_trees OF((deflate_state *s, int lcodes, int dcodes, |         code >>= 1, res <<= 1; | ||||||
|                               int blcodes)); |     } while (--len > 0); | ||||||
| local void compress_block OF((deflate_state *s, const ct_data *ltree, |     return res >> 1; | ||||||
|                               const ct_data *dtree)); | } | ||||||
| local int  detect_data_type OF((deflate_state *s)); |  | ||||||
| local unsigned bi_reverse OF((unsigned code, int len)); | /* =========================================================================== | ||||||
| local void bi_windup      OF((deflate_state *s)); |  * Flush the bit buffer, keeping at most 7 bits in it. | ||||||
| local void bi_flush       OF((deflate_state *s)); |  */ | ||||||
|  | local void bi_flush(deflate_state *s) { | ||||||
|  |     if (s->bi_valid == 16) { | ||||||
|  |         put_short(s, s->bi_buf); | ||||||
|  |         s->bi_buf = 0; | ||||||
|  |         s->bi_valid = 0; | ||||||
|  |     } else if (s->bi_valid >= 8) { | ||||||
|  |         put_byte(s, (Byte)s->bi_buf); | ||||||
|  |         s->bi_buf >>= 8; | ||||||
|  |         s->bi_valid -= 8; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Flush the bit buffer and align the output on a byte boundary | ||||||
|  |  */ | ||||||
|  | local void bi_windup(deflate_state *s) { | ||||||
|  |     if (s->bi_valid > 8) { | ||||||
|  |         put_short(s, s->bi_buf); | ||||||
|  |     } else if (s->bi_valid > 0) { | ||||||
|  |         put_byte(s, (Byte)s->bi_buf); | ||||||
|  |     } | ||||||
|  |     s->bi_buf = 0; | ||||||
|  |     s->bi_valid = 0; | ||||||
|  | #ifdef ZLIB_DEBUG | ||||||
|  |     s->bits_sent = (s->bits_sent + 7) & ~7; | ||||||
|  | #endif | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Generate the codes for a given tree and bit counts (which need not be | ||||||
|  |  * optimal). | ||||||
|  |  * IN assertion: the array bl_count contains the bit length statistics for | ||||||
|  |  * the given tree and the field len is set for all tree elements. | ||||||
|  |  * OUT assertion: the field code is set for all tree elements of non | ||||||
|  |  *     zero code length. | ||||||
|  |  */ | ||||||
|  | local void gen_codes(ct_data *tree, int max_code, ushf *bl_count) { | ||||||
|  |     ush next_code[MAX_BITS+1]; /* next code value for each bit length */ | ||||||
|  |     unsigned code = 0;         /* running code value */ | ||||||
|  |     int bits;                  /* bit index */ | ||||||
|  |     int n;                     /* code index */ | ||||||
|  |  | ||||||
|  |     /* The distribution counts are first used to generate the code values | ||||||
|  |      * without bit reversal. | ||||||
|  |      */ | ||||||
|  |     for (bits = 1; bits <= MAX_BITS; bits++) { | ||||||
|  |         code = (code + bl_count[bits - 1]) << 1; | ||||||
|  |         next_code[bits] = (ush)code; | ||||||
|  |     } | ||||||
|  |     /* Check that the bit counts in bl_count are consistent. The last code | ||||||
|  |      * must be all ones. | ||||||
|  |      */ | ||||||
|  |     Assert (code + bl_count[MAX_BITS] - 1 == (1 << MAX_BITS) - 1, | ||||||
|  |             "inconsistent bit counts"); | ||||||
|  |     Tracev((stderr,"\ngen_codes: max_code %d ", max_code)); | ||||||
|  |  | ||||||
|  |     for (n = 0;  n <= max_code; n++) { | ||||||
|  |         int len = tree[n].Len; | ||||||
|  |         if (len == 0) continue; | ||||||
|  |         /* Now reverse the bits */ | ||||||
|  |         tree[n].Code = (ush)bi_reverse(next_code[len]++, len); | ||||||
|  |  | ||||||
|  |         Tracecv(tree != static_ltree, (stderr,"\nn %3d %c l %2d c %4x (%x) ", | ||||||
|  |             n, (isgraph(n) ? n : ' '), len, tree[n].Code, next_code[len] - 1)); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  |  | ||||||
| #ifdef GEN_TREES_H | #ifdef GEN_TREES_H | ||||||
| local void gen_trees_header OF((void)); | local void gen_trees_header(void); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifndef ZLIB_DEBUG | #ifndef ZLIB_DEBUG | ||||||
| @@ -167,27 +244,12 @@ local void gen_trees_header OF((void)); | |||||||
|        send_bits(s, tree[c].Code, tree[c].Len); } |        send_bits(s, tree[c].Code, tree[c].Len); } | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| /* =========================================================================== |  | ||||||
|  * Output a short LSB first on the stream. |  | ||||||
|  * IN assertion: there is enough room in pendingBuf. |  | ||||||
|  */ |  | ||||||
| #define put_short(s, w) { \ |  | ||||||
|     put_byte(s, (uch)((w) & 0xff)); \ |  | ||||||
|     put_byte(s, (uch)((ush)(w) >> 8)); \ |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Send a value on a given number of bits. |  * Send a value on a given number of bits. | ||||||
|  * IN assertion: length <= 16 and value fits in length bits. |  * IN assertion: length <= 16 and value fits in length bits. | ||||||
|  */ |  */ | ||||||
| #ifdef ZLIB_DEBUG | #ifdef ZLIB_DEBUG | ||||||
| local void send_bits      OF((deflate_state *s, int value, int length)); | local void send_bits(deflate_state *s, int value, int length) { | ||||||
|  |  | ||||||
| local void send_bits(s, value, length) |  | ||||||
|     deflate_state *s; |  | ||||||
|     int value;  /* value to send */ |  | ||||||
|     int length; /* number of bits */ |  | ||||||
| { |  | ||||||
|     Tracevv((stderr," l %2d v %4x ", length, value)); |     Tracevv((stderr," l %2d v %4x ", length, value)); | ||||||
|     Assert(length > 0 && length <= 15, "invalid length"); |     Assert(length > 0 && length <= 15, "invalid length"); | ||||||
|     s->bits_sent += (ulg)length; |     s->bits_sent += (ulg)length; | ||||||
| @@ -229,8 +291,7 @@ local void send_bits(s, value, length) | |||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Initialize the various 'constant' tables. |  * Initialize the various 'constant' tables. | ||||||
|  */ |  */ | ||||||
| local void tr_static_init() | local void tr_static_init(void) { | ||||||
| { |  | ||||||
| #if defined(GEN_TREES_H) || !defined(STDC) | #if defined(GEN_TREES_H) || !defined(STDC) | ||||||
|     static int static_init_done = 0; |     static int static_init_done = 0; | ||||||
|     int n;        /* iterates over tree elements */ |     int n;        /* iterates over tree elements */ | ||||||
| @@ -323,8 +384,7 @@ local void tr_static_init() | |||||||
|       ((i) == (last)? "\n};\n\n" :    \ |       ((i) == (last)? "\n};\n\n" :    \ | ||||||
|        ((i) % (width) == (width) - 1 ? ",\n" : ", ")) |        ((i) % (width) == (width) - 1 ? ",\n" : ", ")) | ||||||
|  |  | ||||||
| void gen_trees_header() | void gen_trees_header(void) { | ||||||
| { |  | ||||||
|     FILE *header = fopen("trees.h", "w"); |     FILE *header = fopen("trees.h", "w"); | ||||||
|     int i; |     int i; | ||||||
|  |  | ||||||
| @@ -373,12 +433,26 @@ void gen_trees_header() | |||||||
| } | } | ||||||
| #endif /* GEN_TREES_H */ | #endif /* GEN_TREES_H */ | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Initialize a new block. | ||||||
|  |  */ | ||||||
|  | local void init_block(deflate_state *s) { | ||||||
|  |     int n; /* iterates over tree elements */ | ||||||
|  |  | ||||||
|  |     /* Initialize the trees. */ | ||||||
|  |     for (n = 0; n < L_CODES;  n++) s->dyn_ltree[n].Freq = 0; | ||||||
|  |     for (n = 0; n < D_CODES;  n++) s->dyn_dtree[n].Freq = 0; | ||||||
|  |     for (n = 0; n < BL_CODES; n++) s->bl_tree[n].Freq = 0; | ||||||
|  |  | ||||||
|  |     s->dyn_ltree[END_BLOCK].Freq = 1; | ||||||
|  |     s->opt_len = s->static_len = 0L; | ||||||
|  |     s->sym_next = s->matches = 0; | ||||||
|  | } | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Initialize the tree data structures for a new zlib stream. |  * Initialize the tree data structures for a new zlib stream. | ||||||
|  */ |  */ | ||||||
| void ZLIB_INTERNAL _tr_init(s) | void ZLIB_INTERNAL _tr_init(deflate_state *s) { | ||||||
|     deflate_state *s; |  | ||||||
| { |  | ||||||
|     tr_static_init(); |     tr_static_init(); | ||||||
|  |  | ||||||
|     s->l_desc.dyn_tree = s->dyn_ltree; |     s->l_desc.dyn_tree = s->dyn_ltree; | ||||||
| @@ -401,24 +475,6 @@ void ZLIB_INTERNAL _tr_init(s) | |||||||
|     init_block(s); |     init_block(s); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* =========================================================================== |  | ||||||
|  * Initialize a new block. |  | ||||||
|  */ |  | ||||||
| local void init_block(s) |  | ||||||
|     deflate_state *s; |  | ||||||
| { |  | ||||||
|     int n; /* iterates over tree elements */ |  | ||||||
|  |  | ||||||
|     /* Initialize the trees. */ |  | ||||||
|     for (n = 0; n < L_CODES;  n++) s->dyn_ltree[n].Freq = 0; |  | ||||||
|     for (n = 0; n < D_CODES;  n++) s->dyn_dtree[n].Freq = 0; |  | ||||||
|     for (n = 0; n < BL_CODES; n++) s->bl_tree[n].Freq = 0; |  | ||||||
|  |  | ||||||
|     s->dyn_ltree[END_BLOCK].Freq = 1; |  | ||||||
|     s->opt_len = s->static_len = 0L; |  | ||||||
|     s->sym_next = s->matches = 0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #define SMALLEST 1 | #define SMALLEST 1 | ||||||
| /* Index within the heap array of least frequent node in the Huffman tree */ | /* Index within the heap array of least frequent node in the Huffman tree */ | ||||||
|  |  | ||||||
| @@ -448,11 +504,7 @@ local void init_block(s) | |||||||
|  * when the heap property is re-established (each father smaller than its |  * when the heap property is re-established (each father smaller than its | ||||||
|  * two sons). |  * two sons). | ||||||
|  */ |  */ | ||||||
| local void pqdownheap(s, tree, k) | local void pqdownheap(deflate_state *s, ct_data *tree, int k) { | ||||||
|     deflate_state *s; |  | ||||||
|     ct_data *tree;  /* the tree to restore */ |  | ||||||
|     int k;               /* node to move down */ |  | ||||||
| { |  | ||||||
|     int v = s->heap[k]; |     int v = s->heap[k]; | ||||||
|     int j = k << 1;  /* left son of k */ |     int j = k << 1;  /* left son of k */ | ||||||
|     while (j <= s->heap_len) { |     while (j <= s->heap_len) { | ||||||
| @@ -483,10 +535,7 @@ local void pqdownheap(s, tree, k) | |||||||
|  *     The length opt_len is updated; static_len is also updated if stree is |  *     The length opt_len is updated; static_len is also updated if stree is | ||||||
|  *     not null. |  *     not null. | ||||||
|  */ |  */ | ||||||
| local void gen_bitlen(s, desc) | local void gen_bitlen(deflate_state *s, tree_desc *desc) { | ||||||
|     deflate_state *s; |  | ||||||
|     tree_desc *desc;    /* the tree descriptor */ |  | ||||||
| { |  | ||||||
|     ct_data *tree        = desc->dyn_tree; |     ct_data *tree        = desc->dyn_tree; | ||||||
|     int max_code         = desc->max_code; |     int max_code         = desc->max_code; | ||||||
|     const ct_data *stree = desc->stat_desc->static_tree; |     const ct_data *stree = desc->stat_desc->static_tree; | ||||||
| @@ -561,48 +610,9 @@ local void gen_bitlen(s, desc) | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| /* =========================================================================== | #ifdef DUMP_BL_TREE | ||||||
|  * Generate the codes for a given tree and bit counts (which need not be | #  include <stdio.h> | ||||||
|  * optimal). | #endif | ||||||
|  * IN assertion: the array bl_count contains the bit length statistics for |  | ||||||
|  * the given tree and the field len is set for all tree elements. |  | ||||||
|  * OUT assertion: the field code is set for all tree elements of non |  | ||||||
|  *     zero code length. |  | ||||||
|  */ |  | ||||||
| local void gen_codes(tree, max_code, bl_count) |  | ||||||
|     ct_data *tree;             /* the tree to decorate */ |  | ||||||
|     int max_code;              /* largest code with non zero frequency */ |  | ||||||
|     ushf *bl_count;            /* number of codes at each bit length */ |  | ||||||
| { |  | ||||||
|     ush next_code[MAX_BITS+1]; /* next code value for each bit length */ |  | ||||||
|     unsigned code = 0;         /* running code value */ |  | ||||||
|     int bits;                  /* bit index */ |  | ||||||
|     int n;                     /* code index */ |  | ||||||
|  |  | ||||||
|     /* The distribution counts are first used to generate the code values |  | ||||||
|      * without bit reversal. |  | ||||||
|      */ |  | ||||||
|     for (bits = 1; bits <= MAX_BITS; bits++) { |  | ||||||
|         code = (code + bl_count[bits - 1]) << 1; |  | ||||||
|         next_code[bits] = (ush)code; |  | ||||||
|     } |  | ||||||
|     /* Check that the bit counts in bl_count are consistent. The last code |  | ||||||
|      * must be all ones. |  | ||||||
|      */ |  | ||||||
|     Assert (code + bl_count[MAX_BITS] - 1 == (1 << MAX_BITS) - 1, |  | ||||||
|             "inconsistent bit counts"); |  | ||||||
|     Tracev((stderr,"\ngen_codes: max_code %d ", max_code)); |  | ||||||
|  |  | ||||||
|     for (n = 0;  n <= max_code; n++) { |  | ||||||
|         int len = tree[n].Len; |  | ||||||
|         if (len == 0) continue; |  | ||||||
|         /* Now reverse the bits */ |  | ||||||
|         tree[n].Code = (ush)bi_reverse(next_code[len]++, len); |  | ||||||
|  |  | ||||||
|         Tracecv(tree != static_ltree, (stderr,"\nn %3d %c l %2d c %4x (%x) ", |  | ||||||
|             n, (isgraph(n) ? n : ' '), len, tree[n].Code, next_code[len] - 1)); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Construct one Huffman tree and assigns the code bit strings and lengths. |  * Construct one Huffman tree and assigns the code bit strings and lengths. | ||||||
| @@ -612,10 +622,7 @@ local void gen_codes(tree, max_code, bl_count) | |||||||
|  *     and corresponding code. The length opt_len is updated; static_len is |  *     and corresponding code. The length opt_len is updated; static_len is | ||||||
|  *     also updated if stree is not null. The field max_code is set. |  *     also updated if stree is not null. The field max_code is set. | ||||||
|  */ |  */ | ||||||
| local void build_tree(s, desc) | local void build_tree(deflate_state *s, tree_desc *desc) { | ||||||
|     deflate_state *s; |  | ||||||
|     tree_desc *desc; /* the tree descriptor */ |  | ||||||
| { |  | ||||||
|     ct_data *tree         = desc->dyn_tree; |     ct_data *tree         = desc->dyn_tree; | ||||||
|     const ct_data *stree  = desc->stat_desc->static_tree; |     const ct_data *stree  = desc->stat_desc->static_tree; | ||||||
|     int elems             = desc->stat_desc->elems; |     int elems             = desc->stat_desc->elems; | ||||||
| @@ -700,11 +707,7 @@ local void build_tree(s, desc) | |||||||
|  * Scan a literal or distance tree to determine the frequencies of the codes |  * Scan a literal or distance tree to determine the frequencies of the codes | ||||||
|  * in the bit length tree. |  * in the bit length tree. | ||||||
|  */ |  */ | ||||||
| local void scan_tree(s, tree, max_code) | local void scan_tree(deflate_state *s, ct_data *tree, int max_code) { | ||||||
|     deflate_state *s; |  | ||||||
|     ct_data *tree;   /* the tree to be scanned */ |  | ||||||
|     int max_code;    /* and its largest code of non zero frequency */ |  | ||||||
| { |  | ||||||
|     int n;                     /* iterates over all tree elements */ |     int n;                     /* iterates over all tree elements */ | ||||||
|     int prevlen = -1;          /* last emitted length */ |     int prevlen = -1;          /* last emitted length */ | ||||||
|     int curlen;                /* length of current code */ |     int curlen;                /* length of current code */ | ||||||
| @@ -745,11 +748,7 @@ local void scan_tree(s, tree, max_code) | |||||||
|  * Send a literal or distance tree in compressed form, using the codes in |  * Send a literal or distance tree in compressed form, using the codes in | ||||||
|  * bl_tree. |  * bl_tree. | ||||||
|  */ |  */ | ||||||
| local void send_tree(s, tree, max_code) | local void send_tree(deflate_state *s, ct_data *tree, int max_code) { | ||||||
|     deflate_state *s; |  | ||||||
|     ct_data *tree; /* the tree to be scanned */ |  | ||||||
|     int max_code;       /* and its largest code of non zero frequency */ |  | ||||||
| { |  | ||||||
|     int n;                     /* iterates over all tree elements */ |     int n;                     /* iterates over all tree elements */ | ||||||
|     int prevlen = -1;          /* last emitted length */ |     int prevlen = -1;          /* last emitted length */ | ||||||
|     int curlen;                /* length of current code */ |     int curlen;                /* length of current code */ | ||||||
| @@ -796,9 +795,7 @@ local void send_tree(s, tree, max_code) | |||||||
|  * Construct the Huffman tree for the bit lengths and return the index in |  * Construct the Huffman tree for the bit lengths and return the index in | ||||||
|  * bl_order of the last bit length code to send. |  * bl_order of the last bit length code to send. | ||||||
|  */ |  */ | ||||||
| local int build_bl_tree(s) | local int build_bl_tree(deflate_state *s) { | ||||||
|     deflate_state *s; |  | ||||||
| { |  | ||||||
|     int max_blindex;  /* index of last bit length code of non zero freq */ |     int max_blindex;  /* index of last bit length code of non zero freq */ | ||||||
|  |  | ||||||
|     /* Determine the bit length frequencies for literal and distance trees */ |     /* Determine the bit length frequencies for literal and distance trees */ | ||||||
| @@ -831,10 +828,8 @@ local int build_bl_tree(s) | |||||||
|  * lengths of the bit length codes, the literal tree and the distance tree. |  * lengths of the bit length codes, the literal tree and the distance tree. | ||||||
|  * IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4. |  * IN assertion: lcodes >= 257, dcodes >= 1, blcodes >= 4. | ||||||
|  */ |  */ | ||||||
| local void send_all_trees(s, lcodes, dcodes, blcodes) | local void send_all_trees(deflate_state *s, int lcodes, int dcodes, | ||||||
|     deflate_state *s; |                           int blcodes) { | ||||||
|     int lcodes, dcodes, blcodes; /* number of codes for each tree */ |  | ||||||
| { |  | ||||||
|     int rank;                    /* index in bl_order */ |     int rank;                    /* index in bl_order */ | ||||||
|  |  | ||||||
|     Assert (lcodes >= 257 && dcodes >= 1 && blcodes >= 4, "not enough codes"); |     Assert (lcodes >= 257 && dcodes >= 1 && blcodes >= 4, "not enough codes"); | ||||||
| @@ -860,12 +855,8 @@ local void send_all_trees(s, lcodes, dcodes, blcodes) | |||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Send a stored block |  * Send a stored block | ||||||
|  */ |  */ | ||||||
| void ZLIB_INTERNAL _tr_stored_block(s, buf, stored_len, last) | void ZLIB_INTERNAL _tr_stored_block(deflate_state *s, charf *buf, | ||||||
|     deflate_state *s; |                                     ulg stored_len, int last) { | ||||||
|     charf *buf;       /* input block */ |  | ||||||
|     ulg stored_len;   /* length of input block */ |  | ||||||
|     int last;         /* one if this is the last block for a file */ |  | ||||||
| { |  | ||||||
|     send_bits(s, (STORED_BLOCK<<1) + last, 3);  /* send block type */ |     send_bits(s, (STORED_BLOCK<<1) + last, 3);  /* send block type */ | ||||||
|     bi_windup(s);        /* align on byte boundary */ |     bi_windup(s);        /* align on byte boundary */ | ||||||
|     put_short(s, (ush)stored_len); |     put_short(s, (ush)stored_len); | ||||||
| @@ -884,9 +875,7 @@ void ZLIB_INTERNAL _tr_stored_block(s, buf, stored_len, last) | |||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Flush the bits in the bit buffer to pending output (leaves at most 7 bits) |  * Flush the bits in the bit buffer to pending output (leaves at most 7 bits) | ||||||
|  */ |  */ | ||||||
| void ZLIB_INTERNAL _tr_flush_bits(s) | void ZLIB_INTERNAL _tr_flush_bits(deflate_state *s) { | ||||||
|     deflate_state *s; |  | ||||||
| { |  | ||||||
|     bi_flush(s); |     bi_flush(s); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -894,9 +883,7 @@ void ZLIB_INTERNAL _tr_flush_bits(s) | |||||||
|  * Send one empty static block to give enough lookahead for inflate. |  * Send one empty static block to give enough lookahead for inflate. | ||||||
|  * This takes 10 bits, of which 7 may remain in the bit buffer. |  * This takes 10 bits, of which 7 may remain in the bit buffer. | ||||||
|  */ |  */ | ||||||
| void ZLIB_INTERNAL _tr_align(s) | void ZLIB_INTERNAL _tr_align(deflate_state *s) { | ||||||
|     deflate_state *s; |  | ||||||
| { |  | ||||||
|     send_bits(s, STATIC_TREES<<1, 3); |     send_bits(s, STATIC_TREES<<1, 3); | ||||||
|     send_code(s, END_BLOCK, static_ltree); |     send_code(s, END_BLOCK, static_ltree); | ||||||
| #ifdef ZLIB_DEBUG | #ifdef ZLIB_DEBUG | ||||||
| @@ -905,16 +892,99 @@ void ZLIB_INTERNAL _tr_align(s) | |||||||
|     bi_flush(s); |     bi_flush(s); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Send the block data compressed using the given Huffman trees | ||||||
|  |  */ | ||||||
|  | local void compress_block(deflate_state *s, const ct_data *ltree, | ||||||
|  |                           const ct_data *dtree) { | ||||||
|  |     unsigned dist;      /* distance of matched string */ | ||||||
|  |     int lc;             /* match length or unmatched char (if dist == 0) */ | ||||||
|  |     unsigned sx = 0;    /* running index in sym_buf */ | ||||||
|  |     unsigned code;      /* the code to send */ | ||||||
|  |     int extra;          /* number of extra bits to send */ | ||||||
|  |  | ||||||
|  |     if (s->sym_next != 0) do { | ||||||
|  |         dist = s->sym_buf[sx++] & 0xff; | ||||||
|  |         dist += (unsigned)(s->sym_buf[sx++] & 0xff) << 8; | ||||||
|  |         lc = s->sym_buf[sx++]; | ||||||
|  |         if (dist == 0) { | ||||||
|  |             send_code(s, lc, ltree); /* send a literal byte */ | ||||||
|  |             Tracecv(isgraph(lc), (stderr," '%c' ", lc)); | ||||||
|  |         } else { | ||||||
|  |             /* Here, lc is the match length - MIN_MATCH */ | ||||||
|  |             code = _length_code[lc]; | ||||||
|  |             send_code(s, code + LITERALS + 1, ltree);   /* send length code */ | ||||||
|  |             extra = extra_lbits[code]; | ||||||
|  |             if (extra != 0) { | ||||||
|  |                 lc -= base_length[code]; | ||||||
|  |                 send_bits(s, lc, extra);       /* send the extra length bits */ | ||||||
|  |             } | ||||||
|  |             dist--; /* dist is now the match distance - 1 */ | ||||||
|  |             code = d_code(dist); | ||||||
|  |             Assert (code < D_CODES, "bad d_code"); | ||||||
|  |  | ||||||
|  |             send_code(s, code, dtree);       /* send the distance code */ | ||||||
|  |             extra = extra_dbits[code]; | ||||||
|  |             if (extra != 0) { | ||||||
|  |                 dist -= (unsigned)base_dist[code]; | ||||||
|  |                 send_bits(s, dist, extra);   /* send the extra distance bits */ | ||||||
|  |             } | ||||||
|  |         } /* literal or match pair ? */ | ||||||
|  |  | ||||||
|  |         /* Check that the overlay between pending_buf and sym_buf is ok: */ | ||||||
|  |         Assert(s->pending < s->lit_bufsize + sx, "pendingBuf overflow"); | ||||||
|  |  | ||||||
|  |     } while (sx < s->sym_next); | ||||||
|  |  | ||||||
|  |     send_code(s, END_BLOCK, ltree); | ||||||
|  | } | ||||||
|  |  | ||||||
|  | /* =========================================================================== | ||||||
|  |  * Check if the data type is TEXT or BINARY, using the following algorithm: | ||||||
|  |  * - TEXT if the two conditions below are satisfied: | ||||||
|  |  *    a) There are no non-portable control characters belonging to the | ||||||
|  |  *       "block list" (0..6, 14..25, 28..31). | ||||||
|  |  *    b) There is at least one printable character belonging to the | ||||||
|  |  *       "allow list" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255). | ||||||
|  |  * - BINARY otherwise. | ||||||
|  |  * - The following partially-portable control characters form a | ||||||
|  |  *   "gray list" that is ignored in this detection algorithm: | ||||||
|  |  *   (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}). | ||||||
|  |  * IN assertion: the fields Freq of dyn_ltree are set. | ||||||
|  |  */ | ||||||
|  | local int detect_data_type(deflate_state *s) { | ||||||
|  |     /* block_mask is the bit mask of block-listed bytes | ||||||
|  |      * set bits 0..6, 14..25, and 28..31 | ||||||
|  |      * 0xf3ffc07f = binary 11110011111111111100000001111111 | ||||||
|  |      */ | ||||||
|  |     unsigned long block_mask = 0xf3ffc07fUL; | ||||||
|  |     int n; | ||||||
|  |  | ||||||
|  |     /* Check for non-textual ("block-listed") bytes. */ | ||||||
|  |     for (n = 0; n <= 31; n++, block_mask >>= 1) | ||||||
|  |         if ((block_mask & 1) && (s->dyn_ltree[n].Freq != 0)) | ||||||
|  |             return Z_BINARY; | ||||||
|  |  | ||||||
|  |     /* Check for textual ("allow-listed") bytes. */ | ||||||
|  |     if (s->dyn_ltree[9].Freq != 0 || s->dyn_ltree[10].Freq != 0 | ||||||
|  |             || s->dyn_ltree[13].Freq != 0) | ||||||
|  |         return Z_TEXT; | ||||||
|  |     for (n = 32; n < LITERALS; n++) | ||||||
|  |         if (s->dyn_ltree[n].Freq != 0) | ||||||
|  |             return Z_TEXT; | ||||||
|  |  | ||||||
|  |     /* There are no "block-listed" or "allow-listed" bytes: | ||||||
|  |      * this stream either is empty or has tolerated ("gray-listed") bytes only. | ||||||
|  |      */ | ||||||
|  |     return Z_BINARY; | ||||||
|  | } | ||||||
|  |  | ||||||
| /* =========================================================================== | /* =========================================================================== | ||||||
|  * Determine the best encoding for the current block: dynamic trees, static |  * Determine the best encoding for the current block: dynamic trees, static | ||||||
|  * trees or store, and write out the encoded block. |  * trees or store, and write out the encoded block. | ||||||
|  */ |  */ | ||||||
| void ZLIB_INTERNAL _tr_flush_block(s, buf, stored_len, last) | void ZLIB_INTERNAL _tr_flush_block(deflate_state *s, charf *buf, | ||||||
|     deflate_state *s; |                                    ulg stored_len, int last) { | ||||||
|     charf *buf;       /* input block, or NULL if too old */ |  | ||||||
|     ulg stored_len;   /* length of input block */ |  | ||||||
|     int last;         /* one if this is the last block for a file */ |  | ||||||
| { |  | ||||||
|     ulg opt_lenb, static_lenb; /* opt_len and static_len in bytes */ |     ulg opt_lenb, static_lenb; /* opt_len and static_len in bytes */ | ||||||
|     int max_blindex = 0;  /* index of last bit length code of non zero freq */ |     int max_blindex = 0;  /* index of last bit length code of non zero freq */ | ||||||
|  |  | ||||||
| @@ -1011,11 +1081,7 @@ void ZLIB_INTERNAL _tr_flush_block(s, buf, stored_len, last) | |||||||
|  * Save the match info and tally the frequency counts. Return true if |  * Save the match info and tally the frequency counts. Return true if | ||||||
|  * the current block must be flushed. |  * the current block must be flushed. | ||||||
|  */ |  */ | ||||||
| int ZLIB_INTERNAL _tr_tally(s, dist, lc) | int ZLIB_INTERNAL _tr_tally(deflate_state *s, unsigned dist, unsigned lc) { | ||||||
|     deflate_state *s; |  | ||||||
|     unsigned dist;  /* distance of matched string */ |  | ||||||
|     unsigned lc;    /* match length - MIN_MATCH or unmatched char (dist==0) */ |  | ||||||
| { |  | ||||||
|     s->sym_buf[s->sym_next++] = (uch)dist; |     s->sym_buf[s->sym_next++] = (uch)dist; | ||||||
|     s->sym_buf[s->sym_next++] = (uch)(dist >> 8); |     s->sym_buf[s->sym_next++] = (uch)(dist >> 8); | ||||||
|     s->sym_buf[s->sym_next++] = (uch)lc; |     s->sym_buf[s->sym_next++] = (uch)lc; | ||||||
| @@ -1035,147 +1101,3 @@ int ZLIB_INTERNAL _tr_tally(s, dist, lc) | |||||||
|     } |     } | ||||||
|     return (s->sym_next == s->sym_end); |     return (s->sym_next == s->sym_end); | ||||||
| } | } | ||||||
|  |  | ||||||
| /* =========================================================================== |  | ||||||
|  * Send the block data compressed using the given Huffman trees |  | ||||||
|  */ |  | ||||||
| local void compress_block(s, ltree, dtree) |  | ||||||
|     deflate_state *s; |  | ||||||
|     const ct_data *ltree; /* literal tree */ |  | ||||||
|     const ct_data *dtree; /* distance tree */ |  | ||||||
| { |  | ||||||
|     unsigned dist;      /* distance of matched string */ |  | ||||||
|     int lc;             /* match length or unmatched char (if dist == 0) */ |  | ||||||
|     unsigned sx = 0;    /* running index in sym_buf */ |  | ||||||
|     unsigned code;      /* the code to send */ |  | ||||||
|     int extra;          /* number of extra bits to send */ |  | ||||||
|  |  | ||||||
|     if (s->sym_next != 0) do { |  | ||||||
|         dist = s->sym_buf[sx++] & 0xff; |  | ||||||
|         dist += (unsigned)(s->sym_buf[sx++] & 0xff) << 8; |  | ||||||
|         lc = s->sym_buf[sx++]; |  | ||||||
|         if (dist == 0) { |  | ||||||
|             send_code(s, lc, ltree); /* send a literal byte */ |  | ||||||
|             Tracecv(isgraph(lc), (stderr," '%c' ", lc)); |  | ||||||
|         } else { |  | ||||||
|             /* Here, lc is the match length - MIN_MATCH */ |  | ||||||
|             code = _length_code[lc]; |  | ||||||
|             send_code(s, code + LITERALS + 1, ltree);   /* send length code */ |  | ||||||
|             extra = extra_lbits[code]; |  | ||||||
|             if (extra != 0) { |  | ||||||
|                 lc -= base_length[code]; |  | ||||||
|                 send_bits(s, lc, extra);       /* send the extra length bits */ |  | ||||||
|             } |  | ||||||
|             dist--; /* dist is now the match distance - 1 */ |  | ||||||
|             code = d_code(dist); |  | ||||||
|             Assert (code < D_CODES, "bad d_code"); |  | ||||||
|  |  | ||||||
|             send_code(s, code, dtree);       /* send the distance code */ |  | ||||||
|             extra = extra_dbits[code]; |  | ||||||
|             if (extra != 0) { |  | ||||||
|                 dist -= (unsigned)base_dist[code]; |  | ||||||
|                 send_bits(s, dist, extra);   /* send the extra distance bits */ |  | ||||||
|             } |  | ||||||
|         } /* literal or match pair ? */ |  | ||||||
|  |  | ||||||
|         /* Check that the overlay between pending_buf and sym_buf is ok: */ |  | ||||||
|         Assert(s->pending < s->lit_bufsize + sx, "pendingBuf overflow"); |  | ||||||
|  |  | ||||||
|     } while (sx < s->sym_next); |  | ||||||
|  |  | ||||||
|     send_code(s, END_BLOCK, ltree); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* =========================================================================== |  | ||||||
|  * Check if the data type is TEXT or BINARY, using the following algorithm: |  | ||||||
|  * - TEXT if the two conditions below are satisfied: |  | ||||||
|  *    a) There are no non-portable control characters belonging to the |  | ||||||
|  *       "block list" (0..6, 14..25, 28..31). |  | ||||||
|  *    b) There is at least one printable character belonging to the |  | ||||||
|  *       "allow list" (9 {TAB}, 10 {LF}, 13 {CR}, 32..255). |  | ||||||
|  * - BINARY otherwise. |  | ||||||
|  * - The following partially-portable control characters form a |  | ||||||
|  *   "gray list" that is ignored in this detection algorithm: |  | ||||||
|  *   (7 {BEL}, 8 {BS}, 11 {VT}, 12 {FF}, 26 {SUB}, 27 {ESC}). |  | ||||||
|  * IN assertion: the fields Freq of dyn_ltree are set. |  | ||||||
|  */ |  | ||||||
| local int detect_data_type(s) |  | ||||||
|     deflate_state *s; |  | ||||||
| { |  | ||||||
|     /* block_mask is the bit mask of block-listed bytes |  | ||||||
|      * set bits 0..6, 14..25, and 28..31 |  | ||||||
|      * 0xf3ffc07f = binary 11110011111111111100000001111111 |  | ||||||
|      */ |  | ||||||
|     unsigned long block_mask = 0xf3ffc07fUL; |  | ||||||
|     int n; |  | ||||||
|  |  | ||||||
|     /* Check for non-textual ("block-listed") bytes. */ |  | ||||||
|     for (n = 0; n <= 31; n++, block_mask >>= 1) |  | ||||||
|         if ((block_mask & 1) && (s->dyn_ltree[n].Freq != 0)) |  | ||||||
|             return Z_BINARY; |  | ||||||
|  |  | ||||||
|     /* Check for textual ("allow-listed") bytes. */ |  | ||||||
|     if (s->dyn_ltree[9].Freq != 0 || s->dyn_ltree[10].Freq != 0 |  | ||||||
|             || s->dyn_ltree[13].Freq != 0) |  | ||||||
|         return Z_TEXT; |  | ||||||
|     for (n = 32; n < LITERALS; n++) |  | ||||||
|         if (s->dyn_ltree[n].Freq != 0) |  | ||||||
|             return Z_TEXT; |  | ||||||
|  |  | ||||||
|     /* There are no "block-listed" or "allow-listed" bytes: |  | ||||||
|      * this stream either is empty or has tolerated ("gray-listed") bytes only. |  | ||||||
|      */ |  | ||||||
|     return Z_BINARY; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* =========================================================================== |  | ||||||
|  * Reverse the first len bits of a code, using straightforward code (a faster |  | ||||||
|  * method would use a table) |  | ||||||
|  * IN assertion: 1 <= len <= 15 |  | ||||||
|  */ |  | ||||||
| local unsigned bi_reverse(code, len) |  | ||||||
|     unsigned code; /* the value to invert */ |  | ||||||
|     int len;       /* its bit length */ |  | ||||||
| { |  | ||||||
|     register unsigned res = 0; |  | ||||||
|     do { |  | ||||||
|         res |= code & 1; |  | ||||||
|         code >>= 1, res <<= 1; |  | ||||||
|     } while (--len > 0); |  | ||||||
|     return res >> 1; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* =========================================================================== |  | ||||||
|  * Flush the bit buffer, keeping at most 7 bits in it. |  | ||||||
|  */ |  | ||||||
| local void bi_flush(s) |  | ||||||
|     deflate_state *s; |  | ||||||
| { |  | ||||||
|     if (s->bi_valid == 16) { |  | ||||||
|         put_short(s, s->bi_buf); |  | ||||||
|         s->bi_buf = 0; |  | ||||||
|         s->bi_valid = 0; |  | ||||||
|     } else if (s->bi_valid >= 8) { |  | ||||||
|         put_byte(s, (Byte)s->bi_buf); |  | ||||||
|         s->bi_buf >>= 8; |  | ||||||
|         s->bi_valid -= 8; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* =========================================================================== |  | ||||||
|  * Flush the bit buffer and align the output on a byte boundary |  | ||||||
|  */ |  | ||||||
| local void bi_windup(s) |  | ||||||
|     deflate_state *s; |  | ||||||
| { |  | ||||||
|     if (s->bi_valid > 8) { |  | ||||||
|         put_short(s, s->bi_buf); |  | ||||||
|     } else if (s->bi_valid > 0) { |  | ||||||
|         put_byte(s, (Byte)s->bi_buf); |  | ||||||
|     } |  | ||||||
|     s->bi_buf = 0; |  | ||||||
|     s->bi_valid = 0; |  | ||||||
| #ifdef ZLIB_DEBUG |  | ||||||
|     s->bits_sent = (s->bits_sent + 7) & ~7; |  | ||||||
| #endif |  | ||||||
| } |  | ||||||
|   | |||||||
| @@ -241,7 +241,11 @@ | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef Z_SOLO | #ifdef Z_SOLO | ||||||
|    typedef unsigned long z_size_t; | #  ifdef _WIN64 | ||||||
|  |      typedef unsigned long long z_size_t; | ||||||
|  | #  else | ||||||
|  |      typedef unsigned long z_size_t; | ||||||
|  | #  endif | ||||||
| #else | #else | ||||||
| #  define z_longlong long long | #  define z_longlong long long | ||||||
| #  if defined(NO_SIZE_T) | #  if defined(NO_SIZE_T) | ||||||
| @@ -520,7 +524,7 @@ typedef uLong FAR uLongf; | |||||||
| #if !defined(_WIN32) && defined(Z_LARGE64) | #if !defined(_WIN32) && defined(Z_LARGE64) | ||||||
| #  define z_off64_t off64_t | #  define z_off64_t off64_t | ||||||
| #else | #else | ||||||
| #  if defined(_WIN32) && !defined(__GNUC__) && !defined(Z_SOLO) | #  if defined(_WIN32) && !defined(__GNUC__) | ||||||
| #    define z_off64_t __int64 | #    define z_off64_t __int64 | ||||||
| #  else | #  else | ||||||
| #    define z_off64_t z_off_t | #    define z_off64_t z_off_t | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| /* zlib.h -- interface of the 'zlib' general purpose compression library | /* zlib.h -- interface of the 'zlib' general purpose compression library | ||||||
|   version 1.2.13, October 13th, 2022 |   version 1.3, August 18th, 2023 | ||||||
|  |  | ||||||
|   Copyright (C) 1995-2022 Jean-loup Gailly and Mark Adler |   Copyright (C) 1995-2023 Jean-loup Gailly and Mark Adler | ||||||
|  |  | ||||||
|   This software is provided 'as-is', without any express or implied |   This software is provided 'as-is', without any express or implied | ||||||
|   warranty.  In no event will the authors be held liable for any damages |   warranty.  In no event will the authors be held liable for any damages | ||||||
| @@ -37,11 +37,11 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #define ZLIB_VERSION "1.2.13" | #define ZLIB_VERSION "1.3" | ||||||
| #define ZLIB_VERNUM 0x12d0 | #define ZLIB_VERNUM 0x1300 | ||||||
| #define ZLIB_VER_MAJOR 1 | #define ZLIB_VER_MAJOR 1 | ||||||
| #define ZLIB_VER_MINOR 2 | #define ZLIB_VER_MINOR 3 | ||||||
| #define ZLIB_VER_REVISION 13 | #define ZLIB_VER_REVISION 0 | ||||||
| #define ZLIB_VER_SUBREVISION 0 | #define ZLIB_VER_SUBREVISION 0 | ||||||
|  |  | ||||||
| /* | /* | ||||||
| @@ -78,8 +78,8 @@ extern "C" { | |||||||
|   even in the case of corrupted input. |   even in the case of corrupted input. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| typedef voidpf (*alloc_func) OF((voidpf opaque, uInt items, uInt size)); | typedef voidpf (*alloc_func)(voidpf opaque, uInt items, uInt size); | ||||||
| typedef void   (*free_func)  OF((voidpf opaque, voidpf address)); | typedef void   (*free_func)(voidpf opaque, voidpf address); | ||||||
|  |  | ||||||
| struct internal_state; | struct internal_state; | ||||||
|  |  | ||||||
| @@ -217,7 +217,7 @@ typedef gz_header FAR *gz_headerp; | |||||||
|  |  | ||||||
|                         /* basic functions */ |                         /* basic functions */ | ||||||
|  |  | ||||||
| ZEXTERN const char * ZEXPORT zlibVersion OF((void)); | ZEXTERN const char * ZEXPORT zlibVersion(void); | ||||||
| /* The application can compare zlibVersion and ZLIB_VERSION for consistency. | /* The application can compare zlibVersion and ZLIB_VERSION for consistency. | ||||||
|    If the first character differs, the library code actually used is not |    If the first character differs, the library code actually used is not | ||||||
|    compatible with the zlib.h header file used by the application.  This check |    compatible with the zlib.h header file used by the application.  This check | ||||||
| @@ -225,12 +225,12 @@ ZEXTERN const char * ZEXPORT zlibVersion OF((void)); | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN int ZEXPORT deflateInit OF((z_streamp strm, int level)); | ZEXTERN int ZEXPORT deflateInit(z_streamp strm, int level); | ||||||
|  |  | ||||||
|      Initializes the internal stream state for compression.  The fields |      Initializes the internal stream state for compression.  The fields | ||||||
|    zalloc, zfree and opaque must be initialized before by the caller.  If |    zalloc, zfree and opaque must be initialized before by the caller.  If | ||||||
|    zalloc and zfree are set to Z_NULL, deflateInit updates them to use default |    zalloc and zfree are set to Z_NULL, deflateInit updates them to use default | ||||||
|    allocation functions. |    allocation functions.  total_in, total_out, adler, and msg are initialized. | ||||||
|  |  | ||||||
|      The compression level must be Z_DEFAULT_COMPRESSION, or between 0 and 9: |      The compression level must be Z_DEFAULT_COMPRESSION, or between 0 and 9: | ||||||
|    1 gives best speed, 9 gives best compression, 0 gives no compression at all |    1 gives best speed, 9 gives best compression, 0 gives no compression at all | ||||||
| @@ -247,7 +247,7 @@ ZEXTERN int ZEXPORT deflateInit OF((z_streamp strm, int level)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflate OF((z_streamp strm, int flush)); | ZEXTERN int ZEXPORT deflate(z_streamp strm, int flush); | ||||||
| /* | /* | ||||||
|     deflate compresses as much data as possible, and stops when the input |     deflate compresses as much data as possible, and stops when the input | ||||||
|   buffer becomes empty or the output buffer becomes full.  It may introduce |   buffer becomes empty or the output buffer becomes full.  It may introduce | ||||||
| @@ -320,8 +320,8 @@ ZEXTERN int ZEXPORT deflate OF((z_streamp strm, int flush)); | |||||||
|   with the same value of the flush parameter and more output space (updated |   with the same value of the flush parameter and more output space (updated | ||||||
|   avail_out), until the flush is complete (deflate returns with non-zero |   avail_out), until the flush is complete (deflate returns with non-zero | ||||||
|   avail_out).  In the case of a Z_FULL_FLUSH or Z_SYNC_FLUSH, make sure that |   avail_out).  In the case of a Z_FULL_FLUSH or Z_SYNC_FLUSH, make sure that | ||||||
|   avail_out is greater than six to avoid repeated flush markers due to |   avail_out is greater than six when the flush marker begins, in order to avoid | ||||||
|   avail_out == 0 on return. |   repeated flush markers upon calling deflate() again when avail_out == 0. | ||||||
|  |  | ||||||
|     If the parameter flush is set to Z_FINISH, pending input is processed, |     If the parameter flush is set to Z_FINISH, pending input is processed, | ||||||
|   pending output is flushed and deflate returns with Z_STREAM_END if there was |   pending output is flushed and deflate returns with Z_STREAM_END if there was | ||||||
| @@ -360,7 +360,7 @@ ZEXTERN int ZEXPORT deflate OF((z_streamp strm, int flush)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateEnd OF((z_streamp strm)); | ZEXTERN int ZEXPORT deflateEnd(z_streamp strm); | ||||||
| /* | /* | ||||||
|      All dynamically allocated data structures for this stream are freed. |      All dynamically allocated data structures for this stream are freed. | ||||||
|    This function discards any unprocessed input and does not flush any pending |    This function discards any unprocessed input and does not flush any pending | ||||||
| @@ -375,7 +375,7 @@ ZEXTERN int ZEXPORT deflateEnd OF((z_streamp strm)); | |||||||
|  |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN int ZEXPORT inflateInit OF((z_streamp strm)); | ZEXTERN int ZEXPORT inflateInit(z_streamp strm); | ||||||
|  |  | ||||||
|      Initializes the internal stream state for decompression.  The fields |      Initializes the internal stream state for decompression.  The fields | ||||||
|    next_in, avail_in, zalloc, zfree and opaque must be initialized before by |    next_in, avail_in, zalloc, zfree and opaque must be initialized before by | ||||||
| @@ -383,7 +383,8 @@ ZEXTERN int ZEXPORT inflateInit OF((z_streamp strm)); | |||||||
|    read or consumed.  The allocation of a sliding window will be deferred to |    read or consumed.  The allocation of a sliding window will be deferred to | ||||||
|    the first call of inflate (if the decompression does not complete on the |    the first call of inflate (if the decompression does not complete on the | ||||||
|    first call).  If zalloc and zfree are set to Z_NULL, inflateInit updates |    first call).  If zalloc and zfree are set to Z_NULL, inflateInit updates | ||||||
|    them to use default allocation functions. |    them to use default allocation functions.  total_in, total_out, adler, and | ||||||
|  |    msg are initialized. | ||||||
|  |  | ||||||
|      inflateInit returns Z_OK if success, Z_MEM_ERROR if there was not enough |      inflateInit returns Z_OK if success, Z_MEM_ERROR if there was not enough | ||||||
|    memory, Z_VERSION_ERROR if the zlib library version is incompatible with the |    memory, Z_VERSION_ERROR if the zlib library version is incompatible with the | ||||||
| @@ -397,7 +398,7 @@ ZEXTERN int ZEXPORT inflateInit OF((z_streamp strm)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflate OF((z_streamp strm, int flush)); | ZEXTERN int ZEXPORT inflate(z_streamp strm, int flush); | ||||||
| /* | /* | ||||||
|     inflate decompresses as much data as possible, and stops when the input |     inflate decompresses as much data as possible, and stops when the input | ||||||
|   buffer becomes empty or the output buffer becomes full.  It may introduce |   buffer becomes empty or the output buffer becomes full.  It may introduce | ||||||
| @@ -517,7 +518,7 @@ ZEXTERN int ZEXPORT inflate OF((z_streamp strm, int flush)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateEnd OF((z_streamp strm)); | ZEXTERN int ZEXPORT inflateEnd(z_streamp strm); | ||||||
| /* | /* | ||||||
|      All dynamically allocated data structures for this stream are freed. |      All dynamically allocated data structures for this stream are freed. | ||||||
|    This function discards any unprocessed input and does not flush any pending |    This function discards any unprocessed input and does not flush any pending | ||||||
| @@ -535,12 +536,12 @@ ZEXTERN int ZEXPORT inflateEnd OF((z_streamp strm)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN int ZEXPORT deflateInit2 OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateInit2(z_streamp strm, | ||||||
|                                      int  level, |                                  int level, | ||||||
|                                      int  method, |                                  int method, | ||||||
|                                      int  windowBits, |                                  int windowBits, | ||||||
|                                      int  memLevel, |                                  int memLevel, | ||||||
|                                      int  strategy)); |                                  int strategy); | ||||||
|  |  | ||||||
|      This is another version of deflateInit with more compression options.  The |      This is another version of deflateInit with more compression options.  The | ||||||
|    fields zalloc, zfree and opaque must be initialized before by the caller. |    fields zalloc, zfree and opaque must be initialized before by the caller. | ||||||
| @@ -607,9 +608,9 @@ ZEXTERN int ZEXPORT deflateInit2 OF((z_streamp strm, | |||||||
|    compression: this will be done by deflate(). |    compression: this will be done by deflate(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateSetDictionary OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateSetDictionary(z_streamp strm, | ||||||
|                                              const Bytef *dictionary, |                                          const Bytef *dictionary, | ||||||
|                                              uInt  dictLength)); |                                          uInt  dictLength); | ||||||
| /* | /* | ||||||
|      Initializes the compression dictionary from the given byte sequence |      Initializes the compression dictionary from the given byte sequence | ||||||
|    without producing any compressed output.  When using the zlib format, this |    without producing any compressed output.  When using the zlib format, this | ||||||
| @@ -651,9 +652,9 @@ ZEXTERN int ZEXPORT deflateSetDictionary OF((z_streamp strm, | |||||||
|    not perform any compression: this will be done by deflate(). |    not perform any compression: this will be done by deflate(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateGetDictionary OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateGetDictionary(z_streamp strm, | ||||||
|                                              Bytef *dictionary, |                                          Bytef *dictionary, | ||||||
|                                              uInt  *dictLength)); |                                          uInt  *dictLength); | ||||||
| /* | /* | ||||||
|      Returns the sliding dictionary being maintained by deflate.  dictLength is |      Returns the sliding dictionary being maintained by deflate.  dictLength is | ||||||
|    set to the number of bytes in the dictionary, and that many bytes are copied |    set to the number of bytes in the dictionary, and that many bytes are copied | ||||||
| @@ -673,8 +674,8 @@ ZEXTERN int ZEXPORT deflateGetDictionary OF((z_streamp strm, | |||||||
|    stream state is inconsistent. |    stream state is inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateCopy OF((z_streamp dest, | ZEXTERN int ZEXPORT deflateCopy(z_streamp dest, | ||||||
|                                     z_streamp source)); |                                 z_streamp source); | ||||||
| /* | /* | ||||||
|      Sets the destination stream as a complete copy of the source stream. |      Sets the destination stream as a complete copy of the source stream. | ||||||
|  |  | ||||||
| @@ -691,20 +692,20 @@ ZEXTERN int ZEXPORT deflateCopy OF((z_streamp dest, | |||||||
|    destination. |    destination. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateReset OF((z_streamp strm)); | ZEXTERN int ZEXPORT deflateReset(z_streamp strm); | ||||||
| /* | /* | ||||||
|      This function is equivalent to deflateEnd followed by deflateInit, but |      This function is equivalent to deflateEnd followed by deflateInit, but | ||||||
|    does not free and reallocate the internal compression state.  The stream |    does not free and reallocate the internal compression state.  The stream | ||||||
|    will leave the compression level and any other attributes that may have been |    will leave the compression level and any other attributes that may have been | ||||||
|    set unchanged. |    set unchanged.  total_in, total_out, adler, and msg are initialized. | ||||||
|  |  | ||||||
|      deflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source |      deflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source | ||||||
|    stream state was inconsistent (such as zalloc or state being Z_NULL). |    stream state was inconsistent (such as zalloc or state being Z_NULL). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateParams OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateParams(z_streamp strm, | ||||||
|                                       int level, |                                   int level, | ||||||
|                                       int strategy)); |                                   int strategy); | ||||||
| /* | /* | ||||||
|      Dynamically update the compression level and compression strategy.  The |      Dynamically update the compression level and compression strategy.  The | ||||||
|    interpretation of level and strategy is as in deflateInit2().  This can be |    interpretation of level and strategy is as in deflateInit2().  This can be | ||||||
| @@ -729,7 +730,7 @@ ZEXTERN int ZEXPORT deflateParams OF((z_streamp strm, | |||||||
|    Then no more input data should be provided before the deflateParams() call. |    Then no more input data should be provided before the deflateParams() call. | ||||||
|    If this is done, the old level and strategy will be applied to the data |    If this is done, the old level and strategy will be applied to the data | ||||||
|    compressed before deflateParams(), and the new level and strategy will be |    compressed before deflateParams(), and the new level and strategy will be | ||||||
|    applied to the the data compressed after deflateParams(). |    applied to the data compressed after deflateParams(). | ||||||
|  |  | ||||||
|      deflateParams returns Z_OK on success, Z_STREAM_ERROR if the source stream |      deflateParams returns Z_OK on success, Z_STREAM_ERROR if the source stream | ||||||
|    state was inconsistent or if a parameter was invalid, or Z_BUF_ERROR if |    state was inconsistent or if a parameter was invalid, or Z_BUF_ERROR if | ||||||
| @@ -740,11 +741,11 @@ ZEXTERN int ZEXPORT deflateParams OF((z_streamp strm, | |||||||
|    retried with more output space. |    retried with more output space. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateTune OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateTune(z_streamp strm, | ||||||
|                                     int good_length, |                                 int good_length, | ||||||
|                                     int max_lazy, |                                 int max_lazy, | ||||||
|                                     int nice_length, |                                 int nice_length, | ||||||
|                                     int max_chain)); |                                 int max_chain); | ||||||
| /* | /* | ||||||
|      Fine tune deflate's internal compression parameters.  This should only be |      Fine tune deflate's internal compression parameters.  This should only be | ||||||
|    used by someone who understands the algorithm used by zlib's deflate for |    used by someone who understands the algorithm used by zlib's deflate for | ||||||
| @@ -757,8 +758,8 @@ ZEXTERN int ZEXPORT deflateTune OF((z_streamp strm, | |||||||
|    returns Z_OK on success, or Z_STREAM_ERROR for an invalid deflate stream. |    returns Z_OK on success, or Z_STREAM_ERROR for an invalid deflate stream. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT deflateBound OF((z_streamp strm, | ZEXTERN uLong ZEXPORT deflateBound(z_streamp strm, | ||||||
|                                        uLong sourceLen)); |                                    uLong sourceLen); | ||||||
| /* | /* | ||||||
|      deflateBound() returns an upper bound on the compressed size after |      deflateBound() returns an upper bound on the compressed size after | ||||||
|    deflation of sourceLen bytes.  It must be called after deflateInit() or |    deflation of sourceLen bytes.  It must be called after deflateInit() or | ||||||
| @@ -772,9 +773,9 @@ ZEXTERN uLong ZEXPORT deflateBound OF((z_streamp strm, | |||||||
|    than Z_FINISH or Z_NO_FLUSH are used. |    than Z_FINISH or Z_NO_FLUSH are used. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflatePending OF((z_streamp strm, | ZEXTERN int ZEXPORT deflatePending(z_streamp strm, | ||||||
|                                        unsigned *pending, |                                    unsigned *pending, | ||||||
|                                        int *bits)); |                                    int *bits); | ||||||
| /* | /* | ||||||
|      deflatePending() returns the number of bytes and bits of output that have |      deflatePending() returns the number of bytes and bits of output that have | ||||||
|    been generated, but not yet provided in the available output.  The bytes not |    been generated, but not yet provided in the available output.  The bytes not | ||||||
| @@ -787,9 +788,9 @@ ZEXTERN int ZEXPORT deflatePending OF((z_streamp strm, | |||||||
|    stream state was inconsistent. |    stream state was inconsistent. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflatePrime OF((z_streamp strm, | ZEXTERN int ZEXPORT deflatePrime(z_streamp strm, | ||||||
|                                      int bits, |                                  int bits, | ||||||
|                                      int value)); |                                  int value); | ||||||
| /* | /* | ||||||
|      deflatePrime() inserts bits in the deflate output stream.  The intent |      deflatePrime() inserts bits in the deflate output stream.  The intent | ||||||
|    is that this function is used to start off the deflate output with the bits |    is that this function is used to start off the deflate output with the bits | ||||||
| @@ -804,8 +805,8 @@ ZEXTERN int ZEXPORT deflatePrime OF((z_streamp strm, | |||||||
|    source stream state was inconsistent. |    source stream state was inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT deflateSetHeader OF((z_streamp strm, | ZEXTERN int ZEXPORT deflateSetHeader(z_streamp strm, | ||||||
|                                          gz_headerp head)); |                                      gz_headerp head); | ||||||
| /* | /* | ||||||
|      deflateSetHeader() provides gzip header information for when a gzip |      deflateSetHeader() provides gzip header information for when a gzip | ||||||
|    stream is requested by deflateInit2().  deflateSetHeader() may be called |    stream is requested by deflateInit2().  deflateSetHeader() may be called | ||||||
| @@ -821,16 +822,17 @@ ZEXTERN int ZEXPORT deflateSetHeader OF((z_streamp strm, | |||||||
|    gzip file" and give up. |    gzip file" and give up. | ||||||
|  |  | ||||||
|      If deflateSetHeader is not used, the default gzip header has text false, |      If deflateSetHeader is not used, the default gzip header has text false, | ||||||
|    the time set to zero, and os set to 255, with no extra, name, or comment |    the time set to zero, and os set to the current operating system, with no | ||||||
|    fields.  The gzip header is returned to the default state by deflateReset(). |    extra, name, or comment fields.  The gzip header is returned to the default | ||||||
|  |    state by deflateReset(). | ||||||
|  |  | ||||||
|      deflateSetHeader returns Z_OK if success, or Z_STREAM_ERROR if the source |      deflateSetHeader returns Z_OK if success, or Z_STREAM_ERROR if the source | ||||||
|    stream state was inconsistent. |    stream state was inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN int ZEXPORT inflateInit2 OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateInit2(z_streamp strm, | ||||||
|                                      int  windowBits)); |                                  int windowBits); | ||||||
|  |  | ||||||
|      This is another version of inflateInit with an extra parameter.  The |      This is another version of inflateInit with an extra parameter.  The | ||||||
|    fields next_in, avail_in, zalloc, zfree and opaque must be initialized |    fields next_in, avail_in, zalloc, zfree and opaque must be initialized | ||||||
| @@ -883,9 +885,9 @@ ZEXTERN int ZEXPORT inflateInit2 OF((z_streamp strm, | |||||||
|    deferred until inflate() is called. |    deferred until inflate() is called. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateSetDictionary OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateSetDictionary(z_streamp strm, | ||||||
|                                              const Bytef *dictionary, |                                          const Bytef *dictionary, | ||||||
|                                              uInt  dictLength)); |                                          uInt  dictLength); | ||||||
| /* | /* | ||||||
|      Initializes the decompression dictionary from the given uncompressed byte |      Initializes the decompression dictionary from the given uncompressed byte | ||||||
|    sequence.  This function must be called immediately after a call of inflate, |    sequence.  This function must be called immediately after a call of inflate, | ||||||
| @@ -906,9 +908,9 @@ ZEXTERN int ZEXPORT inflateSetDictionary OF((z_streamp strm, | |||||||
|    inflate(). |    inflate(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateGetDictionary OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateGetDictionary(z_streamp strm, | ||||||
|                                              Bytef *dictionary, |                                          Bytef *dictionary, | ||||||
|                                              uInt  *dictLength)); |                                          uInt  *dictLength); | ||||||
| /* | /* | ||||||
|      Returns the sliding dictionary being maintained by inflate.  dictLength is |      Returns the sliding dictionary being maintained by inflate.  dictLength is | ||||||
|    set to the number of bytes in the dictionary, and that many bytes are copied |    set to the number of bytes in the dictionary, and that many bytes are copied | ||||||
| @@ -921,7 +923,7 @@ ZEXTERN int ZEXPORT inflateGetDictionary OF((z_streamp strm, | |||||||
|    stream state is inconsistent. |    stream state is inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateSync OF((z_streamp strm)); | ZEXTERN int ZEXPORT inflateSync(z_streamp strm); | ||||||
| /* | /* | ||||||
|      Skips invalid compressed data until a possible full flush point (see above |      Skips invalid compressed data until a possible full flush point (see above | ||||||
|    for the description of deflate with Z_FULL_FLUSH) can be found, or until all |    for the description of deflate with Z_FULL_FLUSH) can be found, or until all | ||||||
| @@ -940,8 +942,8 @@ ZEXTERN int ZEXPORT inflateSync OF((z_streamp strm)); | |||||||
|    input each time, until success or end of the input data. |    input each time, until success or end of the input data. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateCopy OF((z_streamp dest, | ZEXTERN int ZEXPORT inflateCopy(z_streamp dest, | ||||||
|                                     z_streamp source)); |                                 z_streamp source); | ||||||
| /* | /* | ||||||
|      Sets the destination stream as a complete copy of the source stream. |      Sets the destination stream as a complete copy of the source stream. | ||||||
|  |  | ||||||
| @@ -956,18 +958,19 @@ ZEXTERN int ZEXPORT inflateCopy OF((z_streamp dest, | |||||||
|    destination. |    destination. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateReset OF((z_streamp strm)); | ZEXTERN int ZEXPORT inflateReset(z_streamp strm); | ||||||
| /* | /* | ||||||
|      This function is equivalent to inflateEnd followed by inflateInit, |      This function is equivalent to inflateEnd followed by inflateInit, | ||||||
|    but does not free and reallocate the internal decompression state.  The |    but does not free and reallocate the internal decompression state.  The | ||||||
|    stream will keep attributes that may have been set by inflateInit2. |    stream will keep attributes that may have been set by inflateInit2. | ||||||
|  |    total_in, total_out, adler, and msg are initialized. | ||||||
|  |  | ||||||
|      inflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source |      inflateReset returns Z_OK if success, or Z_STREAM_ERROR if the source | ||||||
|    stream state was inconsistent (such as zalloc or state being Z_NULL). |    stream state was inconsistent (such as zalloc or state being Z_NULL). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateReset2 OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateReset2(z_streamp strm, | ||||||
|                                       int windowBits)); |                                   int windowBits); | ||||||
| /* | /* | ||||||
|      This function is the same as inflateReset, but it also permits changing |      This function is the same as inflateReset, but it also permits changing | ||||||
|    the wrap and window size requests.  The windowBits parameter is interpreted |    the wrap and window size requests.  The windowBits parameter is interpreted | ||||||
| @@ -980,9 +983,9 @@ ZEXTERN int ZEXPORT inflateReset2 OF((z_streamp strm, | |||||||
|    the windowBits parameter is invalid. |    the windowBits parameter is invalid. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflatePrime OF((z_streamp strm, | ZEXTERN int ZEXPORT inflatePrime(z_streamp strm, | ||||||
|                                      int bits, |                                  int bits, | ||||||
|                                      int value)); |                                  int value); | ||||||
| /* | /* | ||||||
|      This function inserts bits in the inflate input stream.  The intent is |      This function inserts bits in the inflate input stream.  The intent is | ||||||
|    that this function is used to start inflating at a bit position in the |    that this function is used to start inflating at a bit position in the | ||||||
| @@ -1001,7 +1004,7 @@ ZEXTERN int ZEXPORT inflatePrime OF((z_streamp strm, | |||||||
|    stream state was inconsistent. |    stream state was inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN long ZEXPORT inflateMark OF((z_streamp strm)); | ZEXTERN long ZEXPORT inflateMark(z_streamp strm); | ||||||
| /* | /* | ||||||
|      This function returns two values, one in the lower 16 bits of the return |      This function returns two values, one in the lower 16 bits of the return | ||||||
|    value, and the other in the remaining upper bits, obtained by shifting the |    value, and the other in the remaining upper bits, obtained by shifting the | ||||||
| @@ -1029,8 +1032,8 @@ ZEXTERN long ZEXPORT inflateMark OF((z_streamp strm)); | |||||||
|    source stream state was inconsistent. |    source stream state was inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateGetHeader OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateGetHeader(z_streamp strm, | ||||||
|                                          gz_headerp head)); |                                      gz_headerp head); | ||||||
| /* | /* | ||||||
|      inflateGetHeader() requests that gzip header information be stored in the |      inflateGetHeader() requests that gzip header information be stored in the | ||||||
|    provided gz_header structure.  inflateGetHeader() may be called after |    provided gz_header structure.  inflateGetHeader() may be called after | ||||||
| @@ -1070,8 +1073,8 @@ ZEXTERN int ZEXPORT inflateGetHeader OF((z_streamp strm, | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN int ZEXPORT inflateBackInit OF((z_streamp strm, int windowBits, | ZEXTERN int ZEXPORT inflateBackInit(z_streamp strm, int windowBits, | ||||||
|                                         unsigned char FAR *window)); |                                     unsigned char FAR *window); | ||||||
|  |  | ||||||
|      Initialize the internal stream state for decompression using inflateBack() |      Initialize the internal stream state for decompression using inflateBack() | ||||||
|    calls.  The fields zalloc, zfree and opaque in strm must be initialized |    calls.  The fields zalloc, zfree and opaque in strm must be initialized | ||||||
| @@ -1091,13 +1094,13 @@ ZEXTERN int ZEXPORT inflateBackInit OF((z_streamp strm, int windowBits, | |||||||
|    the version of the header file. |    the version of the header file. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| typedef unsigned (*in_func) OF((void FAR *, | typedef unsigned (*in_func)(void FAR *, | ||||||
|                                 z_const unsigned char FAR * FAR *)); |                             z_const unsigned char FAR * FAR *); | ||||||
| typedef int (*out_func) OF((void FAR *, unsigned char FAR *, unsigned)); | typedef int (*out_func)(void FAR *, unsigned char FAR *, unsigned); | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateBack OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateBack(z_streamp strm, | ||||||
|                                     in_func in, void FAR *in_desc, |                                 in_func in, void FAR *in_desc, | ||||||
|                                     out_func out, void FAR *out_desc)); |                                 out_func out, void FAR *out_desc); | ||||||
| /* | /* | ||||||
|      inflateBack() does a raw inflate with a single call using a call-back |      inflateBack() does a raw inflate with a single call using a call-back | ||||||
|    interface for input and output.  This is potentially more efficient than |    interface for input and output.  This is potentially more efficient than | ||||||
| @@ -1165,7 +1168,7 @@ ZEXTERN int ZEXPORT inflateBack OF((z_streamp strm, | |||||||
|    cannot return Z_OK. |    cannot return Z_OK. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT inflateBackEnd OF((z_streamp strm)); | ZEXTERN int ZEXPORT inflateBackEnd(z_streamp strm); | ||||||
| /* | /* | ||||||
|      All memory allocated by inflateBackInit() is freed. |      All memory allocated by inflateBackInit() is freed. | ||||||
|  |  | ||||||
| @@ -1173,7 +1176,7 @@ ZEXTERN int ZEXPORT inflateBackEnd OF((z_streamp strm)); | |||||||
|    state was inconsistent. |    state was inconsistent. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT zlibCompileFlags OF((void)); | ZEXTERN uLong ZEXPORT zlibCompileFlags(void); | ||||||
| /* Return flags indicating compile-time options. | /* Return flags indicating compile-time options. | ||||||
|  |  | ||||||
|     Type sizes, two bits each, 00 = 16 bits, 01 = 32, 10 = 64, 11 = other: |     Type sizes, two bits each, 00 = 16 bits, 01 = 32, 10 = 64, 11 = other: | ||||||
| @@ -1226,8 +1229,8 @@ ZEXTERN uLong ZEXPORT zlibCompileFlags OF((void)); | |||||||
|    you need special options. |    you need special options. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT compress OF((Bytef *dest,   uLongf *destLen, | ZEXTERN int ZEXPORT compress(Bytef *dest,   uLongf *destLen, | ||||||
|                                  const Bytef *source, uLong sourceLen)); |                              const Bytef *source, uLong sourceLen); | ||||||
| /* | /* | ||||||
|      Compresses the source buffer into the destination buffer.  sourceLen is |      Compresses the source buffer into the destination buffer.  sourceLen is | ||||||
|    the byte length of the source buffer.  Upon entry, destLen is the total size |    the byte length of the source buffer.  Upon entry, destLen is the total size | ||||||
| @@ -1241,9 +1244,9 @@ ZEXTERN int ZEXPORT compress OF((Bytef *dest,   uLongf *destLen, | |||||||
|    buffer. |    buffer. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT compress2 OF((Bytef *dest,   uLongf *destLen, | ZEXTERN int ZEXPORT compress2(Bytef *dest,   uLongf *destLen, | ||||||
|                                   const Bytef *source, uLong sourceLen, |                               const Bytef *source, uLong sourceLen, | ||||||
|                                   int level)); |                               int level); | ||||||
| /* | /* | ||||||
|      Compresses the source buffer into the destination buffer.  The level |      Compresses the source buffer into the destination buffer.  The level | ||||||
|    parameter has the same meaning as in deflateInit.  sourceLen is the byte |    parameter has the same meaning as in deflateInit.  sourceLen is the byte | ||||||
| @@ -1257,15 +1260,15 @@ ZEXTERN int ZEXPORT compress2 OF((Bytef *dest,   uLongf *destLen, | |||||||
|    Z_STREAM_ERROR if the level parameter is invalid. |    Z_STREAM_ERROR if the level parameter is invalid. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT compressBound OF((uLong sourceLen)); | ZEXTERN uLong ZEXPORT compressBound(uLong sourceLen); | ||||||
| /* | /* | ||||||
|      compressBound() returns an upper bound on the compressed size after |      compressBound() returns an upper bound on the compressed size after | ||||||
|    compress() or compress2() on sourceLen bytes.  It would be used before a |    compress() or compress2() on sourceLen bytes.  It would be used before a | ||||||
|    compress() or compress2() call to allocate the destination buffer. |    compress() or compress2() call to allocate the destination buffer. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT uncompress OF((Bytef *dest,   uLongf *destLen, | ZEXTERN int ZEXPORT uncompress(Bytef *dest,   uLongf *destLen, | ||||||
|                                    const Bytef *source, uLong sourceLen)); |                                const Bytef *source, uLong sourceLen); | ||||||
| /* | /* | ||||||
|      Decompresses the source buffer into the destination buffer.  sourceLen is |      Decompresses the source buffer into the destination buffer.  sourceLen is | ||||||
|    the byte length of the source buffer.  Upon entry, destLen is the total size |    the byte length of the source buffer.  Upon entry, destLen is the total size | ||||||
| @@ -1282,8 +1285,8 @@ ZEXTERN int ZEXPORT uncompress OF((Bytef *dest,   uLongf *destLen, | |||||||
|    buffer with the uncompressed data up to that point. |    buffer with the uncompressed data up to that point. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT uncompress2 OF((Bytef *dest,   uLongf *destLen, | ZEXTERN int ZEXPORT uncompress2(Bytef *dest,   uLongf *destLen, | ||||||
|                                     const Bytef *source, uLong *sourceLen)); |                                 const Bytef *source, uLong *sourceLen); | ||||||
| /* | /* | ||||||
|      Same as uncompress, except that sourceLen is a pointer, where the |      Same as uncompress, except that sourceLen is a pointer, where the | ||||||
|    length of the source is *sourceLen.  On return, *sourceLen is the number of |    length of the source is *sourceLen.  On return, *sourceLen is the number of | ||||||
| @@ -1302,7 +1305,7 @@ ZEXTERN int ZEXPORT uncompress2 OF((Bytef *dest,   uLongf *destLen, | |||||||
| typedef struct gzFile_s *gzFile;    /* semi-opaque gzip file descriptor */ | typedef struct gzFile_s *gzFile;    /* semi-opaque gzip file descriptor */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN gzFile ZEXPORT gzopen OF((const char *path, const char *mode)); | ZEXTERN gzFile ZEXPORT gzopen(const char *path, const char *mode); | ||||||
|  |  | ||||||
|      Open the gzip (.gz) file at path for reading and decompressing, or |      Open the gzip (.gz) file at path for reading and decompressing, or | ||||||
|    compressing and writing.  The mode parameter is as in fopen ("rb" or "wb") |    compressing and writing.  The mode parameter is as in fopen ("rb" or "wb") | ||||||
| @@ -1339,7 +1342,7 @@ ZEXTERN gzFile ZEXPORT gzopen OF((const char *path, const char *mode)); | |||||||
|    file could not be opened. |    file could not be opened. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN gzFile ZEXPORT gzdopen OF((int fd, const char *mode)); | ZEXTERN gzFile ZEXPORT gzdopen(int fd, const char *mode); | ||||||
| /* | /* | ||||||
|      Associate a gzFile with the file descriptor fd.  File descriptors are |      Associate a gzFile with the file descriptor fd.  File descriptors are | ||||||
|    obtained from calls like open, dup, creat, pipe or fileno (if the file has |    obtained from calls like open, dup, creat, pipe or fileno (if the file has | ||||||
| @@ -1362,7 +1365,7 @@ ZEXTERN gzFile ZEXPORT gzdopen OF((int fd, const char *mode)); | |||||||
|    will not detect if fd is invalid (unless fd is -1). |    will not detect if fd is invalid (unless fd is -1). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzbuffer OF((gzFile file, unsigned size)); | ZEXTERN int ZEXPORT gzbuffer(gzFile file, unsigned size); | ||||||
| /* | /* | ||||||
|      Set the internal buffer size used by this library's functions for file to |      Set the internal buffer size used by this library's functions for file to | ||||||
|    size.  The default buffer size is 8192 bytes.  This function must be called |    size.  The default buffer size is 8192 bytes.  This function must be called | ||||||
| @@ -1378,7 +1381,7 @@ ZEXTERN int ZEXPORT gzbuffer OF((gzFile file, unsigned size)); | |||||||
|    too late. |    too late. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzsetparams OF((gzFile file, int level, int strategy)); | ZEXTERN int ZEXPORT gzsetparams(gzFile file, int level, int strategy); | ||||||
| /* | /* | ||||||
|      Dynamically update the compression level and strategy for file.  See the |      Dynamically update the compression level and strategy for file.  See the | ||||||
|    description of deflateInit2 for the meaning of these parameters. Previously |    description of deflateInit2 for the meaning of these parameters. Previously | ||||||
| @@ -1389,7 +1392,7 @@ ZEXTERN int ZEXPORT gzsetparams OF((gzFile file, int level, int strategy)); | |||||||
|    or Z_MEM_ERROR if there is a memory allocation error. |    or Z_MEM_ERROR if there is a memory allocation error. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzread OF((gzFile file, voidp buf, unsigned len)); | ZEXTERN int ZEXPORT gzread(gzFile file, voidp buf, unsigned len); | ||||||
| /* | /* | ||||||
|      Read and decompress up to len uncompressed bytes from file into buf.  If |      Read and decompress up to len uncompressed bytes from file into buf.  If | ||||||
|    the input file is not in gzip format, gzread copies the given number of |    the input file is not in gzip format, gzread copies the given number of | ||||||
| @@ -1419,8 +1422,8 @@ ZEXTERN int ZEXPORT gzread OF((gzFile file, voidp buf, unsigned len)); | |||||||
|    Z_STREAM_ERROR. |    Z_STREAM_ERROR. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN z_size_t ZEXPORT gzfread OF((voidp buf, z_size_t size, z_size_t nitems, | ZEXTERN z_size_t ZEXPORT gzfread(voidp buf, z_size_t size, z_size_t nitems, | ||||||
|                                      gzFile file)); |                                  gzFile file); | ||||||
| /* | /* | ||||||
|      Read and decompress up to nitems items of size size from file into buf, |      Read and decompress up to nitems items of size size from file into buf, | ||||||
|    otherwise operating as gzread() does.  This duplicates the interface of |    otherwise operating as gzread() does.  This duplicates the interface of | ||||||
| @@ -1445,14 +1448,14 @@ ZEXTERN z_size_t ZEXPORT gzfread OF((voidp buf, z_size_t size, z_size_t nitems, | |||||||
|    file, resetting and retrying on end-of-file, when size is not 1. |    file, resetting and retrying on end-of-file, when size is not 1. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzwrite OF((gzFile file, voidpc buf, unsigned len)); | ZEXTERN int ZEXPORT gzwrite(gzFile file, voidpc buf, unsigned len); | ||||||
| /* | /* | ||||||
|      Compress and write the len uncompressed bytes at buf to file. gzwrite |      Compress and write the len uncompressed bytes at buf to file. gzwrite | ||||||
|    returns the number of uncompressed bytes written or 0 in case of error. |    returns the number of uncompressed bytes written or 0 in case of error. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN z_size_t ZEXPORT gzfwrite OF((voidpc buf, z_size_t size, | ZEXTERN z_size_t ZEXPORT gzfwrite(voidpc buf, z_size_t size, | ||||||
|                                       z_size_t nitems, gzFile file)); |                                   z_size_t nitems, gzFile file); | ||||||
| /* | /* | ||||||
|      Compress and write nitems items of size size from buf to file, duplicating |      Compress and write nitems items of size size from buf to file, duplicating | ||||||
|    the interface of stdio's fwrite(), with size_t request and return types.  If |    the interface of stdio's fwrite(), with size_t request and return types.  If | ||||||
| @@ -1465,7 +1468,7 @@ ZEXTERN z_size_t ZEXPORT gzfwrite OF((voidpc buf, z_size_t size, | |||||||
|    is returned, and the error state is set to Z_STREAM_ERROR. |    is returned, and the error state is set to Z_STREAM_ERROR. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORTVA gzprintf Z_ARG((gzFile file, const char *format, ...)); | ZEXTERN int ZEXPORTVA gzprintf(gzFile file, const char *format, ...); | ||||||
| /* | /* | ||||||
|      Convert, format, compress, and write the arguments (...) to file under |      Convert, format, compress, and write the arguments (...) to file under | ||||||
|    control of the string format, as in fprintf.  gzprintf returns the number of |    control of the string format, as in fprintf.  gzprintf returns the number of | ||||||
| @@ -1480,7 +1483,7 @@ ZEXTERN int ZEXPORTVA gzprintf Z_ARG((gzFile file, const char *format, ...)); | |||||||
|    This can be determined using zlibCompileFlags(). |    This can be determined using zlibCompileFlags(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzputs OF((gzFile file, const char *s)); | ZEXTERN int ZEXPORT gzputs(gzFile file, const char *s); | ||||||
| /* | /* | ||||||
|      Compress and write the given null-terminated string s to file, excluding |      Compress and write the given null-terminated string s to file, excluding | ||||||
|    the terminating null character. |    the terminating null character. | ||||||
| @@ -1488,7 +1491,7 @@ ZEXTERN int ZEXPORT gzputs OF((gzFile file, const char *s)); | |||||||
|      gzputs returns the number of characters written, or -1 in case of error. |      gzputs returns the number of characters written, or -1 in case of error. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN char * ZEXPORT gzgets OF((gzFile file, char *buf, int len)); | ZEXTERN char * ZEXPORT gzgets(gzFile file, char *buf, int len); | ||||||
| /* | /* | ||||||
|      Read and decompress bytes from file into buf, until len-1 characters are |      Read and decompress bytes from file into buf, until len-1 characters are | ||||||
|    read, or until a newline character is read and transferred to buf, or an |    read, or until a newline character is read and transferred to buf, or an | ||||||
| @@ -1502,13 +1505,13 @@ ZEXTERN char * ZEXPORT gzgets OF((gzFile file, char *buf, int len)); | |||||||
|    buf are indeterminate. |    buf are indeterminate. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzputc OF((gzFile file, int c)); | ZEXTERN int ZEXPORT gzputc(gzFile file, int c); | ||||||
| /* | /* | ||||||
|      Compress and write c, converted to an unsigned char, into file.  gzputc |      Compress and write c, converted to an unsigned char, into file.  gzputc | ||||||
|    returns the value that was written, or -1 in case of error. |    returns the value that was written, or -1 in case of error. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzgetc OF((gzFile file)); | ZEXTERN int ZEXPORT gzgetc(gzFile file); | ||||||
| /* | /* | ||||||
|      Read and decompress one byte from file.  gzgetc returns this byte or -1 |      Read and decompress one byte from file.  gzgetc returns this byte or -1 | ||||||
|    in case of end of file or error.  This is implemented as a macro for speed. |    in case of end of file or error.  This is implemented as a macro for speed. | ||||||
| @@ -1517,7 +1520,7 @@ ZEXTERN int ZEXPORT gzgetc OF((gzFile file)); | |||||||
|    points to has been clobbered or not. |    points to has been clobbered or not. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzungetc OF((int c, gzFile file)); | ZEXTERN int ZEXPORT gzungetc(int c, gzFile file); | ||||||
| /* | /* | ||||||
|      Push c back onto the stream for file to be read as the first character on |      Push c back onto the stream for file to be read as the first character on | ||||||
|    the next read.  At least one character of push-back is always allowed. |    the next read.  At least one character of push-back is always allowed. | ||||||
| @@ -1529,7 +1532,7 @@ ZEXTERN int ZEXPORT gzungetc OF((int c, gzFile file)); | |||||||
|    gzseek() or gzrewind(). |    gzseek() or gzrewind(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzflush OF((gzFile file, int flush)); | ZEXTERN int ZEXPORT gzflush(gzFile file, int flush); | ||||||
| /* | /* | ||||||
|      Flush all pending output to file.  The parameter flush is as in the |      Flush all pending output to file.  The parameter flush is as in the | ||||||
|    deflate() function.  The return value is the zlib error number (see function |    deflate() function.  The return value is the zlib error number (see function | ||||||
| @@ -1545,8 +1548,8 @@ ZEXTERN int ZEXPORT gzflush OF((gzFile file, int flush)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN z_off_t ZEXPORT gzseek OF((gzFile file, | ZEXTERN z_off_t ZEXPORT gzseek(gzFile file, | ||||||
|                                    z_off_t offset, int whence)); |                                z_off_t offset, int whence); | ||||||
|  |  | ||||||
|      Set the starting position to offset relative to whence for the next gzread |      Set the starting position to offset relative to whence for the next gzread | ||||||
|    or gzwrite on file.  The offset represents a number of bytes in the |    or gzwrite on file.  The offset represents a number of bytes in the | ||||||
| @@ -1564,7 +1567,7 @@ ZEXTERN z_off_t ZEXPORT gzseek OF((gzFile file, | |||||||
|    would be before the current position. |    would be before the current position. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT    gzrewind OF((gzFile file)); | ZEXTERN int ZEXPORT    gzrewind(gzFile file); | ||||||
| /* | /* | ||||||
|      Rewind file. This function is supported only for reading. |      Rewind file. This function is supported only for reading. | ||||||
|  |  | ||||||
| @@ -1572,7 +1575,7 @@ ZEXTERN int ZEXPORT    gzrewind OF((gzFile file)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN z_off_t ZEXPORT    gztell OF((gzFile file)); | ZEXTERN z_off_t ZEXPORT    gztell(gzFile file); | ||||||
|  |  | ||||||
|      Return the starting position for the next gzread or gzwrite on file. |      Return the starting position for the next gzread or gzwrite on file. | ||||||
|    This position represents a number of bytes in the uncompressed data stream, |    This position represents a number of bytes in the uncompressed data stream, | ||||||
| @@ -1583,7 +1586,7 @@ ZEXTERN z_off_t ZEXPORT    gztell OF((gzFile file)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN z_off_t ZEXPORT gzoffset OF((gzFile file)); | ZEXTERN z_off_t ZEXPORT gzoffset(gzFile file); | ||||||
|  |  | ||||||
|      Return the current compressed (actual) read or write offset of file.  This |      Return the current compressed (actual) read or write offset of file.  This | ||||||
|    offset includes the count of bytes that precede the gzip stream, for example |    offset includes the count of bytes that precede the gzip stream, for example | ||||||
| @@ -1592,7 +1595,7 @@ ZEXTERN z_off_t ZEXPORT gzoffset OF((gzFile file)); | |||||||
|    be used for a progress indicator.  On error, gzoffset() returns -1. |    be used for a progress indicator.  On error, gzoffset() returns -1. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzeof OF((gzFile file)); | ZEXTERN int ZEXPORT gzeof(gzFile file); | ||||||
| /* | /* | ||||||
|      Return true (1) if the end-of-file indicator for file has been set while |      Return true (1) if the end-of-file indicator for file has been set while | ||||||
|    reading, false (0) otherwise.  Note that the end-of-file indicator is set |    reading, false (0) otherwise.  Note that the end-of-file indicator is set | ||||||
| @@ -1607,7 +1610,7 @@ ZEXTERN int ZEXPORT gzeof OF((gzFile file)); | |||||||
|    has grown since the previous end of file was detected. |    has grown since the previous end of file was detected. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzdirect OF((gzFile file)); | ZEXTERN int ZEXPORT gzdirect(gzFile file); | ||||||
| /* | /* | ||||||
|      Return true (1) if file is being copied directly while reading, or false |      Return true (1) if file is being copied directly while reading, or false | ||||||
|    (0) if file is a gzip stream being decompressed. |    (0) if file is a gzip stream being decompressed. | ||||||
| @@ -1628,7 +1631,7 @@ ZEXTERN int ZEXPORT gzdirect OF((gzFile file)); | |||||||
|    gzip file reading and decompression, which may not be desired.) |    gzip file reading and decompression, which may not be desired.) | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT    gzclose OF((gzFile file)); | ZEXTERN int ZEXPORT    gzclose(gzFile file); | ||||||
| /* | /* | ||||||
|      Flush all pending output for file, if necessary, close file and |      Flush all pending output for file, if necessary, close file and | ||||||
|    deallocate the (de)compression state.  Note that once file is closed, you |    deallocate the (de)compression state.  Note that once file is closed, you | ||||||
| @@ -1641,8 +1644,8 @@ ZEXTERN int ZEXPORT    gzclose OF((gzFile file)); | |||||||
|    last read ended in the middle of a gzip stream, or Z_OK on success. |    last read ended in the middle of a gzip stream, or Z_OK on success. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN int ZEXPORT gzclose_r OF((gzFile file)); | ZEXTERN int ZEXPORT gzclose_r(gzFile file); | ||||||
| ZEXTERN int ZEXPORT gzclose_w OF((gzFile file)); | ZEXTERN int ZEXPORT gzclose_w(gzFile file); | ||||||
| /* | /* | ||||||
|      Same as gzclose(), but gzclose_r() is only for use when reading, and |      Same as gzclose(), but gzclose_r() is only for use when reading, and | ||||||
|    gzclose_w() is only for use when writing or appending.  The advantage to |    gzclose_w() is only for use when writing or appending.  The advantage to | ||||||
| @@ -1653,7 +1656,7 @@ ZEXTERN int ZEXPORT gzclose_w OF((gzFile file)); | |||||||
|    zlib library. |    zlib library. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN const char * ZEXPORT gzerror OF((gzFile file, int *errnum)); | ZEXTERN const char * ZEXPORT gzerror(gzFile file, int *errnum); | ||||||
| /* | /* | ||||||
|      Return the error message for the last error which occurred on file. |      Return the error message for the last error which occurred on file. | ||||||
|    errnum is set to zlib error number.  If an error occurred in the file system |    errnum is set to zlib error number.  If an error occurred in the file system | ||||||
| @@ -1669,7 +1672,7 @@ ZEXTERN const char * ZEXPORT gzerror OF((gzFile file, int *errnum)); | |||||||
|    functions above that do not distinguish those cases in their return values. |    functions above that do not distinguish those cases in their return values. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN void ZEXPORT gzclearerr OF((gzFile file)); | ZEXTERN void ZEXPORT gzclearerr(gzFile file); | ||||||
| /* | /* | ||||||
|      Clear the error and end-of-file flags for file.  This is analogous to the |      Clear the error and end-of-file flags for file.  This is analogous to the | ||||||
|    clearerr() function in stdio.  This is useful for continuing to read a gzip |    clearerr() function in stdio.  This is useful for continuing to read a gzip | ||||||
| @@ -1686,7 +1689,7 @@ ZEXTERN void ZEXPORT gzclearerr OF((gzFile file)); | |||||||
|    library. |    library. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT adler32 OF((uLong adler, const Bytef *buf, uInt len)); | ZEXTERN uLong ZEXPORT adler32(uLong adler, const Bytef *buf, uInt len); | ||||||
| /* | /* | ||||||
|      Update a running Adler-32 checksum with the bytes buf[0..len-1] and |      Update a running Adler-32 checksum with the bytes buf[0..len-1] and | ||||||
|    return the updated checksum. An Adler-32 value is in the range of a 32-bit |    return the updated checksum. An Adler-32 value is in the range of a 32-bit | ||||||
| @@ -1706,15 +1709,15 @@ ZEXTERN uLong ZEXPORT adler32 OF((uLong adler, const Bytef *buf, uInt len)); | |||||||
|      if (adler != original_adler) error(); |      if (adler != original_adler) error(); | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT adler32_z OF((uLong adler, const Bytef *buf, | ZEXTERN uLong ZEXPORT adler32_z(uLong adler, const Bytef *buf, | ||||||
|                                     z_size_t len)); |                                 z_size_t len); | ||||||
| /* | /* | ||||||
|      Same as adler32(), but with a size_t length. |      Same as adler32(), but with a size_t length. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN uLong ZEXPORT adler32_combine OF((uLong adler1, uLong adler2, | ZEXTERN uLong ZEXPORT adler32_combine(uLong adler1, uLong adler2, | ||||||
|                                           z_off_t len2)); |                                       z_off_t len2); | ||||||
|  |  | ||||||
|      Combine two Adler-32 checksums into one.  For two sequences of bytes, seq1 |      Combine two Adler-32 checksums into one.  For two sequences of bytes, seq1 | ||||||
|    and seq2 with lengths len1 and len2, Adler-32 checksums were calculated for |    and seq2 with lengths len1 and len2, Adler-32 checksums were calculated for | ||||||
| @@ -1724,7 +1727,7 @@ ZEXTERN uLong ZEXPORT adler32_combine OF((uLong adler1, uLong adler2, | |||||||
|    negative, the result has no meaning or utility. |    negative, the result has no meaning or utility. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT crc32 OF((uLong crc, const Bytef *buf, uInt len)); | ZEXTERN uLong ZEXPORT crc32(uLong crc, const Bytef *buf, uInt len); | ||||||
| /* | /* | ||||||
|      Update a running CRC-32 with the bytes buf[0..len-1] and return the |      Update a running CRC-32 with the bytes buf[0..len-1] and return the | ||||||
|    updated CRC-32. A CRC-32 value is in the range of a 32-bit unsigned integer. |    updated CRC-32. A CRC-32 value is in the range of a 32-bit unsigned integer. | ||||||
| @@ -1742,14 +1745,14 @@ ZEXTERN uLong ZEXPORT crc32 OF((uLong crc, const Bytef *buf, uInt len)); | |||||||
|      if (crc != original_crc) error(); |      if (crc != original_crc) error(); | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT crc32_z OF((uLong crc, const Bytef *buf, | ZEXTERN uLong ZEXPORT crc32_z(uLong crc, const Bytef *buf, | ||||||
|                                   z_size_t len)); |                               z_size_t len); | ||||||
| /* | /* | ||||||
|      Same as crc32(), but with a size_t length. |      Same as crc32(), but with a size_t length. | ||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN uLong ZEXPORT crc32_combine OF((uLong crc1, uLong crc2, z_off_t len2)); | ZEXTERN uLong ZEXPORT crc32_combine(uLong crc1, uLong crc2, z_off_t len2); | ||||||
|  |  | ||||||
|      Combine two CRC-32 check values into one.  For two sequences of bytes, |      Combine two CRC-32 check values into one.  For two sequences of bytes, | ||||||
|    seq1 and seq2 with lengths len1 and len2, CRC-32 check values were |    seq1 and seq2 with lengths len1 and len2, CRC-32 check values were | ||||||
| @@ -1759,13 +1762,13 @@ ZEXTERN uLong ZEXPORT crc32_combine OF((uLong crc1, uLong crc2, z_off_t len2)); | |||||||
| */ | */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
| ZEXTERN uLong ZEXPORT crc32_combine_gen OF((z_off_t len2)); | ZEXTERN uLong ZEXPORT crc32_combine_gen(z_off_t len2); | ||||||
|  |  | ||||||
|      Return the operator corresponding to length len2, to be used with |      Return the operator corresponding to length len2, to be used with | ||||||
|    crc32_combine_op(). |    crc32_combine_op(). | ||||||
| */ | */ | ||||||
|  |  | ||||||
| ZEXTERN uLong ZEXPORT crc32_combine_op OF((uLong crc1, uLong crc2, uLong op)); | ZEXTERN uLong ZEXPORT crc32_combine_op(uLong crc1, uLong crc2, uLong op); | ||||||
| /* | /* | ||||||
|      Give the same result as crc32_combine(), using op in place of len2. op is |      Give the same result as crc32_combine(), using op in place of len2. op is | ||||||
|    is generated from len2 by crc32_combine_gen(). This will be faster than |    is generated from len2 by crc32_combine_gen(). This will be faster than | ||||||
| @@ -1778,20 +1781,20 @@ ZEXTERN uLong ZEXPORT crc32_combine_op OF((uLong crc1, uLong crc2, uLong op)); | |||||||
| /* deflateInit and inflateInit are macros to allow checking the zlib version | /* deflateInit and inflateInit are macros to allow checking the zlib version | ||||||
|  * and the compiler's view of z_stream: |  * and the compiler's view of z_stream: | ||||||
|  */ |  */ | ||||||
| ZEXTERN int ZEXPORT deflateInit_ OF((z_streamp strm, int level, | ZEXTERN int ZEXPORT deflateInit_(z_streamp strm, int level, | ||||||
|                                      const char *version, int stream_size)); |                                  const char *version, int stream_size); | ||||||
| ZEXTERN int ZEXPORT inflateInit_ OF((z_streamp strm, | ZEXTERN int ZEXPORT inflateInit_(z_streamp strm, | ||||||
|                                      const char *version, int stream_size)); |                                  const char *version, int stream_size); | ||||||
| ZEXTERN int ZEXPORT deflateInit2_ OF((z_streamp strm, int  level, int  method, | ZEXTERN int ZEXPORT deflateInit2_(z_streamp strm, int  level, int  method, | ||||||
|                                       int windowBits, int memLevel, |                                   int windowBits, int memLevel, | ||||||
|                                       int strategy, const char *version, |                                   int strategy, const char *version, | ||||||
|                                       int stream_size)); |                                   int stream_size); | ||||||
| ZEXTERN int ZEXPORT inflateInit2_ OF((z_streamp strm, int  windowBits, | ZEXTERN int ZEXPORT inflateInit2_(z_streamp strm, int  windowBits, | ||||||
|                                       const char *version, int stream_size)); |                                   const char *version, int stream_size); | ||||||
| ZEXTERN int ZEXPORT inflateBackInit_ OF((z_streamp strm, int windowBits, | ZEXTERN int ZEXPORT inflateBackInit_(z_streamp strm, int windowBits, | ||||||
|                                          unsigned char FAR *window, |                                      unsigned char FAR *window, | ||||||
|                                          const char *version, |                                      const char *version, | ||||||
|                                          int stream_size)); |                                      int stream_size); | ||||||
| #ifdef Z_PREFIX_SET | #ifdef Z_PREFIX_SET | ||||||
| #  define z_deflateInit(strm, level) \ | #  define z_deflateInit(strm, level) \ | ||||||
|           deflateInit_((strm), (level), ZLIB_VERSION, (int)sizeof(z_stream)) |           deflateInit_((strm), (level), ZLIB_VERSION, (int)sizeof(z_stream)) | ||||||
| @@ -1836,7 +1839,7 @@ struct gzFile_s { | |||||||
|     unsigned char *next; |     unsigned char *next; | ||||||
|     z_off64_t pos; |     z_off64_t pos; | ||||||
| }; | }; | ||||||
| ZEXTERN int ZEXPORT gzgetc_ OF((gzFile file));  /* backward compatibility */ | ZEXTERN int ZEXPORT gzgetc_(gzFile file);       /* backward compatibility */ | ||||||
| #ifdef Z_PREFIX_SET | #ifdef Z_PREFIX_SET | ||||||
| #  undef z_gzgetc | #  undef z_gzgetc | ||||||
| #  define z_gzgetc(g) \ | #  define z_gzgetc(g) \ | ||||||
| @@ -1853,13 +1856,13 @@ ZEXTERN int ZEXPORT gzgetc_ OF((gzFile file));  /* backward compatibility */ | |||||||
|  * without large file support, _LFS64_LARGEFILE must also be true |  * without large file support, _LFS64_LARGEFILE must also be true | ||||||
|  */ |  */ | ||||||
| #ifdef Z_LARGE64 | #ifdef Z_LARGE64 | ||||||
|    ZEXTERN gzFile ZEXPORT gzopen64 OF((const char *, const char *)); |    ZEXTERN gzFile ZEXPORT gzopen64(const char *, const char *); | ||||||
|    ZEXTERN z_off64_t ZEXPORT gzseek64 OF((gzFile, z_off64_t, int)); |    ZEXTERN z_off64_t ZEXPORT gzseek64(gzFile, z_off64_t, int); | ||||||
|    ZEXTERN z_off64_t ZEXPORT gztell64 OF((gzFile)); |    ZEXTERN z_off64_t ZEXPORT gztell64(gzFile); | ||||||
|    ZEXTERN z_off64_t ZEXPORT gzoffset64 OF((gzFile)); |    ZEXTERN z_off64_t ZEXPORT gzoffset64(gzFile); | ||||||
|    ZEXTERN uLong ZEXPORT adler32_combine64 OF((uLong, uLong, z_off64_t)); |    ZEXTERN uLong ZEXPORT adler32_combine64(uLong, uLong, z_off64_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine64 OF((uLong, uLong, z_off64_t)); |    ZEXTERN uLong ZEXPORT crc32_combine64(uLong, uLong, z_off64_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine_gen64 OF((z_off64_t)); |    ZEXTERN uLong ZEXPORT crc32_combine_gen64(z_off64_t); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #if !defined(ZLIB_INTERNAL) && defined(Z_WANT64) | #if !defined(ZLIB_INTERNAL) && defined(Z_WANT64) | ||||||
| @@ -1881,50 +1884,50 @@ ZEXTERN int ZEXPORT gzgetc_ OF((gzFile file));  /* backward compatibility */ | |||||||
| #    define crc32_combine_gen crc32_combine_gen64 | #    define crc32_combine_gen crc32_combine_gen64 | ||||||
| #  endif | #  endif | ||||||
| #  ifndef Z_LARGE64 | #  ifndef Z_LARGE64 | ||||||
|      ZEXTERN gzFile ZEXPORT gzopen64 OF((const char *, const char *)); |      ZEXTERN gzFile ZEXPORT gzopen64(const char *, const char *); | ||||||
|      ZEXTERN z_off_t ZEXPORT gzseek64 OF((gzFile, z_off_t, int)); |      ZEXTERN z_off_t ZEXPORT gzseek64(gzFile, z_off_t, int); | ||||||
|      ZEXTERN z_off_t ZEXPORT gztell64 OF((gzFile)); |      ZEXTERN z_off_t ZEXPORT gztell64(gzFile); | ||||||
|      ZEXTERN z_off_t ZEXPORT gzoffset64 OF((gzFile)); |      ZEXTERN z_off_t ZEXPORT gzoffset64(gzFile); | ||||||
|      ZEXTERN uLong ZEXPORT adler32_combine64 OF((uLong, uLong, z_off_t)); |      ZEXTERN uLong ZEXPORT adler32_combine64(uLong, uLong, z_off_t); | ||||||
|      ZEXTERN uLong ZEXPORT crc32_combine64 OF((uLong, uLong, z_off_t)); |      ZEXTERN uLong ZEXPORT crc32_combine64(uLong, uLong, z_off_t); | ||||||
|      ZEXTERN uLong ZEXPORT crc32_combine_gen64 OF((z_off_t)); |      ZEXTERN uLong ZEXPORT crc32_combine_gen64(z_off_t); | ||||||
| #  endif | #  endif | ||||||
| #else | #else | ||||||
|    ZEXTERN gzFile ZEXPORT gzopen OF((const char *, const char *)); |    ZEXTERN gzFile ZEXPORT gzopen(const char *, const char *); | ||||||
|    ZEXTERN z_off_t ZEXPORT gzseek OF((gzFile, z_off_t, int)); |    ZEXTERN z_off_t ZEXPORT gzseek(gzFile, z_off_t, int); | ||||||
|    ZEXTERN z_off_t ZEXPORT gztell OF((gzFile)); |    ZEXTERN z_off_t ZEXPORT gztell(gzFile); | ||||||
|    ZEXTERN z_off_t ZEXPORT gzoffset OF((gzFile)); |    ZEXTERN z_off_t ZEXPORT gzoffset(gzFile); | ||||||
|    ZEXTERN uLong ZEXPORT adler32_combine OF((uLong, uLong, z_off_t)); |    ZEXTERN uLong ZEXPORT adler32_combine(uLong, uLong, z_off_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine OF((uLong, uLong, z_off_t)); |    ZEXTERN uLong ZEXPORT crc32_combine(uLong, uLong, z_off_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine_gen OF((z_off_t)); |    ZEXTERN uLong ZEXPORT crc32_combine_gen(z_off_t); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #else /* Z_SOLO */ | #else /* Z_SOLO */ | ||||||
|  |  | ||||||
|    ZEXTERN uLong ZEXPORT adler32_combine OF((uLong, uLong, z_off_t)); |    ZEXTERN uLong ZEXPORT adler32_combine(uLong, uLong, z_off_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine OF((uLong, uLong, z_off_t)); |    ZEXTERN uLong ZEXPORT crc32_combine(uLong, uLong, z_off_t); | ||||||
|    ZEXTERN uLong ZEXPORT crc32_combine_gen OF((z_off_t)); |    ZEXTERN uLong ZEXPORT crc32_combine_gen(z_off_t); | ||||||
|  |  | ||||||
| #endif /* !Z_SOLO */ | #endif /* !Z_SOLO */ | ||||||
|  |  | ||||||
| /* undocumented functions */ | /* undocumented functions */ | ||||||
| ZEXTERN const char   * ZEXPORT zError           OF((int)); | ZEXTERN const char   * ZEXPORT zError(int); | ||||||
| ZEXTERN int            ZEXPORT inflateSyncPoint OF((z_streamp)); | ZEXTERN int            ZEXPORT inflateSyncPoint(z_streamp); | ||||||
| ZEXTERN const z_crc_t FAR * ZEXPORT get_crc_table    OF((void)); | ZEXTERN const z_crc_t FAR * ZEXPORT get_crc_table(void); | ||||||
| ZEXTERN int            ZEXPORT inflateUndermine OF((z_streamp, int)); | ZEXTERN int            ZEXPORT inflateUndermine(z_streamp, int); | ||||||
| ZEXTERN int            ZEXPORT inflateValidate OF((z_streamp, int)); | ZEXTERN int            ZEXPORT inflateValidate(z_streamp, int); | ||||||
| ZEXTERN unsigned long  ZEXPORT inflateCodesUsed OF((z_streamp)); | ZEXTERN unsigned long  ZEXPORT inflateCodesUsed(z_streamp); | ||||||
| ZEXTERN int            ZEXPORT inflateResetKeep OF((z_streamp)); | ZEXTERN int            ZEXPORT inflateResetKeep(z_streamp); | ||||||
| ZEXTERN int            ZEXPORT deflateResetKeep OF((z_streamp)); | ZEXTERN int            ZEXPORT deflateResetKeep(z_streamp); | ||||||
| #if defined(_WIN32) && !defined(Z_SOLO) | #if defined(_WIN32) && !defined(Z_SOLO) | ||||||
| ZEXTERN gzFile         ZEXPORT gzopen_w OF((const wchar_t *path, | ZEXTERN gzFile         ZEXPORT gzopen_w(const wchar_t *path, | ||||||
|                                             const char *mode)); |                                         const char *mode); | ||||||
| #endif | #endif | ||||||
| #if defined(STDC) || defined(Z_HAVE_STDARG_H) | #if defined(STDC) || defined(Z_HAVE_STDARG_H) | ||||||
| #  ifndef Z_SOLO | #  ifndef Z_SOLO | ||||||
| ZEXTERN int            ZEXPORTVA gzvprintf Z_ARG((gzFile file, | ZEXTERN int            ZEXPORTVA gzvprintf(gzFile file, | ||||||
|                                                   const char *format, |                                            const char *format, | ||||||
|                                                   va_list va)); |                                            va_list va); | ||||||
| #  endif | #  endif | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   | |||||||
| @@ -24,13 +24,11 @@ z_const char * const z_errmsg[10] = { | |||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| const char * ZEXPORT zlibVersion() | const char * ZEXPORT zlibVersion(void) { | ||||||
| { |  | ||||||
|     return ZLIB_VERSION; |     return ZLIB_VERSION; | ||||||
| } | } | ||||||
|  |  | ||||||
| uLong ZEXPORT zlibCompileFlags() | uLong ZEXPORT zlibCompileFlags(void) { | ||||||
| { |  | ||||||
|     uLong flags; |     uLong flags; | ||||||
|  |  | ||||||
|     flags = 0; |     flags = 0; | ||||||
| @@ -121,9 +119,7 @@ uLong ZEXPORT zlibCompileFlags() | |||||||
| #  endif | #  endif | ||||||
| int ZLIB_INTERNAL z_verbose = verbose; | int ZLIB_INTERNAL z_verbose = verbose; | ||||||
|  |  | ||||||
| void ZLIB_INTERNAL z_error(m) | void ZLIB_INTERNAL z_error(char *m) { | ||||||
|     char *m; |  | ||||||
| { |  | ||||||
|     fprintf(stderr, "%s\n", m); |     fprintf(stderr, "%s\n", m); | ||||||
|     exit(1); |     exit(1); | ||||||
| } | } | ||||||
| @@ -132,9 +128,7 @@ void ZLIB_INTERNAL z_error(m) | |||||||
| /* exported to allow conversion of error code to string for compress() and | /* exported to allow conversion of error code to string for compress() and | ||||||
|  * uncompress() |  * uncompress() | ||||||
|  */ |  */ | ||||||
| const char * ZEXPORT zError(err) | const char * ZEXPORT zError(int err) { | ||||||
|     int err; |  | ||||||
| { |  | ||||||
|     return ERR_MSG(err); |     return ERR_MSG(err); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -148,22 +142,14 @@ const char * ZEXPORT zError(err) | |||||||
|  |  | ||||||
| #ifndef HAVE_MEMCPY | #ifndef HAVE_MEMCPY | ||||||
|  |  | ||||||
| void ZLIB_INTERNAL zmemcpy(dest, source, len) | void ZLIB_INTERNAL zmemcpy(Bytef* dest, const Bytef* source, uInt len) { | ||||||
|     Bytef* dest; |  | ||||||
|     const Bytef* source; |  | ||||||
|     uInt  len; |  | ||||||
| { |  | ||||||
|     if (len == 0) return; |     if (len == 0) return; | ||||||
|     do { |     do { | ||||||
|         *dest++ = *source++; /* ??? to be unrolled */ |         *dest++ = *source++; /* ??? to be unrolled */ | ||||||
|     } while (--len != 0); |     } while (--len != 0); | ||||||
| } | } | ||||||
|  |  | ||||||
| int ZLIB_INTERNAL zmemcmp(s1, s2, len) | int ZLIB_INTERNAL zmemcmp(const Bytef* s1, const Bytef* s2, uInt len) { | ||||||
|     const Bytef* s1; |  | ||||||
|     const Bytef* s2; |  | ||||||
|     uInt  len; |  | ||||||
| { |  | ||||||
|     uInt j; |     uInt j; | ||||||
|  |  | ||||||
|     for (j = 0; j < len; j++) { |     for (j = 0; j < len; j++) { | ||||||
| @@ -172,10 +158,7 @@ int ZLIB_INTERNAL zmemcmp(s1, s2, len) | |||||||
|     return 0; |     return 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| void ZLIB_INTERNAL zmemzero(dest, len) | void ZLIB_INTERNAL zmemzero(Bytef* dest, uInt len) { | ||||||
|     Bytef* dest; |  | ||||||
|     uInt  len; |  | ||||||
| { |  | ||||||
|     if (len == 0) return; |     if (len == 0) return; | ||||||
|     do { |     do { | ||||||
|         *dest++ = 0;  /* ??? to be unrolled */ |         *dest++ = 0;  /* ??? to be unrolled */ | ||||||
| @@ -216,8 +199,7 @@ local ptr_table table[MAX_PTR]; | |||||||
|  * a protected system like OS/2. Use Microsoft C instead. |  * a protected system like OS/2. Use Microsoft C instead. | ||||||
|  */ |  */ | ||||||
|  |  | ||||||
| voidpf ZLIB_INTERNAL zcalloc(voidpf opaque, unsigned items, unsigned size) | voidpf ZLIB_INTERNAL zcalloc(voidpf opaque, unsigned items, unsigned size) { | ||||||
| { |  | ||||||
|     voidpf buf; |     voidpf buf; | ||||||
|     ulg bsize = (ulg)items*size; |     ulg bsize = (ulg)items*size; | ||||||
|  |  | ||||||
| @@ -242,8 +224,7 @@ voidpf ZLIB_INTERNAL zcalloc(voidpf opaque, unsigned items, unsigned size) | |||||||
|     return buf; |     return buf; | ||||||
| } | } | ||||||
|  |  | ||||||
| void ZLIB_INTERNAL zcfree(voidpf opaque, voidpf ptr) | void ZLIB_INTERNAL zcfree(voidpf opaque, voidpf ptr) { | ||||||
| { |  | ||||||
|     int n; |     int n; | ||||||
|  |  | ||||||
|     (void)opaque; |     (void)opaque; | ||||||
| @@ -279,14 +260,12 @@ void ZLIB_INTERNAL zcfree(voidpf opaque, voidpf ptr) | |||||||
| #  define _hfree   hfree | #  define _hfree   hfree | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| voidpf ZLIB_INTERNAL zcalloc(voidpf opaque, uInt items, uInt size) | voidpf ZLIB_INTERNAL zcalloc(voidpf opaque, uInt items, uInt size) { | ||||||
| { |  | ||||||
|     (void)opaque; |     (void)opaque; | ||||||
|     return _halloc((long)items, size); |     return _halloc((long)items, size); | ||||||
| } | } | ||||||
|  |  | ||||||
| void ZLIB_INTERNAL zcfree(voidpf opaque, voidpf ptr) | void ZLIB_INTERNAL zcfree(voidpf opaque, voidpf ptr) { | ||||||
| { |  | ||||||
|     (void)opaque; |     (void)opaque; | ||||||
|     _hfree(ptr); |     _hfree(ptr); | ||||||
| } | } | ||||||
| @@ -299,25 +278,18 @@ void ZLIB_INTERNAL zcfree(voidpf opaque, voidpf ptr) | |||||||
| #ifndef MY_ZCALLOC /* Any system without a special alloc function */ | #ifndef MY_ZCALLOC /* Any system without a special alloc function */ | ||||||
|  |  | ||||||
| #ifndef STDC | #ifndef STDC | ||||||
| extern voidp  malloc OF((uInt size)); | extern voidp malloc(uInt size); | ||||||
| extern voidp  calloc OF((uInt items, uInt size)); | extern voidp calloc(uInt items, uInt size); | ||||||
| extern void   free   OF((voidpf ptr)); | extern void free(voidpf ptr); | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| voidpf ZLIB_INTERNAL zcalloc(opaque, items, size) | voidpf ZLIB_INTERNAL zcalloc(voidpf opaque, unsigned items, unsigned size) { | ||||||
|     voidpf opaque; |  | ||||||
|     unsigned items; |  | ||||||
|     unsigned size; |  | ||||||
| { |  | ||||||
|     (void)opaque; |     (void)opaque; | ||||||
|     return sizeof(uInt) > 2 ? (voidpf)malloc(items * size) : |     return sizeof(uInt) > 2 ? (voidpf)malloc(items * size) : | ||||||
|                               (voidpf)calloc(items, size); |                               (voidpf)calloc(items, size); | ||||||
| } | } | ||||||
|  |  | ||||||
| void ZLIB_INTERNAL zcfree(opaque, ptr) | void ZLIB_INTERNAL zcfree(voidpf opaque, voidpf ptr) { | ||||||
|     voidpf opaque; |  | ||||||
|     voidpf ptr; |  | ||||||
| { |  | ||||||
|     (void)opaque; |     (void)opaque; | ||||||
|     free(ptr); |     free(ptr); | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Günter Obiltschnig
					Günter Obiltschnig