mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-26 02:18:04 +01:00 
			
		
		
		
	SF# 3190723 - fixed zlib 1.2.5, but only for trunk, because of some new/deleted files and possible project files unconsitencies (plain Makefile and cmake scripts are fixed and OK)
This commit is contained in:
		| @@ -145,7 +145,11 @@ set( BASE_SRCS | ||||
|   src/compress.c | ||||
|   src/crc32.c | ||||
|   src/deflate.c | ||||
|   src/gzio.c | ||||
|   src/gzclose.c | ||||
|   src/gzlib.c | ||||
|   src/gzread.c | ||||
|   src/gzwrite.c | ||||
|   src/uncompr.c | ||||
|   src/infback.c | ||||
|   src/inffast.c | ||||
|   src/inflate.c | ||||
|   | ||||
| @@ -31,7 +31,7 @@ objects = ArchiveStrategy ASCIIEncoding AsyncChannel Base64Decoder Base64Encoder | ||||
| 	FileStreamFactory URIStreamFactory URIStreamOpener UTF16Encoding Windows1250Encoding Windows1251Encoding Windows1252Encoding \ | ||||
| 	UTF8Encoding UnicodeConverter UUID UUIDGenerator Var VarHolder Void Format \ | ||||
| 	Pipe PipeImpl PipeStream SharedMemory FileStream Unicode UTF8String \ | ||||
| 	adler32 compress crc32 deflate gzio infback inffast inflate inftrees trees zutil \ | ||||
| 	adler32 compress crc32 deflate gclose gzlib gzread gzwrite infback inffast inflate inftrees trees uncompr zutil \ | ||||
| 	pcre_chartables pcre_compile pcre_globals pcre_maketables pcre_study \ | ||||
| 	pcre_tables pcre_try_flipped pcre_ucd pcre_valid_utf8 \ | ||||
| 	pcre_exec pcre_ord2utf8 pcre_newline pcre_fullinfo pcre_xclass | ||||
|   | ||||
| @@ -1,12 +1,15 @@ | ||||
| /* adler32.c -- compute the Adler-32 checksum of a data stream | ||||
|  * Copyright (C) 1995-2004 Mark Adler | ||||
|  * Copyright (C) 1995-2007 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| /* @(#) $Id$ */ | ||||
|  | ||||
| #define ZLIB_INTERNAL | ||||
| #include "zlib.h" | ||||
| #include "zutil.h" | ||||
|  | ||||
| #define local static | ||||
|  | ||||
| local uLong adler32_combine_(uLong adler1, uLong adler2, z_off64_t len2); | ||||
|  | ||||
| #define BASE 65521UL    /* largest prime smaller than 65536 */ | ||||
| #define NMAX 5552 | ||||
| @@ -125,10 +128,10 @@ uLong ZEXPORT adler32(adler, buf, len) | ||||
| } | ||||
|  | ||||
| /* ========================================================================= */ | ||||
| uLong ZEXPORT adler32_combine(adler1, adler2, len2) | ||||
| local uLong adler32_combine_(adler1, adler2, len2) | ||||
|     uLong adler1; | ||||
|     uLong adler2; | ||||
|     z_off_t len2; | ||||
|     z_off64_t len2; | ||||
| { | ||||
|     unsigned long sum1; | ||||
|     unsigned long sum2; | ||||
| @@ -141,9 +144,26 @@ uLong ZEXPORT adler32_combine(adler1, adler2, len2) | ||||
|     MOD(sum2); | ||||
|     sum1 += (adler2 & 0xffff) + BASE - 1; | ||||
|     sum2 += ((adler1 >> 16) & 0xffff) + ((adler2 >> 16) & 0xffff) + BASE - rem; | ||||
|     if (sum1 > BASE) sum1 -= BASE; | ||||
|     if (sum1 > BASE) sum1 -= BASE; | ||||
|     if (sum2 > (BASE << 1)) sum2 -= (BASE << 1); | ||||
|     if (sum2 > BASE) sum2 -= BASE; | ||||
|     if (sum1 >= BASE) sum1 -= BASE; | ||||
|     if (sum1 >= BASE) sum1 -= BASE; | ||||
|     if (sum2 >= (BASE << 1)) sum2 -= (BASE << 1); | ||||
|     if (sum2 >= BASE) sum2 -= BASE; | ||||
|     return sum1 | (sum2 << 16); | ||||
| } | ||||
|  | ||||
| /* ========================================================================= */ | ||||
| uLong ZEXPORT adler32_combine(adler1, adler2, len2) | ||||
|     uLong adler1; | ||||
|     uLong adler2; | ||||
|     z_off_t len2; | ||||
| { | ||||
|     return adler32_combine_(adler1, adler2, len2); | ||||
| } | ||||
|  | ||||
| uLong ZEXPORT adler32_combine64(adler1, adler2, len2) | ||||
|     uLong adler1; | ||||
|     uLong adler2; | ||||
|     z_off64_t len2; | ||||
| { | ||||
|     return adler32_combine_(adler1, adler2, len2); | ||||
| } | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| /* compress.c -- compress a memory buffer | ||||
|  * Copyright (C) 1995-2003 Jean-loup Gailly. | ||||
|  * Copyright (C) 1995-2005 Jean-loup Gailly. | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| /* @(#) $Id: //poco/svn/Foundation/src/compress.c#2 $ */ | ||||
| /* @(#) $Id$ */ | ||||
|  | ||||
| #define ZLIB_INTERNAL | ||||
| #include "zlib.h" | ||||
| @@ -75,5 +75,6 @@ int ZEXPORT compress (dest, destLen, source, sourceLen) | ||||
| uLong ZEXPORT compressBound (sourceLen) | ||||
|     uLong sourceLen; | ||||
| { | ||||
|     return sourceLen + (sourceLen >> 12) + (sourceLen >> 14) + 11; | ||||
|     return sourceLen + (sourceLen >> 12) + (sourceLen >> 14) + | ||||
|            (sourceLen >> 25) + 13; | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* crc32.c -- compute the CRC-32 of a data stream | ||||
|  * Copyright (C) 1995-2005 Mark Adler | ||||
|  * Copyright (C) 1995-2006, 2010 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  * | ||||
|  * Thanks to Rodney Brown <rbrown64@csc.com.au> for his contribution of faster | ||||
| @@ -9,7 +9,7 @@ | ||||
|  * factor of two increase in speed on a Power PC G4 (PPC7455) using gcc -O3. | ||||
|  */ | ||||
|  | ||||
| /* @(#) $Id: //poco/svn/Foundation/src/crc32.c#2 $ */ | ||||
| /* @(#) $Id$ */ | ||||
|  | ||||
| /* | ||||
|   Note on the use of DYNAMIC_CRC_TABLE: there is no mutex or semaphore | ||||
| @@ -53,7 +53,7 @@ | ||||
|  | ||||
| /* Definitions for doing the crc four data bytes at a time. */ | ||||
| #ifdef BYFOUR | ||||
| #  define REV(w) (((w)>>24)+(((w)>>8)&0xff00)+ \ | ||||
| #  define REV(w) ((((w)>>24)&0xff)+(((w)>>8)&0xff00)+ \ | ||||
|                 (((w)&0xff00)<<8)+(((w)&0xff)<<24)) | ||||
|    local unsigned long crc32_little OF((unsigned long, | ||||
|                         const unsigned char FAR *, unsigned)); | ||||
| @@ -68,6 +68,8 @@ | ||||
| local unsigned long gf2_matrix_times OF((unsigned long *mat, | ||||
|                                          unsigned long vec)); | ||||
| local void gf2_matrix_square OF((unsigned long *square, unsigned long *mat)); | ||||
| local uLong crc32_combine_(uLong crc1, uLong crc2, z_off64_t len2); | ||||
|  | ||||
|  | ||||
| #ifdef DYNAMIC_CRC_TABLE | ||||
|  | ||||
| @@ -219,7 +221,7 @@ const unsigned long FAR * ZEXPORT get_crc_table() | ||||
| unsigned long ZEXPORT crc32(crc, buf, len) | ||||
|     unsigned long crc; | ||||
|     const unsigned char FAR *buf; | ||||
|     unsigned len; | ||||
|     uInt len; | ||||
| { | ||||
|     if (buf == Z_NULL) return 0UL; | ||||
|  | ||||
| @@ -367,22 +369,22 @@ local void gf2_matrix_square(square, mat) | ||||
| } | ||||
|  | ||||
| /* ========================================================================= */ | ||||
| uLong ZEXPORT crc32_combine(crc1, crc2, len2) | ||||
| local uLong crc32_combine_(crc1, crc2, len2) | ||||
|     uLong crc1; | ||||
|     uLong crc2; | ||||
|     z_off_t len2; | ||||
|     z_off64_t len2; | ||||
| { | ||||
|     int n; | ||||
|     unsigned long row; | ||||
|     unsigned long even[GF2_DIM];    /* even-power-of-two zeros operator */ | ||||
|     unsigned long odd[GF2_DIM];     /* odd-power-of-two zeros operator */ | ||||
|  | ||||
|     /* degenerate case */ | ||||
|     if (len2 == 0) | ||||
|     /* degenerate case (also disallow negative lengths) */ | ||||
|     if (len2 <= 0) | ||||
|         return crc1; | ||||
|  | ||||
|     /* put operator for one zero bit in odd */ | ||||
|     odd[0] = 0xedb88320L;           /* CRC-32 polynomial */ | ||||
|     odd[0] = 0xedb88320UL;          /* CRC-32 polynomial */ | ||||
|     row = 1; | ||||
|     for (n = 1; n < GF2_DIM; n++) { | ||||
|         odd[n] = row; | ||||
| @@ -421,3 +423,20 @@ uLong ZEXPORT crc32_combine(crc1, crc2, len2) | ||||
|     crc1 ^= crc2; | ||||
|     return crc1; | ||||
| } | ||||
|  | ||||
| /* ========================================================================= */ | ||||
| uLong ZEXPORT crc32_combine(crc1, crc2, len2) | ||||
|     uLong crc1; | ||||
|     uLong crc2; | ||||
|     z_off_t len2; | ||||
| { | ||||
|     return crc32_combine_(crc1, crc2, len2); | ||||
| } | ||||
|  | ||||
| uLong ZEXPORT crc32_combine64(crc1, crc2, len2) | ||||
|     uLong crc1; | ||||
|     uLong crc2; | ||||
|     z_off64_t len2; | ||||
| { | ||||
|     return crc32_combine_(crc1, crc2, len2); | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* deflate.c -- compress data using the deflation algorithm | ||||
|  * Copyright (C) 1995-2005 Jean-loup Gailly. | ||||
|  * Copyright (C) 1995-2010 Jean-loup Gailly and Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| @@ -47,12 +47,12 @@ | ||||
|  * | ||||
|  */ | ||||
|  | ||||
| /* @(#) $Id: //poco/svn/Foundation/src/deflate.c#2 $ */ | ||||
| /* @(#) $Id$ */ | ||||
|  | ||||
| #include "deflate.h" | ||||
|  | ||||
| const char deflate_copyright[] = | ||||
|    " deflate 1.2.3 Copyright 1995-2005 Jean-loup Gailly "; | ||||
|    " deflate 1.2.5 Copyright 1995-2010 Jean-loup Gailly and Mark Adler "; | ||||
| /* | ||||
|   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 | ||||
| @@ -79,19 +79,18 @@ local block_state deflate_fast   OF((deflate_state *s, int flush)); | ||||
| #ifndef FASTEST | ||||
| local block_state deflate_slow   OF((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 int read_buf        OF((z_streamp strm, Bytef *buf, unsigned size)); | ||||
| #ifndef FASTEST | ||||
| #ifdef ASMV | ||||
|       void match_init OF((void)); /* asm code initialization */ | ||||
|       uInt longest_match  OF((deflate_state *s, IPos cur_match)); | ||||
| #else | ||||
| local uInt longest_match  OF((deflate_state *s, IPos cur_match)); | ||||
| #endif | ||||
| #endif | ||||
| local uInt longest_match_fast OF((deflate_state *s, IPos cur_match)); | ||||
|  | ||||
| #ifdef DEBUG | ||||
| local  void check_match OF((deflate_state *s, IPos start, IPos match, | ||||
| @@ -110,11 +109,6 @@ local  void check_match OF((deflate_state *s, IPos start, IPos match, | ||||
| #endif | ||||
| /* Matches of length 3 are discarded if their distance exceeds TOO_FAR */ | ||||
|  | ||||
| #define MIN_LOOKAHEAD (MAX_MATCH+MIN_MATCH+1) | ||||
| /* Minimum amount of lookahead, except at the end of the input file. | ||||
|  * See deflate.c for comments about the MIN_MATCH+1. | ||||
|  */ | ||||
|  | ||||
| /* Values for max_lazy_match, good_match and max_chain_length, depending on | ||||
|  * the desired pack level (0..9). The values given below have been tuned to | ||||
|  * exclude worst case performance for pathological files. Better values may be | ||||
| @@ -288,6 +282,8 @@ int ZEXPORT deflateInit2_(strm, level, method, windowBits, memLevel, strategy, | ||||
|     s->prev   = (Posf *)  ZALLOC(strm, s->w_size, sizeof(Pos)); | ||||
|     s->head   = (Posf *)  ZALLOC(strm, s->hash_size, sizeof(Pos)); | ||||
|  | ||||
|     s->high_water = 0;      /* nothing written to s->window yet */ | ||||
|  | ||||
|     s->lit_bufsize = 1 << (memLevel + 6); /* 16K elements by default */ | ||||
|  | ||||
|     overlay = (ushf *) ZALLOC(strm, s->lit_bufsize, sizeof(ush)+2); | ||||
| @@ -332,8 +328,8 @@ int ZEXPORT deflateSetDictionary (strm, dictionary, dictLength) | ||||
|         strm->adler = adler32(strm->adler, dictionary, dictLength); | ||||
|  | ||||
|     if (length < MIN_MATCH) return Z_OK; | ||||
|     if (length > MAX_DIST(s)) { | ||||
|         length = MAX_DIST(s); | ||||
|     if (length > s->w_size) { | ||||
|         length = s->w_size; | ||||
|         dictionary += dictLength - length; /* use the tail of the dictionary */ | ||||
|     } | ||||
|     zmemcpy(s->window, dictionary, length); | ||||
| @@ -435,9 +431,10 @@ int ZEXPORT deflateParams(strm, level, strategy) | ||||
|     } | ||||
|     func = configuration_table[s->level].func; | ||||
|  | ||||
|     if (func != configuration_table[level].func && strm->total_in != 0) { | ||||
|     if ((strategy != s->strategy || func != configuration_table[level].func) && | ||||
|         strm->total_in != 0) { | ||||
|         /* Flush the last buffer: */ | ||||
|         err = deflate(strm, Z_PARTIAL_FLUSH); | ||||
|         err = deflate(strm, Z_BLOCK); | ||||
|     } | ||||
|     if (s->level != level) { | ||||
|         s->level = level; | ||||
| @@ -481,33 +478,66 @@ int ZEXPORT deflateTune(strm, good_length, max_lazy, nice_length, max_chain) | ||||
|  * resulting from using fixed blocks instead of stored blocks, which deflate | ||||
|  * can emit on compressed data for some combinations of the parameters. | ||||
|  * | ||||
|  * This function could be more sophisticated to provide closer upper bounds | ||||
|  * for every combination of windowBits and memLevel, as well as wrap. | ||||
|  * But even the conservative upper bound of about 14% expansion does not | ||||
|  * seem onerous for output buffer allocation. | ||||
|  * This function could be more sophisticated to provide closer upper bounds for | ||||
|  * every combination of windowBits and memLevel.  But even the conservative | ||||
|  * upper bound of about 14% expansion does not seem onerous for output buffer | ||||
|  * allocation. | ||||
|  */ | ||||
| uLong ZEXPORT deflateBound(strm, sourceLen) | ||||
|     z_streamp strm; | ||||
|     uLong sourceLen; | ||||
| { | ||||
|     deflate_state *s; | ||||
|     uLong destLen; | ||||
|     uLong complen, wraplen; | ||||
|     Bytef *str; | ||||
|  | ||||
|     /* conservative upper bound */ | ||||
|     destLen = sourceLen + | ||||
|               ((sourceLen + 7) >> 3) + ((sourceLen + 63) >> 6) + 11; | ||||
|     /* conservative upper bound for compressed data */ | ||||
|     complen = sourceLen + | ||||
|               ((sourceLen + 7) >> 3) + ((sourceLen + 63) >> 6) + 5; | ||||
|  | ||||
|     /* if can't get parameters, return conservative bound */ | ||||
|     /* if can't get parameters, return conservative bound plus zlib wrapper */ | ||||
|     if (strm == Z_NULL || strm->state == Z_NULL) | ||||
|         return destLen; | ||||
|         return complen + 6; | ||||
|  | ||||
|     /* compute wrapper length */ | ||||
|     s = strm->state; | ||||
|     switch (s->wrap) { | ||||
|     case 0:                                 /* raw deflate */ | ||||
|         wraplen = 0; | ||||
|         break; | ||||
|     case 1:                                 /* zlib wrapper */ | ||||
|         wraplen = 6 + (s->strstart ? 4 : 0); | ||||
|         break; | ||||
|     case 2:                                 /* gzip wrapper */ | ||||
|         wraplen = 18; | ||||
|         if (s->gzhead != Z_NULL) {          /* user-supplied gzip header */ | ||||
|             if (s->gzhead->extra != Z_NULL) | ||||
|                 wraplen += 2 + s->gzhead->extra_len; | ||||
|             str = s->gzhead->name; | ||||
|             if (str != Z_NULL) | ||||
|                 do { | ||||
|                     wraplen++; | ||||
|                 } while (*str++); | ||||
|             str = s->gzhead->comment; | ||||
|             if (str != Z_NULL) | ||||
|                 do { | ||||
|                     wraplen++; | ||||
|                 } while (*str++); | ||||
|             if (s->gzhead->hcrc) | ||||
|                 wraplen += 2; | ||||
|         } | ||||
|         break; | ||||
|     default:                                /* for compiler happiness */ | ||||
|         wraplen = 6; | ||||
|     } | ||||
|  | ||||
|     /* if not default parameters, return conservative bound */ | ||||
|     s = strm->state; | ||||
|     if (s->w_bits != 15 || s->hash_bits != 8 + 7) | ||||
|         return destLen; | ||||
|         return complen + wraplen; | ||||
|  | ||||
|     /* default settings: return tight bound for that case */ | ||||
|     return compressBound(sourceLen); | ||||
|     return sourceLen + (sourceLen >> 12) + (sourceLen >> 14) + | ||||
|            (sourceLen >> 25) + 13 - 6 + wraplen; | ||||
| } | ||||
|  | ||||
| /* ========================================================================= | ||||
| @@ -557,7 +587,7 @@ int ZEXPORT deflate (strm, flush) | ||||
|     deflate_state *s; | ||||
|  | ||||
|     if (strm == Z_NULL || strm->state == Z_NULL || | ||||
|         flush > Z_FINISH || flush < 0) { | ||||
|         flush > Z_BLOCK || flush < 0) { | ||||
|         return Z_STREAM_ERROR; | ||||
|     } | ||||
|     s = strm->state; | ||||
| @@ -581,7 +611,7 @@ int ZEXPORT deflate (strm, flush) | ||||
|             put_byte(s, 31); | ||||
|             put_byte(s, 139); | ||||
|             put_byte(s, 8); | ||||
|             if (s->gzhead == NULL) { | ||||
|             if (s->gzhead == Z_NULL) { | ||||
|                 put_byte(s, 0); | ||||
|                 put_byte(s, 0); | ||||
|                 put_byte(s, 0); | ||||
| @@ -608,7 +638,7 @@ int ZEXPORT deflate (strm, flush) | ||||
|                             (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2 ? | ||||
|                              4 : 0)); | ||||
|                 put_byte(s, s->gzhead->os & 0xff); | ||||
|                 if (s->gzhead->extra != NULL) { | ||||
|                 if (s->gzhead->extra != Z_NULL) { | ||||
|                     put_byte(s, s->gzhead->extra_len & 0xff); | ||||
|                     put_byte(s, (s->gzhead->extra_len >> 8) & 0xff); | ||||
|                 } | ||||
| @@ -650,7 +680,7 @@ int ZEXPORT deflate (strm, flush) | ||||
|     } | ||||
| #ifdef GZIP | ||||
|     if (s->status == EXTRA_STATE) { | ||||
|         if (s->gzhead->extra != NULL) { | ||||
|         if (s->gzhead->extra != Z_NULL) { | ||||
|             uInt beg = s->pending;  /* start of bytes to update crc */ | ||||
|  | ||||
|             while (s->gzindex < (s->gzhead->extra_len & 0xffff)) { | ||||
| @@ -678,7 +708,7 @@ int ZEXPORT deflate (strm, flush) | ||||
|             s->status = NAME_STATE; | ||||
|     } | ||||
|     if (s->status == NAME_STATE) { | ||||
|         if (s->gzhead->name != NULL) { | ||||
|         if (s->gzhead->name != Z_NULL) { | ||||
|             uInt beg = s->pending;  /* start of bytes to update crc */ | ||||
|             int val; | ||||
|  | ||||
| @@ -709,7 +739,7 @@ int ZEXPORT deflate (strm, flush) | ||||
|             s->status = COMMENT_STATE; | ||||
|     } | ||||
|     if (s->status == COMMENT_STATE) { | ||||
|         if (s->gzhead->comment != NULL) { | ||||
|         if (s->gzhead->comment != Z_NULL) { | ||||
|             uInt beg = s->pending;  /* start of bytes to update crc */ | ||||
|             int val; | ||||
|  | ||||
| @@ -787,7 +817,9 @@ int ZEXPORT deflate (strm, flush) | ||||
|         (flush != Z_NO_FLUSH && s->status != FINISH_STATE)) { | ||||
|         block_state bstate; | ||||
|  | ||||
|         bstate = (*(configuration_table[s->level].func))(s, flush); | ||||
|         bstate = s->strategy == Z_HUFFMAN_ONLY ? deflate_huff(s, flush) : | ||||
|                     (s->strategy == Z_RLE ? deflate_rle(s, flush) : | ||||
|                         (*(configuration_table[s->level].func))(s, flush)); | ||||
|  | ||||
|         if (bstate == finish_started || bstate == finish_done) { | ||||
|             s->status = FINISH_STATE; | ||||
| @@ -808,13 +840,17 @@ int ZEXPORT deflate (strm, flush) | ||||
|         if (bstate == block_done) { | ||||
|             if (flush == Z_PARTIAL_FLUSH) { | ||||
|                 _tr_align(s); | ||||
|             } else { /* FULL_FLUSH or SYNC_FLUSH */ | ||||
|             } else if (flush != Z_BLOCK) { /* FULL_FLUSH or SYNC_FLUSH */ | ||||
|                 _tr_stored_block(s, (char*)0, 0L, 0); | ||||
|                 /* For a full flush, this empty block will be recognized | ||||
|                  * as a special marker by inflate_sync(). | ||||
|                  */ | ||||
|                 if (flush == Z_FULL_FLUSH) { | ||||
|                     CLEAR_HASH(s);             /* forget history */ | ||||
|                     if (s->lookahead == 0) { | ||||
|                         s->strstart = 0; | ||||
|                         s->block_start = 0L; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|             flush_pending(strm); | ||||
| @@ -1167,12 +1203,13 @@ local uInt longest_match(s, cur_match) | ||||
|     return s->lookahead; | ||||
| } | ||||
| #endif /* ASMV */ | ||||
| #endif /* FASTEST */ | ||||
|  | ||||
| #else /* FASTEST */ | ||||
|  | ||||
| /* --------------------------------------------------------------------------- | ||||
|  * Optimized version for level == 1 or strategy == Z_RLE only | ||||
|  * Optimized version for FASTEST only | ||||
|  */ | ||||
| local uInt longest_match_fast(s, cur_match) | ||||
| local uInt longest_match(s, cur_match) | ||||
|     deflate_state *s; | ||||
|     IPos cur_match;                             /* current match */ | ||||
| { | ||||
| @@ -1225,6 +1262,8 @@ local uInt longest_match_fast(s, cur_match) | ||||
|     return (uInt)len <= s->lookahead ? (uInt)len : s->lookahead; | ||||
| } | ||||
|  | ||||
| #endif /* FASTEST */ | ||||
|  | ||||
| #ifdef DEBUG | ||||
| /* =========================================================================== | ||||
|  * Check that the match at match_start is indeed a match. | ||||
| @@ -1303,7 +1342,6 @@ local void fill_window(s) | ||||
|                later. (Using level 0 permanently is not an optimal usage of | ||||
|                zlib, so we don't care about this pathological case.) | ||||
|              */ | ||||
|             /* %%% avoid this when Z_RLE */ | ||||
|             n = s->hash_size; | ||||
|             p = &s->head[n]; | ||||
|             do { | ||||
| @@ -1355,27 +1393,61 @@ local void fill_window(s) | ||||
|          */ | ||||
|  | ||||
|     } 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; | ||||
|         } | ||||
|     } | ||||
| } | ||||
|  | ||||
| /* =========================================================================== | ||||
|  * Flush the current block, with given end-of-file flag. | ||||
|  * IN assertion: strstart is set to the end of the current match. | ||||
|  */ | ||||
| #define FLUSH_BLOCK_ONLY(s, eof) { \ | ||||
| #define FLUSH_BLOCK_ONLY(s, last) { \ | ||||
|    _tr_flush_block(s, (s->block_start >= 0L ? \ | ||||
|                    (charf *)&s->window[(unsigned)s->block_start] : \ | ||||
|                    (charf *)Z_NULL), \ | ||||
|                 (ulg)((long)s->strstart - s->block_start), \ | ||||
|                 (eof)); \ | ||||
|                 (last)); \ | ||||
|    s->block_start = s->strstart; \ | ||||
|    flush_pending(s->strm); \ | ||||
|    Tracev((stderr,"[FLUSH]")); \ | ||||
| } | ||||
|  | ||||
| /* Same but force premature exit if necessary. */ | ||||
| #define FLUSH_BLOCK(s, eof) { \ | ||||
|    FLUSH_BLOCK_ONLY(s, eof); \ | ||||
|    if (s->strm->avail_out == 0) return (eof) ? finish_started : need_more; \ | ||||
| #define FLUSH_BLOCK(s, last) { \ | ||||
|    FLUSH_BLOCK_ONLY(s, last); \ | ||||
|    if (s->strm->avail_out == 0) return (last) ? finish_started : need_more; \ | ||||
| } | ||||
|  | ||||
| /* =========================================================================== | ||||
| @@ -1449,7 +1521,7 @@ local block_state deflate_fast(s, flush) | ||||
|     deflate_state *s; | ||||
|     int flush; | ||||
| { | ||||
|     IPos hash_head = NIL; /* head of the hash chain */ | ||||
|     IPos hash_head;       /* head of the hash chain */ | ||||
|     int bflush;           /* set if current block must be flushed */ | ||||
|  | ||||
|     for (;;) { | ||||
| @@ -1469,6 +1541,7 @@ local block_state deflate_fast(s, flush) | ||||
|         /* Insert the string window[strstart .. strstart+2] in the | ||||
|          * dictionary, and set hash_head to the head of the hash chain: | ||||
|          */ | ||||
|         hash_head = NIL; | ||||
|         if (s->lookahead >= MIN_MATCH) { | ||||
|             INSERT_STRING(s, s->strstart, hash_head); | ||||
|         } | ||||
| @@ -1481,19 +1554,8 @@ local block_state deflate_fast(s, flush) | ||||
|              * of window index 0 (in particular we have to avoid a match | ||||
|              * of the string with itself at the start of the input file). | ||||
|              */ | ||||
| #ifdef FASTEST | ||||
|             if ((s->strategy != Z_HUFFMAN_ONLY && s->strategy != Z_RLE) || | ||||
|                 (s->strategy == Z_RLE && s->strstart - hash_head == 1)) { | ||||
|                 s->match_length = longest_match_fast (s, hash_head); | ||||
|             } | ||||
| #else | ||||
|             if (s->strategy != Z_HUFFMAN_ONLY && s->strategy != Z_RLE) { | ||||
|                 s->match_length = longest_match (s, hash_head); | ||||
|             } else if (s->strategy == Z_RLE && s->strstart - hash_head == 1) { | ||||
|                 s->match_length = longest_match_fast (s, hash_head); | ||||
|             } | ||||
| #endif | ||||
|             /* longest_match() or longest_match_fast() sets match_start */ | ||||
|             s->match_length = longest_match (s, hash_head); | ||||
|             /* longest_match() sets match_start */ | ||||
|         } | ||||
|         if (s->match_length >= MIN_MATCH) { | ||||
|             check_match(s, s->strstart, s->match_start, s->match_length); | ||||
| @@ -1555,7 +1617,7 @@ local block_state deflate_slow(s, flush) | ||||
|     deflate_state *s; | ||||
|     int flush; | ||||
| { | ||||
|     IPos hash_head = NIL;    /* head of hash chain */ | ||||
|     IPos hash_head;          /* head of hash chain */ | ||||
|     int bflush;              /* set if current block must be flushed */ | ||||
|  | ||||
|     /* Process the input block. */ | ||||
| @@ -1576,6 +1638,7 @@ local block_state deflate_slow(s, flush) | ||||
|         /* Insert the string window[strstart .. strstart+2] in the | ||||
|          * dictionary, and set hash_head to the head of the hash chain: | ||||
|          */ | ||||
|         hash_head = NIL; | ||||
|         if (s->lookahead >= MIN_MATCH) { | ||||
|             INSERT_STRING(s, s->strstart, hash_head); | ||||
|         } | ||||
| @@ -1591,12 +1654,8 @@ local block_state deflate_slow(s, flush) | ||||
|              * of window index 0 (in particular we have to avoid a match | ||||
|              * of the string with itself at the start of the input file). | ||||
|              */ | ||||
|             if (s->strategy != Z_HUFFMAN_ONLY && s->strategy != Z_RLE) { | ||||
|                 s->match_length = longest_match (s, hash_head); | ||||
|             } else if (s->strategy == Z_RLE && s->strstart - hash_head == 1) { | ||||
|                 s->match_length = longest_match_fast (s, hash_head); | ||||
|             } | ||||
|             /* longest_match() or longest_match_fast() sets match_start */ | ||||
|             s->match_length = longest_match (s, hash_head); | ||||
|             /* longest_match() sets match_start */ | ||||
|  | ||||
|             if (s->match_length <= 5 && (s->strategy == Z_FILTERED | ||||
| #if TOO_FAR <= 32767 | ||||
| @@ -1674,7 +1733,6 @@ local block_state deflate_slow(s, flush) | ||||
| } | ||||
| #endif /* FASTEST */ | ||||
|  | ||||
| #if 0 | ||||
| /* =========================================================================== | ||||
|  * For Z_RLE, simply look for runs of bytes, generate matches only of distance | ||||
|  * one.  Do not maintain a hash table.  (It will be regenerated if this run of | ||||
| @@ -1684,11 +1742,9 @@ local block_state deflate_rle(s, flush) | ||||
|     deflate_state *s; | ||||
|     int flush; | ||||
| { | ||||
|     int bflush;         /* set if current block must be flushed */ | ||||
|     uInt run;           /* length of run */ | ||||
|     uInt max;           /* maximum length of run */ | ||||
|     uInt prev;          /* byte at distance one to match */ | ||||
|     Bytef *scan;        /* scan for end of run */ | ||||
|     int bflush;             /* set if current block must be flushed */ | ||||
|     uInt prev;              /* byte at distance one to match */ | ||||
|     Bytef *scan, *strend;   /* scan goes up to strend for length of run */ | ||||
|  | ||||
|     for (;;) { | ||||
|         /* Make sure that we always have enough lookahead, except | ||||
| @@ -1704,23 +1760,33 @@ local block_state deflate_rle(s, flush) | ||||
|         } | ||||
|  | ||||
|         /* See how many times the previous byte repeats */ | ||||
|         run = 0; | ||||
|         if (s->strstart > 0) {      /* if there is a previous byte, that is */ | ||||
|             max = s->lookahead < MAX_MATCH ? s->lookahead : MAX_MATCH; | ||||
|         s->match_length = 0; | ||||
|         if (s->lookahead >= MIN_MATCH && s->strstart > 0) { | ||||
|             scan = s->window + s->strstart - 1; | ||||
|             prev = *scan++; | ||||
|             do { | ||||
|                 if (*scan++ != prev) | ||||
|                     break; | ||||
|             } while (++run < max); | ||||
|             prev = *scan; | ||||
|             if (prev == *++scan && prev == *++scan && prev == *++scan) { | ||||
|                 strend = s->window + s->strstart + MAX_MATCH; | ||||
|                 do { | ||||
|                 } while (prev == *++scan && prev == *++scan && | ||||
|                          prev == *++scan && prev == *++scan && | ||||
|                          prev == *++scan && prev == *++scan && | ||||
|                          prev == *++scan && prev == *++scan && | ||||
|                          scan < strend); | ||||
|                 s->match_length = MAX_MATCH - (int)(strend - scan); | ||||
|                 if (s->match_length > s->lookahead) | ||||
|                     s->match_length = s->lookahead; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         /* Emit match if have run of MIN_MATCH or longer, else emit literal */ | ||||
|         if (run >= MIN_MATCH) { | ||||
|             check_match(s, s->strstart, s->strstart - 1, run); | ||||
|             _tr_tally_dist(s, 1, run - MIN_MATCH, bflush); | ||||
|             s->lookahead -= run; | ||||
|             s->strstart += run; | ||||
|         if (s->match_length >= MIN_MATCH) { | ||||
|             check_match(s, s->strstart, s->strstart - 1, s->match_length); | ||||
|  | ||||
|             _tr_tally_dist(s, 1, s->match_length - MIN_MATCH, bflush); | ||||
|  | ||||
|             s->lookahead -= s->match_length; | ||||
|             s->strstart += s->match_length; | ||||
|             s->match_length = 0; | ||||
|         } else { | ||||
|             /* No match, output a literal byte */ | ||||
|             Tracevv((stderr,"%c", s->window[s->strstart])); | ||||
| @@ -1733,4 +1799,36 @@ local block_state deflate_rle(s, flush) | ||||
|     FLUSH_BLOCK(s, flush == Z_FINISH); | ||||
|     return flush == Z_FINISH ? finish_done : block_done; | ||||
| } | ||||
| #endif | ||||
|  | ||||
| /* =========================================================================== | ||||
|  * 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.) | ||||
|  */ | ||||
| local block_state deflate_huff(s, flush) | ||||
|     deflate_state *s; | ||||
|     int flush; | ||||
| { | ||||
|     int bflush;             /* set if current block must be flushed */ | ||||
|  | ||||
|     for (;;) { | ||||
|         /* Make sure that we have a literal to write. */ | ||||
|         if (s->lookahead == 0) { | ||||
|             fill_window(s); | ||||
|             if (s->lookahead == 0) { | ||||
|                 if (flush == Z_NO_FLUSH) | ||||
|                     return need_more; | ||||
|                 break;      /* flush the current block */ | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         /* Output a literal byte */ | ||||
|         s->match_length = 0; | ||||
|         Tracevv((stderr,"%c", s->window[s->strstart])); | ||||
|         _tr_tally_lit (s, s->window[s->strstart], bflush); | ||||
|         s->lookahead--; | ||||
|         s->strstart++; | ||||
|         if (bflush) FLUSH_BLOCK(s, 0); | ||||
|     } | ||||
|     FLUSH_BLOCK(s, flush == Z_FINISH); | ||||
|     return flush == Z_FINISH ? finish_done : block_done; | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* deflate.h -- internal compression state | ||||
|  * Copyright (C) 1995-2004 Jean-loup Gailly | ||||
|  * Copyright (C) 1995-2010 Jean-loup Gailly | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| @@ -8,7 +8,7 @@ | ||||
|    subject to change. Applications should only use zlib.h. | ||||
|  */ | ||||
|  | ||||
| /* @(#) $Id: //poco/svn/Foundation/src/deflate.h#2 $ */ | ||||
| /* @(#) $Id$ */ | ||||
|  | ||||
| #ifndef DEFLATE_H | ||||
| #define DEFLATE_H | ||||
| @@ -260,6 +260,13 @@ typedef struct internal_state { | ||||
|      * are always zero. | ||||
|      */ | ||||
|  | ||||
|     ulg high_water; | ||||
|     /* High water mark offset in window for initialized bytes -- bytes above | ||||
|      * this are set to zero in order to avoid memory check warnings when | ||||
|      * longest match routines access bytes past the input.  This is then | ||||
|      * updated to the new high water mark. | ||||
|      */ | ||||
|  | ||||
| } FAR deflate_state; | ||||
|  | ||||
| /* Output a byte on the stream. | ||||
| @@ -278,14 +285,18 @@ typedef struct internal_state { | ||||
|  * distances are limited to MAX_DIST instead of WSIZE. | ||||
|  */ | ||||
|  | ||||
| #define WIN_INIT MAX_MATCH | ||||
| /* Number of bytes after end of data in window to initialize in order to avoid | ||||
|    memory checker errors from longest match routines */ | ||||
|  | ||||
|         /* in trees.c */ | ||||
| void _tr_init         OF((deflate_state *s)); | ||||
| int  _tr_tally        OF((deflate_state *s, unsigned dist, unsigned lc)); | ||||
| void _tr_flush_block  OF((deflate_state *s, charf *buf, ulg stored_len, | ||||
|                           int eof)); | ||||
| void _tr_align        OF((deflate_state *s)); | ||||
| void _tr_stored_block OF((deflate_state *s, charf *buf, ulg stored_len, | ||||
|                           int eof)); | ||||
| void ZLIB_INTERNAL _tr_init OF((deflate_state *s)); | ||||
| int ZLIB_INTERNAL _tr_tally OF((deflate_state *s, unsigned dist, unsigned lc)); | ||||
| void ZLIB_INTERNAL _tr_flush_block OF((deflate_state *s, charf *buf, | ||||
|                         ulg stored_len, int last)); | ||||
| void ZLIB_INTERNAL _tr_align OF((deflate_state *s)); | ||||
| void ZLIB_INTERNAL _tr_stored_block OF((deflate_state *s, charf *buf, | ||||
|                         ulg stored_len, int last)); | ||||
|  | ||||
| #define d_code(dist) \ | ||||
|    ((dist) < 256 ? _dist_code[dist] : _dist_code[256+((dist)>>7)]) | ||||
| @@ -298,11 +309,11 @@ void _tr_stored_block OF((deflate_state *s, charf *buf, ulg stored_len, | ||||
| /* Inline versions of _tr_tally for speed: */ | ||||
|  | ||||
| #if defined(GEN_TREES_H) || !defined(STDC) | ||||
|   extern uch _length_code[]; | ||||
|   extern uch _dist_code[]; | ||||
|   extern uch ZLIB_INTERNAL _length_code[]; | ||||
|   extern uch ZLIB_INTERNAL _dist_code[]; | ||||
| #else | ||||
|   extern const uch _length_code[]; | ||||
|   extern const uch _dist_code[]; | ||||
|   extern const uch ZLIB_INTERNAL _length_code[]; | ||||
|   extern const uch ZLIB_INTERNAL _dist_code[]; | ||||
| #endif | ||||
|  | ||||
| # define _tr_tally_lit(s, c, flush) \ | ||||
|   | ||||
							
								
								
									
										25
									
								
								Foundation/src/gzclose.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								Foundation/src/gzclose.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | ||||
| /* gzclose.c -- zlib gzclose() function | ||||
|  * Copyright (C) 2004, 2010 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| #include "gzguts.h" | ||||
|  | ||||
| /* gzclose() is in a separate file so that it is linked in only if it is used. | ||||
|    That way the other gzclose functions can be used instead to avoid linking in | ||||
|    unneeded compression or decompression routines. */ | ||||
| int ZEXPORT gzclose(file) | ||||
|     gzFile file; | ||||
| { | ||||
| #ifndef NO_GZCOMPRESS | ||||
|     gz_statep state; | ||||
|  | ||||
|     if (file == NULL) | ||||
|         return Z_STREAM_ERROR; | ||||
|     state = (gz_statep)file; | ||||
|  | ||||
|     return state->mode == GZ_READ ? gzclose_r(file) : gzclose_w(file); | ||||
| #else | ||||
|     return gzclose_r(file); | ||||
| #endif | ||||
| } | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										537
									
								
								Foundation/src/gzlib.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										537
									
								
								Foundation/src/gzlib.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,537 @@ | ||||
| /* gzlib.c -- zlib functions common to reading and writing gzip files | ||||
|  * Copyright (C) 2004, 2010 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| #include "gzguts.h" | ||||
|  | ||||
| #if defined(_LARGEFILE64_SOURCE) && _LFS64_LARGEFILE-0 | ||||
| #  define LSEEK lseek64 | ||||
| #else | ||||
| #  define LSEEK lseek | ||||
| #endif | ||||
|  | ||||
| /* Local functions */ | ||||
| local void gz_reset OF((gz_statep)); | ||||
| local gzFile gz_open OF((const char *, int, const char *)); | ||||
|  | ||||
| #if defined UNDER_CE | ||||
|  | ||||
| /* Map the Windows error number in ERROR to a locale-dependent error message | ||||
|    string and return a pointer to it.  Typically, the values for ERROR come | ||||
|    from GetLastError. | ||||
|  | ||||
|    The string pointed to shall not be modified by the application, but may be | ||||
|    overwritten by a subsequent call to gz_strwinerror | ||||
|  | ||||
|    The gz_strwinerror function does not change the current setting of | ||||
|    GetLastError. */ | ||||
| char ZLIB_INTERNAL *gz_strwinerror (error) | ||||
|      DWORD error; | ||||
| { | ||||
|     static char buf[1024]; | ||||
|  | ||||
|     wchar_t *msgbuf; | ||||
|     DWORD lasterr = GetLastError(); | ||||
|     DWORD chars = FormatMessage(FORMAT_MESSAGE_FROM_SYSTEM | ||||
|         | FORMAT_MESSAGE_ALLOCATE_BUFFER, | ||||
|         NULL, | ||||
|         error, | ||||
|         0, /* Default language */ | ||||
|         (LPVOID)&msgbuf, | ||||
|         0, | ||||
|         NULL); | ||||
|     if (chars != 0) { | ||||
|         /* If there is an \r\n appended, zap it.  */ | ||||
|         if (chars >= 2 | ||||
|             && msgbuf[chars - 2] == '\r' && msgbuf[chars - 1] == '\n') { | ||||
|             chars -= 2; | ||||
|             msgbuf[chars] = 0; | ||||
|         } | ||||
|  | ||||
|         if (chars > sizeof (buf) - 1) { | ||||
|             chars = sizeof (buf) - 1; | ||||
|             msgbuf[chars] = 0; | ||||
|         } | ||||
|  | ||||
|         wcstombs(buf, msgbuf, chars + 1); | ||||
|         LocalFree(msgbuf); | ||||
|     } | ||||
|     else { | ||||
|         sprintf(buf, "unknown win32 error (%ld)", error); | ||||
|     } | ||||
|  | ||||
|     SetLastError(lasterr); | ||||
|     return buf; | ||||
| } | ||||
|  | ||||
| #endif /* UNDER_CE */ | ||||
|  | ||||
| /* Reset gzip file state */ | ||||
| local void gz_reset(state) | ||||
|     gz_statep state; | ||||
| { | ||||
|     if (state->mode == GZ_READ) {   /* for reading ... */ | ||||
|         state->have = 0;            /* no output data available */ | ||||
|         state->eof = 0;             /* not at end of file */ | ||||
|         state->how = LOOK;          /* look for gzip header */ | ||||
|         state->direct = 1;          /* default for empty file */ | ||||
|     } | ||||
|     state->seek = 0;                /* no seek request pending */ | ||||
|     gz_error(state, Z_OK, NULL);    /* clear error */ | ||||
|     state->pos = 0;                 /* no uncompressed data yet */ | ||||
|     state->strm.avail_in = 0;       /* no input data yet */ | ||||
| } | ||||
|  | ||||
| /* Open a gzip file either by name or file descriptor. */ | ||||
| local gzFile gz_open(path, fd, mode) | ||||
|     const char *path; | ||||
|     int fd; | ||||
|     const char *mode; | ||||
| { | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* allocate gzFile structure to return */ | ||||
|     state = malloc(sizeof(gz_state)); | ||||
|     if (state == NULL) | ||||
|         return NULL; | ||||
|     state->size = 0;            /* no buffers allocated yet */ | ||||
|     state->want = GZBUFSIZE;    /* requested buffer size */ | ||||
|     state->msg = NULL;          /* no error message yet */ | ||||
|  | ||||
|     /* interpret mode */ | ||||
|     state->mode = GZ_NONE; | ||||
|     state->level = Z_DEFAULT_COMPRESSION; | ||||
|     state->strategy = Z_DEFAULT_STRATEGY; | ||||
|     while (*mode) { | ||||
|         if (*mode >= '0' && *mode <= '9') | ||||
|             state->level = *mode - '0'; | ||||
|         else | ||||
|             switch (*mode) { | ||||
|             case 'r': | ||||
|                 state->mode = GZ_READ; | ||||
|                 break; | ||||
| #ifndef NO_GZCOMPRESS | ||||
|             case 'w': | ||||
|                 state->mode = GZ_WRITE; | ||||
|                 break; | ||||
|             case 'a': | ||||
|                 state->mode = GZ_APPEND; | ||||
|                 break; | ||||
| #endif | ||||
|             case '+':       /* can't read and write at the same time */ | ||||
|                 free(state); | ||||
|                 return NULL; | ||||
|             case 'b':       /* ignore -- will request binary anyway */ | ||||
|                 break; | ||||
|             case 'f': | ||||
|                 state->strategy = Z_FILTERED; | ||||
|                 break; | ||||
|             case 'h': | ||||
|                 state->strategy = Z_HUFFMAN_ONLY; | ||||
|                 break; | ||||
|             case 'R': | ||||
|                 state->strategy = Z_RLE; | ||||
|                 break; | ||||
|             case 'F': | ||||
|                 state->strategy = Z_FIXED; | ||||
|             default:        /* could consider as an error, but just ignore */ | ||||
|                 ; | ||||
|             } | ||||
|         mode++; | ||||
|     } | ||||
|  | ||||
|     /* must provide an "r", "w", or "a" */ | ||||
|     if (state->mode == GZ_NONE) { | ||||
|         free(state); | ||||
|         return NULL; | ||||
|     } | ||||
|  | ||||
|     /* save the path name for error messages */ | ||||
|     state->path = malloc(strlen(path) + 1); | ||||
|     if (state->path == NULL) { | ||||
|         free(state); | ||||
|         return NULL; | ||||
|     } | ||||
|     strcpy(state->path, path); | ||||
|  | ||||
|     /* open the file with the appropriate mode (or just use fd) */ | ||||
|     state->fd = fd != -1 ? fd : | ||||
|         open(path, | ||||
| #ifdef O_LARGEFILE | ||||
|             O_LARGEFILE | | ||||
| #endif | ||||
| #ifdef O_BINARY | ||||
|             O_BINARY | | ||||
| #endif | ||||
|             (state->mode == GZ_READ ? | ||||
|                 O_RDONLY : | ||||
|                 (O_WRONLY | O_CREAT | ( | ||||
|                     state->mode == GZ_WRITE ? | ||||
|                         O_TRUNC : | ||||
|                         O_APPEND))), | ||||
|             0666); | ||||
|     if (state->fd == -1) { | ||||
|         free(state->path); | ||||
|         free(state); | ||||
|         return NULL; | ||||
|     } | ||||
|     if (state->mode == GZ_APPEND) | ||||
|         state->mode = GZ_WRITE;         /* simplify later checks */ | ||||
|  | ||||
|     /* save the current position for rewinding (only if reading) */ | ||||
|     if (state->mode == GZ_READ) { | ||||
|         state->start = LSEEK(state->fd, 0, SEEK_CUR); | ||||
|         if (state->start == -1) state->start = 0; | ||||
|     } | ||||
|  | ||||
|     /* initialize stream */ | ||||
|     gz_reset(state); | ||||
|  | ||||
|     /* return stream */ | ||||
|     return (gzFile)state; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| gzFile ZEXPORT gzopen(path, mode) | ||||
|     const char *path; | ||||
|     const char *mode; | ||||
| { | ||||
|     return gz_open(path, -1, mode); | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| gzFile ZEXPORT gzopen64(path, mode) | ||||
|     const char *path; | ||||
|     const char *mode; | ||||
| { | ||||
|     return gz_open(path, -1, mode); | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| gzFile ZEXPORT gzdopen(fd, mode) | ||||
|     int fd; | ||||
|     const char *mode; | ||||
| { | ||||
|     char *path;         /* identifier for error messages */ | ||||
|     gzFile gz; | ||||
|  | ||||
|     if (fd == -1 || (path = malloc(7 + 3 * sizeof(int))) == NULL) | ||||
|         return NULL; | ||||
|     sprintf(path, "<fd:%d>", fd);   /* for debugging */ | ||||
|     gz = gz_open(path, fd, mode); | ||||
|     free(path); | ||||
|     return gz; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzbuffer(file, size) | ||||
|     gzFile file; | ||||
|     unsigned size; | ||||
| { | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure and check integrity */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|     if (state->mode != GZ_READ && state->mode != GZ_WRITE) | ||||
|         return -1; | ||||
|  | ||||
|     /* make sure we haven't already allocated memory */ | ||||
|     if (state->size != 0) | ||||
|         return -1; | ||||
|  | ||||
|     /* check and set requested size */ | ||||
|     if (size == 0) | ||||
|         return -1; | ||||
|     state->want = size; | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzrewind(file) | ||||
|     gzFile file; | ||||
| { | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|  | ||||
|     /* check that we're reading and that there's no error */ | ||||
|     if (state->mode != GZ_READ || state->err != Z_OK) | ||||
|         return -1; | ||||
|  | ||||
|     /* back up and start over */ | ||||
|     if (LSEEK(state->fd, state->start, SEEK_SET) == -1) | ||||
|         return -1; | ||||
|     gz_reset(state); | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| z_off64_t ZEXPORT gzseek64(file, offset, whence) | ||||
|     gzFile file; | ||||
|     z_off64_t offset; | ||||
|     int whence; | ||||
| { | ||||
|     unsigned n; | ||||
|     z_off64_t ret; | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure and check integrity */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|     if (state->mode != GZ_READ && state->mode != GZ_WRITE) | ||||
|         return -1; | ||||
|  | ||||
|     /* check that there's no error */ | ||||
|     if (state->err != Z_OK) | ||||
|         return -1; | ||||
|  | ||||
|     /* can only seek from start or relative to current position */ | ||||
|     if (whence != SEEK_SET && whence != SEEK_CUR) | ||||
|         return -1; | ||||
|  | ||||
|     /* normalize offset to a SEEK_CUR specification */ | ||||
|     if (whence == SEEK_SET) | ||||
|         offset -= state->pos; | ||||
|     else if (state->seek) | ||||
|         offset += state->skip; | ||||
|     state->seek = 0; | ||||
|  | ||||
|     /* if within raw area while reading, just go there */ | ||||
|     if (state->mode == GZ_READ && state->how == COPY && | ||||
|         state->pos + offset >= state->raw) { | ||||
|         ret = LSEEK(state->fd, offset - state->have, SEEK_CUR); | ||||
|         if (ret == -1) | ||||
|             return -1; | ||||
|         state->have = 0; | ||||
|         state->eof = 0; | ||||
|         state->seek = 0; | ||||
|         gz_error(state, Z_OK, NULL); | ||||
|         state->strm.avail_in = 0; | ||||
|         state->pos += offset; | ||||
|         return state->pos; | ||||
|     } | ||||
|  | ||||
|     /* calculate skip amount, rewinding if needed for back seek when reading */ | ||||
|     if (offset < 0) { | ||||
|         if (state->mode != GZ_READ)         /* writing -- can't go backwards */ | ||||
|             return -1; | ||||
|         offset += state->pos; | ||||
|         if (offset < 0)                     /* before start of file! */ | ||||
|             return -1; | ||||
|         if (gzrewind(file) == -1)           /* rewind, then skip to offset */ | ||||
|             return -1; | ||||
|     } | ||||
|  | ||||
|     /* if reading, skip what's in output buffer (one less gzgetc() check) */ | ||||
|     if (state->mode == GZ_READ) { | ||||
|         n = GT_OFF(state->have) || (z_off64_t)state->have > offset ? | ||||
|             (unsigned)offset : state->have; | ||||
|         state->have -= n; | ||||
|         state->next += n; | ||||
|         state->pos += n; | ||||
|         offset -= n; | ||||
|     } | ||||
|  | ||||
|     /* request skip (if not zero) */ | ||||
|     if (offset) { | ||||
|         state->seek = 1; | ||||
|         state->skip = offset; | ||||
|     } | ||||
|     return state->pos + offset; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| z_off_t ZEXPORT gzseek(file, offset, whence) | ||||
|     gzFile file; | ||||
|     z_off_t offset; | ||||
|     int whence; | ||||
| { | ||||
|     z_off64_t ret; | ||||
|  | ||||
|     ret = gzseek64(file, (z_off64_t)offset, whence); | ||||
|     return ret == (z_off_t)ret ? (z_off_t)ret : -1; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| z_off64_t ZEXPORT gztell64(file) | ||||
|     gzFile file; | ||||
| { | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure and check integrity */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|     if (state->mode != GZ_READ && state->mode != GZ_WRITE) | ||||
|         return -1; | ||||
|  | ||||
|     /* return position */ | ||||
|     return state->pos + (state->seek ? state->skip : 0); | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| z_off_t ZEXPORT gztell(file) | ||||
|     gzFile file; | ||||
| { | ||||
|     z_off64_t ret; | ||||
|  | ||||
|     ret = gztell64(file); | ||||
|     return ret == (z_off_t)ret ? (z_off_t)ret : -1; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| z_off64_t ZEXPORT gzoffset64(file) | ||||
|     gzFile file; | ||||
| { | ||||
|     z_off64_t offset; | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure and check integrity */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|     if (state->mode != GZ_READ && state->mode != GZ_WRITE) | ||||
|         return -1; | ||||
|  | ||||
|     /* compute and return effective offset in file */ | ||||
|     offset = LSEEK(state->fd, 0, SEEK_CUR); | ||||
|     if (offset == -1) | ||||
|         return -1; | ||||
|     if (state->mode == GZ_READ)             /* reading */ | ||||
|         offset -= state->strm.avail_in;     /* don't count buffered input */ | ||||
|     return offset; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| z_off_t ZEXPORT gzoffset(file) | ||||
|     gzFile file; | ||||
| { | ||||
|     z_off64_t ret; | ||||
|  | ||||
|     ret = gzoffset64(file); | ||||
|     return ret == (z_off_t)ret ? (z_off_t)ret : -1; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzeof(file) | ||||
|     gzFile file; | ||||
| { | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure and check integrity */ | ||||
|     if (file == NULL) | ||||
|         return 0; | ||||
|     state = (gz_statep)file; | ||||
|     if (state->mode != GZ_READ && state->mode != GZ_WRITE) | ||||
|         return 0; | ||||
|  | ||||
|     /* return end-of-file state */ | ||||
|     return state->mode == GZ_READ ? | ||||
|         (state->eof && state->strm.avail_in == 0 && state->have == 0) : 0; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| const char * ZEXPORT gzerror(file, errnum) | ||||
|     gzFile file; | ||||
|     int *errnum; | ||||
| { | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure and check integrity */ | ||||
|     if (file == NULL) | ||||
|         return NULL; | ||||
|     state = (gz_statep)file; | ||||
|     if (state->mode != GZ_READ && state->mode != GZ_WRITE) | ||||
|         return NULL; | ||||
|  | ||||
|     /* return error information */ | ||||
|     if (errnum != NULL) | ||||
|         *errnum = state->err; | ||||
|     return state->msg == NULL ? "" : state->msg; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| void ZEXPORT gzclearerr(file) | ||||
|     gzFile file; | ||||
| { | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure and check integrity */ | ||||
|     if (file == NULL) | ||||
|         return; | ||||
|     state = (gz_statep)file; | ||||
|     if (state->mode != GZ_READ && state->mode != GZ_WRITE) | ||||
|         return; | ||||
|  | ||||
|     /* clear error and end-of-file */ | ||||
|     if (state->mode == GZ_READ) | ||||
|         state->eof = 0; | ||||
|     gz_error(state, Z_OK, NULL); | ||||
| } | ||||
|  | ||||
| /* Create an error message in allocated memory and set state->err and | ||||
|    state->msg accordingly.  Free any previous error message already there.  Do | ||||
|    not try to free or allocate space if the error is Z_MEM_ERROR (out of | ||||
|    memory).  Simply save the error message as a static string.  If there is an | ||||
|    allocation failure constructing the error message, then convert the error to | ||||
|    out of memory. */ | ||||
| void ZLIB_INTERNAL gz_error(state, err, msg) | ||||
|     gz_statep state; | ||||
|     int err; | ||||
|     const char *msg; | ||||
| { | ||||
|     /* free previously allocated message and clear */ | ||||
|     if (state->msg != NULL) { | ||||
|         if (state->err != Z_MEM_ERROR) | ||||
|             free(state->msg); | ||||
|         state->msg = NULL; | ||||
|     } | ||||
|  | ||||
|     /* set error code, and if no message, then done */ | ||||
|     state->err = err; | ||||
|     if (msg == NULL) | ||||
|         return; | ||||
|  | ||||
|     /* for an out of memory error, save as static string */ | ||||
|     if (err == Z_MEM_ERROR) { | ||||
|         state->msg = (char *)msg; | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     /* construct error message with path */ | ||||
|     if ((state->msg = malloc(strlen(state->path) + strlen(msg) + 3)) == NULL) { | ||||
|         state->err = Z_MEM_ERROR; | ||||
|         state->msg = (char *)"out of memory"; | ||||
|         return; | ||||
|     } | ||||
|     strcpy(state->msg, state->path); | ||||
|     strcat(state->msg, ": "); | ||||
|     strcat(state->msg, msg); | ||||
|     return; | ||||
| } | ||||
|  | ||||
| #ifndef INT_MAX | ||||
| /* portably return maximum value for an int (when limits.h presumed not | ||||
|    available) -- we need to do this to cover cases where 2's complement not | ||||
|    used, since C standard permits 1's complement and sign-bit representations, | ||||
|    otherwise we could just use ((unsigned)-1) >> 1 */ | ||||
| unsigned ZLIB_INTERNAL gz_intmax() | ||||
| { | ||||
|     unsigned p, q; | ||||
|  | ||||
|     p = 1; | ||||
|     do { | ||||
|         q = p; | ||||
|         p <<= 1; | ||||
|         p++; | ||||
|     } while (p > q); | ||||
|     return q >> 1; | ||||
| } | ||||
| #endif | ||||
							
								
								
									
										653
									
								
								Foundation/src/gzread.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										653
									
								
								Foundation/src/gzread.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,653 @@ | ||||
| /* gzread.c -- zlib functions for reading gzip files | ||||
|  * Copyright (C) 2004, 2005, 2010 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| #include "gzguts.h" | ||||
|  | ||||
| /* Local functions */ | ||||
| local int gz_load OF((gz_statep, unsigned char *, unsigned, unsigned *)); | ||||
| local int gz_avail OF((gz_statep)); | ||||
| local int gz_next4 OF((gz_statep, unsigned long *)); | ||||
| local int gz_head OF((gz_statep)); | ||||
| local int gz_decomp OF((gz_statep)); | ||||
| local int gz_make OF((gz_statep)); | ||||
| local int gz_skip OF((gz_statep, z_off64_t)); | ||||
|  | ||||
| /* Use read() to load a buffer -- return -1 on error, otherwise 0.  Read from | ||||
|    state->fd, and update state->eof, state->err, and state->msg as appropriate. | ||||
|    This function needs to loop on read(), since read() is not guaranteed to | ||||
|    read the number of bytes requested, depending on the type of descriptor. */ | ||||
| local int gz_load(state, buf, len, have) | ||||
|     gz_statep state; | ||||
|     unsigned char *buf; | ||||
|     unsigned len; | ||||
|     unsigned *have; | ||||
| { | ||||
|     int ret; | ||||
|  | ||||
|     *have = 0; | ||||
|     do { | ||||
|         ret = read(state->fd, buf + *have, len - *have); | ||||
|         if (ret <= 0) | ||||
|             break; | ||||
|         *have += ret; | ||||
|     } while (*have < len); | ||||
|     if (ret < 0) { | ||||
|         gz_error(state, Z_ERRNO, zstrerror()); | ||||
|         return -1; | ||||
|     } | ||||
|     if (ret == 0) | ||||
|         state->eof = 1; | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* Load up input buffer and set eof flag if last data loaded -- return -1 on | ||||
|    error, 0 otherwise.  Note that the eof flag is set when the end of the input | ||||
|    file is reached, even though there may be unused data in the buffer.  Once | ||||
|    that data has been used, no more attempts will be made to read the file. | ||||
|    gz_avail() assumes that strm->avail_in == 0. */ | ||||
| local int gz_avail(state) | ||||
|     gz_statep state; | ||||
| { | ||||
|     z_streamp strm = &(state->strm); | ||||
|  | ||||
|     if (state->err != Z_OK) | ||||
|         return -1; | ||||
|     if (state->eof == 0) { | ||||
|         if (gz_load(state, state->in, state->size, | ||||
|                 (unsigned *)&(strm->avail_in)) == -1) | ||||
|             return -1; | ||||
|         strm->next_in = state->in; | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* Get next byte from input, or -1 if end or error. */ | ||||
| #define NEXT() ((strm->avail_in == 0 && gz_avail(state) == -1) ? -1 : \ | ||||
|                 (strm->avail_in == 0 ? -1 : \ | ||||
|                  (strm->avail_in--, *(strm->next_in)++))) | ||||
|  | ||||
| /* Get a four-byte little-endian integer and return 0 on success and the value | ||||
|    in *ret.  Otherwise -1 is returned and *ret is not modified. */ | ||||
| local int gz_next4(state, ret) | ||||
|     gz_statep state; | ||||
|     unsigned long *ret; | ||||
| { | ||||
|     int ch; | ||||
|     unsigned long val; | ||||
|     z_streamp strm = &(state->strm); | ||||
|  | ||||
|     val = NEXT(); | ||||
|     val += (unsigned)NEXT() << 8; | ||||
|     val += (unsigned long)NEXT() << 16; | ||||
|     ch = NEXT(); | ||||
|     if (ch == -1) | ||||
|         return -1; | ||||
|     val += (unsigned long)ch << 24; | ||||
|     *ret = val; | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* Look for gzip header, set up for inflate or copy.  state->have must be zero. | ||||
|    If this is the first time in, allocate required memory.  state->how will be | ||||
|    left unchanged if there is no more input data available, will be set to COPY | ||||
|    if there is no gzip header and direct copying will be performed, or it will | ||||
|    be set to GZIP for decompression, and the gzip header will be skipped so | ||||
|    that the next available input data is the raw deflate stream.  If direct | ||||
|    copying, then leftover input data from the input buffer will be copied to | ||||
|    the output buffer.  In that case, all further file reads will be directly to | ||||
|    either the output buffer or a user buffer.  If decompressing, the inflate | ||||
|    state and the check value will be initialized.  gz_head() will return 0 on | ||||
|    success or -1 on failure.  Failures may include read errors or gzip header | ||||
|    errors.  */ | ||||
| local int gz_head(state) | ||||
|     gz_statep state; | ||||
| { | ||||
|     z_streamp strm = &(state->strm); | ||||
|     int flags; | ||||
|     unsigned len; | ||||
|  | ||||
|     /* allocate read buffers and inflate memory */ | ||||
|     if (state->size == 0) { | ||||
|         /* allocate buffers */ | ||||
|         state->in = malloc(state->want); | ||||
|         state->out = malloc(state->want << 1); | ||||
|         if (state->in == NULL || state->out == NULL) { | ||||
|             if (state->out != NULL) | ||||
|                 free(state->out); | ||||
|             if (state->in != NULL) | ||||
|                 free(state->in); | ||||
|             gz_error(state, Z_MEM_ERROR, "out of memory"); | ||||
|             return -1; | ||||
|         } | ||||
|         state->size = state->want; | ||||
|  | ||||
|         /* allocate inflate memory */ | ||||
|         state->strm.zalloc = Z_NULL; | ||||
|         state->strm.zfree = Z_NULL; | ||||
|         state->strm.opaque = Z_NULL; | ||||
|         state->strm.avail_in = 0; | ||||
|         state->strm.next_in = Z_NULL; | ||||
|         if (inflateInit2(&(state->strm), -15) != Z_OK) {    /* raw inflate */ | ||||
|             free(state->out); | ||||
|             free(state->in); | ||||
|             state->size = 0; | ||||
|             gz_error(state, Z_MEM_ERROR, "out of memory"); | ||||
|             return -1; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /* get some data in the input buffer */ | ||||
|     if (strm->avail_in == 0) { | ||||
|         if (gz_avail(state) == -1) | ||||
|             return -1; | ||||
|         if (strm->avail_in == 0) | ||||
|             return 0; | ||||
|     } | ||||
|  | ||||
|     /* look for the gzip magic header bytes 31 and 139 */ | ||||
|     if (strm->next_in[0] == 31) { | ||||
|         strm->avail_in--; | ||||
|         strm->next_in++; | ||||
|         if (strm->avail_in == 0 && gz_avail(state) == -1) | ||||
|             return -1; | ||||
|         if (strm->avail_in && strm->next_in[0] == 139) { | ||||
|             /* we have a gzip header, woo hoo! */ | ||||
|             strm->avail_in--; | ||||
|             strm->next_in++; | ||||
|  | ||||
|             /* skip rest of header */ | ||||
|             if (NEXT() != 8) {      /* compression method */ | ||||
|                 gz_error(state, Z_DATA_ERROR, "unknown compression method"); | ||||
|                 return -1; | ||||
|             } | ||||
|             flags = NEXT(); | ||||
|             if (flags & 0xe0) {     /* reserved flag bits */ | ||||
|                 gz_error(state, Z_DATA_ERROR, "unknown header flags set"); | ||||
|                 return -1; | ||||
|             } | ||||
|             NEXT();                 /* modification time */ | ||||
|             NEXT(); | ||||
|             NEXT(); | ||||
|             NEXT(); | ||||
|             NEXT();                 /* extra flags */ | ||||
|             NEXT();                 /* operating system */ | ||||
|             if (flags & 4) {        /* extra field */ | ||||
|                 len = (unsigned)NEXT(); | ||||
|                 len += (unsigned)NEXT() << 8; | ||||
|                 while (len--) | ||||
|                     if (NEXT() < 0) | ||||
|                         break; | ||||
|             } | ||||
|             if (flags & 8)          /* file name */ | ||||
|                 while (NEXT() > 0) | ||||
|                     ; | ||||
|             if (flags & 16)         /* comment */ | ||||
|                 while (NEXT() > 0) | ||||
|                     ; | ||||
|             if (flags & 2) {        /* header crc */ | ||||
|                 NEXT(); | ||||
|                 NEXT(); | ||||
|             } | ||||
|             /* an unexpected end of file is not checked for here -- it will be | ||||
|                noticed on the first request for uncompressed data */ | ||||
|  | ||||
|             /* set up for decompression */ | ||||
|             inflateReset(strm); | ||||
|             strm->adler = crc32(0L, Z_NULL, 0); | ||||
|             state->how = GZIP; | ||||
|             state->direct = 0; | ||||
|             return 0; | ||||
|         } | ||||
|         else { | ||||
|             /* not a gzip file -- save first byte (31) and fall to raw i/o */ | ||||
|             state->out[0] = 31; | ||||
|             state->have = 1; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /* doing raw i/o, save start of raw data for seeking, copy any leftover | ||||
|        input to output -- this assumes that the output buffer is larger than | ||||
|        the input buffer, which also assures space for gzungetc() */ | ||||
|     state->raw = state->pos; | ||||
|     state->next = state->out; | ||||
|     if (strm->avail_in) { | ||||
|         memcpy(state->next + state->have, strm->next_in, strm->avail_in); | ||||
|         state->have += strm->avail_in; | ||||
|         strm->avail_in = 0; | ||||
|     } | ||||
|     state->how = COPY; | ||||
|     state->direct = 1; | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* Decompress from input to the provided next_out and avail_out in the state. | ||||
|    If the end of the compressed data is reached, then verify the gzip trailer | ||||
|    check value and length (modulo 2^32).  state->have and state->next are set | ||||
|    to point to the just decompressed data, and the crc is updated.  If the | ||||
|    trailer is verified, state->how is reset to LOOK to look for the next gzip | ||||
|    stream or raw data, once state->have is depleted.  Returns 0 on success, -1 | ||||
|    on failure.  Failures may include invalid compressed data or a failed gzip | ||||
|    trailer verification. */ | ||||
| local int gz_decomp(state) | ||||
|     gz_statep state; | ||||
| { | ||||
|     int ret; | ||||
|     unsigned had; | ||||
|     unsigned long crc, len; | ||||
|     z_streamp strm = &(state->strm); | ||||
|  | ||||
|     /* fill output buffer up to end of deflate stream */ | ||||
|     had = strm->avail_out; | ||||
|     do { | ||||
|         /* get more input for inflate() */ | ||||
|         if (strm->avail_in == 0 && gz_avail(state) == -1) | ||||
|             return -1; | ||||
|         if (strm->avail_in == 0) { | ||||
|             gz_error(state, Z_DATA_ERROR, "unexpected end of file"); | ||||
|             return -1; | ||||
|         } | ||||
|  | ||||
|         /* decompress and handle errors */ | ||||
|         ret = inflate(strm, Z_NO_FLUSH); | ||||
|         if (ret == Z_STREAM_ERROR || ret == Z_NEED_DICT) { | ||||
|             gz_error(state, Z_STREAM_ERROR, | ||||
|                       "internal error: inflate stream corrupt"); | ||||
|             return -1; | ||||
|         } | ||||
|         if (ret == Z_MEM_ERROR) { | ||||
|             gz_error(state, Z_MEM_ERROR, "out of memory"); | ||||
|             return -1; | ||||
|         } | ||||
|         if (ret == Z_DATA_ERROR) {              /* deflate stream invalid */ | ||||
|             gz_error(state, Z_DATA_ERROR, | ||||
|                       strm->msg == NULL ? "compressed data error" : strm->msg); | ||||
|             return -1; | ||||
|         } | ||||
|     } while (strm->avail_out && ret != Z_STREAM_END); | ||||
|  | ||||
|     /* update available output and crc check value */ | ||||
|     state->have = had - strm->avail_out; | ||||
|     state->next = strm->next_out - state->have; | ||||
|     strm->adler = crc32(strm->adler, state->next, state->have); | ||||
|  | ||||
|     /* check gzip trailer if at end of deflate stream */ | ||||
|     if (ret == Z_STREAM_END) { | ||||
|         if (gz_next4(state, &crc) == -1 || gz_next4(state, &len) == -1) { | ||||
|             gz_error(state, Z_DATA_ERROR, "unexpected end of file"); | ||||
|             return -1; | ||||
|         } | ||||
|         if (crc != strm->adler) { | ||||
|             gz_error(state, Z_DATA_ERROR, "incorrect data check"); | ||||
|             return -1; | ||||
|         } | ||||
|         if (len != (strm->total_out & 0xffffffffL)) { | ||||
|             gz_error(state, Z_DATA_ERROR, "incorrect length check"); | ||||
|             return -1; | ||||
|         } | ||||
|         state->how = LOOK;      /* ready for next stream, once have is 0 (leave | ||||
|                                    state->direct unchanged to remember how) */ | ||||
|     } | ||||
|  | ||||
|     /* good decompression */ | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* Make data and put in the output buffer.  Assumes that state->have == 0. | ||||
|    Data is either copied from the input file or decompressed from the input | ||||
|    file depending on state->how.  If state->how is LOOK, then a gzip header is | ||||
|    looked for (and skipped if found) to determine wither to copy or decompress. | ||||
|    Returns -1 on error, otherwise 0.  gz_make() will leave state->have as COPY | ||||
|    or GZIP unless the end of the input file has been reached and all data has | ||||
|    been processed.  */ | ||||
| local int gz_make(state) | ||||
|     gz_statep state; | ||||
| { | ||||
|     z_streamp strm = &(state->strm); | ||||
|  | ||||
|     if (state->how == LOOK) {           /* look for gzip header */ | ||||
|         if (gz_head(state) == -1) | ||||
|             return -1; | ||||
|         if (state->have)                /* got some data from gz_head() */ | ||||
|             return 0; | ||||
|     } | ||||
|     if (state->how == COPY) {           /* straight copy */ | ||||
|         if (gz_load(state, state->out, state->size << 1, &(state->have)) == -1) | ||||
|             return -1; | ||||
|         state->next = state->out; | ||||
|     } | ||||
|     else if (state->how == GZIP) {      /* decompress */ | ||||
|         strm->avail_out = state->size << 1; | ||||
|         strm->next_out = state->out; | ||||
|         if (gz_decomp(state) == -1) | ||||
|             return -1; | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* Skip len uncompressed bytes of output.  Return -1 on error, 0 on success. */ | ||||
| local int gz_skip(state, len) | ||||
|     gz_statep state; | ||||
|     z_off64_t len; | ||||
| { | ||||
|     unsigned n; | ||||
|  | ||||
|     /* skip over len bytes or reach end-of-file, whichever comes first */ | ||||
|     while (len) | ||||
|         /* skip over whatever is in output buffer */ | ||||
|         if (state->have) { | ||||
|             n = GT_OFF(state->have) || (z_off64_t)state->have > len ? | ||||
|                 (unsigned)len : state->have; | ||||
|             state->have -= n; | ||||
|             state->next += n; | ||||
|             state->pos += n; | ||||
|             len -= n; | ||||
|         } | ||||
|  | ||||
|         /* output buffer empty -- return if we're at the end of the input */ | ||||
|         else if (state->eof && state->strm.avail_in == 0) | ||||
|             break; | ||||
|  | ||||
|         /* need more data to skip -- load up output buffer */ | ||||
|         else { | ||||
|             /* get more output, looking for header if required */ | ||||
|             if (gz_make(state) == -1) | ||||
|                 return -1; | ||||
|         } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzread(file, buf, len) | ||||
|     gzFile file; | ||||
|     voidp buf; | ||||
|     unsigned len; | ||||
| { | ||||
|     unsigned got, n; | ||||
|     gz_statep state; | ||||
|     z_streamp strm; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|     strm = &(state->strm); | ||||
|  | ||||
|     /* check that we're reading and that there's no error */ | ||||
|     if (state->mode != GZ_READ || state->err != Z_OK) | ||||
|         return -1; | ||||
|  | ||||
|     /* since an int is returned, make sure len fits in one, otherwise return | ||||
|        with an error (this avoids the flaw in the interface) */ | ||||
|     if ((int)len < 0) { | ||||
|         gz_error(state, Z_BUF_ERROR, "requested length does not fit in int"); | ||||
|         return -1; | ||||
|     } | ||||
|  | ||||
|     /* if len is zero, avoid unnecessary operations */ | ||||
|     if (len == 0) | ||||
|         return 0; | ||||
|  | ||||
|     /* process a skip request */ | ||||
|     if (state->seek) { | ||||
|         state->seek = 0; | ||||
|         if (gz_skip(state, state->skip) == -1) | ||||
|             return -1; | ||||
|     } | ||||
|  | ||||
|     /* get len bytes to buf, or less than len if at the end */ | ||||
|     got = 0; | ||||
|     do { | ||||
|         /* first just try copying data from the output buffer */ | ||||
|         if (state->have) { | ||||
|             n = state->have > len ? len : state->have; | ||||
|             memcpy(buf, state->next, n); | ||||
|             state->next += n; | ||||
|             state->have -= n; | ||||
|         } | ||||
|  | ||||
|         /* output buffer empty -- return if we're at the end of the input */ | ||||
|         else if (state->eof && strm->avail_in == 0) | ||||
|             break; | ||||
|  | ||||
|         /* need output data -- for small len or new stream load up our output | ||||
|            buffer */ | ||||
|         else if (state->how == LOOK || len < (state->size << 1)) { | ||||
|             /* get more output, looking for header if required */ | ||||
|             if (gz_make(state) == -1) | ||||
|                 return -1; | ||||
|             continue;       /* no progress yet -- go back to memcpy() above */ | ||||
|             /* the copy above assures that we will leave with space in the | ||||
|                output buffer, allowing at least one gzungetc() to succeed */ | ||||
|         } | ||||
|  | ||||
|         /* large len -- read directly into user buffer */ | ||||
|         else if (state->how == COPY) {      /* read directly */ | ||||
|             if (gz_load(state, buf, len, &n) == -1) | ||||
|                 return -1; | ||||
|         } | ||||
|  | ||||
|         /* large len -- decompress directly into user buffer */ | ||||
|         else {  /* state->how == GZIP */ | ||||
|             strm->avail_out = len; | ||||
|             strm->next_out = buf; | ||||
|             if (gz_decomp(state) == -1) | ||||
|                 return -1; | ||||
|             n = state->have; | ||||
|             state->have = 0; | ||||
|         } | ||||
|  | ||||
|         /* update progress */ | ||||
|         len -= n; | ||||
|         buf = (char *)buf + n; | ||||
|         got += n; | ||||
|         state->pos += n; | ||||
|     } while (len); | ||||
|  | ||||
|     /* return number of bytes read into user buffer (will fit in int) */ | ||||
|     return (int)got; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzgetc(file) | ||||
|     gzFile file; | ||||
| { | ||||
|     int ret; | ||||
|     unsigned char buf[1]; | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|  | ||||
|     /* check that we're reading and that there's no error */ | ||||
|     if (state->mode != GZ_READ || state->err != Z_OK) | ||||
|         return -1; | ||||
|  | ||||
|     /* try output buffer (no need to check for skip request) */ | ||||
|     if (state->have) { | ||||
|         state->have--; | ||||
|         state->pos++; | ||||
|         return *(state->next)++; | ||||
|     } | ||||
|  | ||||
|     /* nothing there -- try gzread() */ | ||||
|     ret = gzread(file, buf, 1); | ||||
|     return ret < 1 ? -1 : buf[0]; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzungetc(c, file) | ||||
|     int c; | ||||
|     gzFile file; | ||||
| { | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|  | ||||
|     /* check that we're reading and that there's no error */ | ||||
|     if (state->mode != GZ_READ || state->err != Z_OK) | ||||
|         return -1; | ||||
|  | ||||
|     /* process a skip request */ | ||||
|     if (state->seek) { | ||||
|         state->seek = 0; | ||||
|         if (gz_skip(state, state->skip) == -1) | ||||
|             return -1; | ||||
|     } | ||||
|  | ||||
|     /* can't push EOF */ | ||||
|     if (c < 0) | ||||
|         return -1; | ||||
|  | ||||
|     /* if output buffer empty, put byte at end (allows more pushing) */ | ||||
|     if (state->have == 0) { | ||||
|         state->have = 1; | ||||
|         state->next = state->out + (state->size << 1) - 1; | ||||
|         state->next[0] = c; | ||||
|         state->pos--; | ||||
|         return c; | ||||
|     } | ||||
|  | ||||
|     /* if no room, give up (must have already done a gzungetc()) */ | ||||
|     if (state->have == (state->size << 1)) { | ||||
|         gz_error(state, Z_BUF_ERROR, "out of room to push characters"); | ||||
|         return -1; | ||||
|     } | ||||
|  | ||||
|     /* slide output data if needed and insert byte before existing data */ | ||||
|     if (state->next == state->out) { | ||||
|         unsigned char *src = state->out + state->have; | ||||
|         unsigned char *dest = state->out + (state->size << 1); | ||||
|         while (src > state->out) | ||||
|             *--dest = *--src; | ||||
|         state->next = dest; | ||||
|     } | ||||
|     state->have++; | ||||
|     state->next--; | ||||
|     state->next[0] = c; | ||||
|     state->pos--; | ||||
|     return c; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| char * ZEXPORT gzgets(file, buf, len) | ||||
|     gzFile file; | ||||
|     char *buf; | ||||
|     int len; | ||||
| { | ||||
|     unsigned left, n; | ||||
|     char *str; | ||||
|     unsigned char *eol; | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* check parameters and get internal structure */ | ||||
|     if (file == NULL || buf == NULL || len < 1) | ||||
|         return NULL; | ||||
|     state = (gz_statep)file; | ||||
|  | ||||
|     /* check that we're reading and that there's no error */ | ||||
|     if (state->mode != GZ_READ || state->err != Z_OK) | ||||
|         return NULL; | ||||
|  | ||||
|     /* process a skip request */ | ||||
|     if (state->seek) { | ||||
|         state->seek = 0; | ||||
|         if (gz_skip(state, state->skip) == -1) | ||||
|             return NULL; | ||||
|     } | ||||
|  | ||||
|     /* copy output bytes up to new line or len - 1, whichever comes first -- | ||||
|        append a terminating zero to the string (we don't check for a zero in | ||||
|        the contents, let the user worry about that) */ | ||||
|     str = buf; | ||||
|     left = (unsigned)len - 1; | ||||
|     if (left) do { | ||||
|         /* assure that something is in the output buffer */ | ||||
|         if (state->have == 0) { | ||||
|             if (gz_make(state) == -1) | ||||
|                 return NULL;            /* error */ | ||||
|             if (state->have == 0) {     /* end of file */ | ||||
|                 if (buf == str)         /* got bupkus */ | ||||
|                     return NULL; | ||||
|                 break;                  /* got something -- return it */ | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         /* look for end-of-line in current output buffer */ | ||||
|         n = state->have > left ? left : state->have; | ||||
|         eol = memchr(state->next, '\n', n); | ||||
|         if (eol != NULL) | ||||
|             n = (unsigned)(eol - state->next) + 1; | ||||
|  | ||||
|         /* copy through end-of-line, or remainder if not found */ | ||||
|         memcpy(buf, state->next, n); | ||||
|         state->have -= n; | ||||
|         state->next += n; | ||||
|         state->pos += n; | ||||
|         left -= n; | ||||
|         buf += n; | ||||
|     } while (left && eol == NULL); | ||||
|  | ||||
|     /* found end-of-line or out of space -- terminate string and return it */ | ||||
|     buf[0] = 0; | ||||
|     return str; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzdirect(file) | ||||
|     gzFile file; | ||||
| { | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return 0; | ||||
|     state = (gz_statep)file; | ||||
|  | ||||
|     /* check that we're reading */ | ||||
|     if (state->mode != GZ_READ) | ||||
|         return 0; | ||||
|  | ||||
|     /* if the state is not known, but we can find out, then do so (this is | ||||
|        mainly for right after a gzopen() or gzdopen()) */ | ||||
|     if (state->how == LOOK && state->have == 0) | ||||
|         (void)gz_head(state); | ||||
|  | ||||
|     /* return 1 if reading direct, 0 if decompressing a gzip stream */ | ||||
|     return state->direct; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzclose_r(file) | ||||
|     gzFile file; | ||||
| { | ||||
|     int ret; | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return Z_STREAM_ERROR; | ||||
|     state = (gz_statep)file; | ||||
|  | ||||
|     /* check that we're reading */ | ||||
|     if (state->mode != GZ_READ) | ||||
|         return Z_STREAM_ERROR; | ||||
|  | ||||
|     /* free memory and close file */ | ||||
|     if (state->size) { | ||||
|         inflateEnd(&(state->strm)); | ||||
|         free(state->out); | ||||
|         free(state->in); | ||||
|     } | ||||
|     gz_error(state, Z_OK, NULL); | ||||
|     free(state->path); | ||||
|     ret = close(state->fd); | ||||
|     free(state); | ||||
|     return ret ? Z_ERRNO : Z_OK; | ||||
| } | ||||
							
								
								
									
										531
									
								
								Foundation/src/gzwrite.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										531
									
								
								Foundation/src/gzwrite.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,531 @@ | ||||
| /* gzwrite.c -- zlib functions for writing gzip files | ||||
|  * Copyright (C) 2004, 2005, 2010 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| #include "gzguts.h" | ||||
|  | ||||
| /* Local functions */ | ||||
| local int gz_init OF((gz_statep)); | ||||
| local int gz_comp OF((gz_statep, int)); | ||||
| local int gz_zero OF((gz_statep, z_off64_t)); | ||||
|  | ||||
| /* Initialize state for writing a gzip file.  Mark initialization by setting | ||||
|    state->size to non-zero.  Return -1 on failure or 0 on success. */ | ||||
| local int gz_init(state) | ||||
|     gz_statep state; | ||||
| { | ||||
|     int ret; | ||||
|     z_streamp strm = &(state->strm); | ||||
|  | ||||
|     /* allocate input and output buffers */ | ||||
|     state->in = malloc(state->want); | ||||
|     state->out = malloc(state->want); | ||||
|     if (state->in == NULL || state->out == NULL) { | ||||
|         if (state->out != NULL) | ||||
|             free(state->out); | ||||
|         if (state->in != NULL) | ||||
|             free(state->in); | ||||
|         gz_error(state, Z_MEM_ERROR, "out of memory"); | ||||
|         return -1; | ||||
|     } | ||||
|  | ||||
|     /* allocate deflate memory, set up for gzip compression */ | ||||
|     strm->zalloc = Z_NULL; | ||||
|     strm->zfree = Z_NULL; | ||||
|     strm->opaque = Z_NULL; | ||||
|     ret = deflateInit2(strm, state->level, Z_DEFLATED, | ||||
|                        15 + 16, 8, state->strategy); | ||||
|     if (ret != Z_OK) { | ||||
|         free(state->in); | ||||
|         gz_error(state, Z_MEM_ERROR, "out of memory"); | ||||
|         return -1; | ||||
|     } | ||||
|  | ||||
|     /* mark state as initialized */ | ||||
|     state->size = state->want; | ||||
|  | ||||
|     /* initialize write buffer */ | ||||
|     strm->avail_out = state->size; | ||||
|     strm->next_out = state->out; | ||||
|     state->next = strm->next_out; | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* Compress whatever is at avail_in and next_in and write to the output file. | ||||
|    Return -1 if there is an error writing to the output file, otherwise 0. | ||||
|    flush is assumed to be a valid deflate() flush value.  If flush is Z_FINISH, | ||||
|    then the deflate() state is reset to start a new gzip stream. */ | ||||
| local int gz_comp(state, flush) | ||||
|     gz_statep state; | ||||
|     int flush; | ||||
| { | ||||
|     int ret, got; | ||||
|     unsigned have; | ||||
|     z_streamp strm = &(state->strm); | ||||
|  | ||||
|     /* allocate memory if this is the first time through */ | ||||
|     if (state->size == 0 && gz_init(state) == -1) | ||||
|         return -1; | ||||
|  | ||||
|     /* run deflate() on provided input until it produces no more output */ | ||||
|     ret = Z_OK; | ||||
|     do { | ||||
|         /* write out current buffer contents if full, or if flushing, but if | ||||
|            doing Z_FINISH then don't write until we get to Z_STREAM_END */ | ||||
|         if (strm->avail_out == 0 || (flush != Z_NO_FLUSH && | ||||
|             (flush != Z_FINISH || ret == Z_STREAM_END))) { | ||||
|             have = (unsigned)(strm->next_out - state->next); | ||||
|             if (have && ((got = write(state->fd, state->next, have)) < 0 || | ||||
|                          (unsigned)got != have)) { | ||||
|                 gz_error(state, Z_ERRNO, zstrerror()); | ||||
|                 return -1; | ||||
|             } | ||||
|             if (strm->avail_out == 0) { | ||||
|                 strm->avail_out = state->size; | ||||
|                 strm->next_out = state->out; | ||||
|             } | ||||
|             state->next = strm->next_out; | ||||
|         } | ||||
|  | ||||
|         /* compress */ | ||||
|         have = strm->avail_out; | ||||
|         ret = deflate(strm, flush); | ||||
|         if (ret == Z_STREAM_ERROR) { | ||||
|             gz_error(state, Z_STREAM_ERROR, | ||||
|                       "internal error: deflate stream corrupt"); | ||||
|             return -1; | ||||
|         } | ||||
|         have -= strm->avail_out; | ||||
|     } while (have); | ||||
|  | ||||
|     /* if that completed a deflate stream, allow another to start */ | ||||
|     if (flush == Z_FINISH) | ||||
|         deflateReset(strm); | ||||
|  | ||||
|     /* all done, no errors */ | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* Compress len zeros to output.  Return -1 on error, 0 on success. */ | ||||
| local int gz_zero(state, len) | ||||
|     gz_statep state; | ||||
|     z_off64_t len; | ||||
| { | ||||
|     int first; | ||||
|     unsigned n; | ||||
|     z_streamp strm = &(state->strm); | ||||
|  | ||||
|     /* consume whatever's left in the input buffer */ | ||||
|     if (strm->avail_in && gz_comp(state, Z_NO_FLUSH) == -1) | ||||
|         return -1; | ||||
|  | ||||
|     /* compress len zeros (len guaranteed > 0) */ | ||||
|     first = 1; | ||||
|     while (len) { | ||||
|         n = GT_OFF(state->size) || (z_off64_t)state->size > len ? | ||||
|             (unsigned)len : state->size; | ||||
|         if (first) { | ||||
|             memset(state->in, 0, n); | ||||
|             first = 0; | ||||
|         } | ||||
|         strm->avail_in = n; | ||||
|         strm->next_in = state->in; | ||||
|         state->pos += n; | ||||
|         if (gz_comp(state, Z_NO_FLUSH) == -1) | ||||
|             return -1; | ||||
|         len -= n; | ||||
|     } | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzwrite(file, buf, len) | ||||
|     gzFile file; | ||||
|     voidpc buf; | ||||
|     unsigned len; | ||||
| { | ||||
|     unsigned put = len; | ||||
|     unsigned n; | ||||
|     gz_statep state; | ||||
|     z_streamp strm; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return 0; | ||||
|     state = (gz_statep)file; | ||||
|     strm = &(state->strm); | ||||
|  | ||||
|     /* check that we're writing and that there's no error */ | ||||
|     if (state->mode != GZ_WRITE || state->err != Z_OK) | ||||
|         return 0; | ||||
|  | ||||
|     /* since an int is returned, make sure len fits in one, otherwise return | ||||
|        with an error (this avoids the flaw in the interface) */ | ||||
|     if ((int)len < 0) { | ||||
|         gz_error(state, Z_BUF_ERROR, "requested length does not fit in int"); | ||||
|         return 0; | ||||
|     } | ||||
|  | ||||
|     /* if len is zero, avoid unnecessary operations */ | ||||
|     if (len == 0) | ||||
|         return 0; | ||||
|  | ||||
|     /* allocate memory if this is the first time through */ | ||||
|     if (state->size == 0 && gz_init(state) == -1) | ||||
|         return 0; | ||||
|  | ||||
|     /* check for seek request */ | ||||
|     if (state->seek) { | ||||
|         state->seek = 0; | ||||
|         if (gz_zero(state, state->skip) == -1) | ||||
|             return 0; | ||||
|     } | ||||
|  | ||||
|     /* for small len, copy to input buffer, otherwise compress directly */ | ||||
|     if (len < state->size) { | ||||
|         /* copy to input buffer, compress when full */ | ||||
|         do { | ||||
|             if (strm->avail_in == 0) | ||||
|                 strm->next_in = state->in; | ||||
|             n = state->size - strm->avail_in; | ||||
|             if (n > len) | ||||
|                 n = len; | ||||
|             memcpy(strm->next_in + strm->avail_in, buf, n); | ||||
|             strm->avail_in += n; | ||||
|             state->pos += n; | ||||
|             buf = (char *)buf + n; | ||||
|             len -= n; | ||||
|             if (len && gz_comp(state, Z_NO_FLUSH) == -1) | ||||
|                 return 0; | ||||
|         } while (len); | ||||
|     } | ||||
|     else { | ||||
|         /* consume whatever's left in the input buffer */ | ||||
|         if (strm->avail_in && gz_comp(state, Z_NO_FLUSH) == -1) | ||||
|             return 0; | ||||
|  | ||||
|         /* directly compress user buffer to file */ | ||||
|         strm->avail_in = len; | ||||
|         strm->next_in = (voidp)buf; | ||||
|         state->pos += len; | ||||
|         if (gz_comp(state, Z_NO_FLUSH) == -1) | ||||
|             return 0; | ||||
|     } | ||||
|  | ||||
|     /* input was all buffered or compressed (put will fit in int) */ | ||||
|     return (int)put; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzputc(file, c) | ||||
|     gzFile file; | ||||
|     int c; | ||||
| { | ||||
|     unsigned char buf[1]; | ||||
|     gz_statep state; | ||||
|     z_streamp strm; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|     strm = &(state->strm); | ||||
|  | ||||
|     /* check that we're writing and that there's no error */ | ||||
|     if (state->mode != GZ_WRITE || state->err != Z_OK) | ||||
|         return -1; | ||||
|  | ||||
|     /* check for seek request */ | ||||
|     if (state->seek) { | ||||
|         state->seek = 0; | ||||
|         if (gz_zero(state, state->skip) == -1) | ||||
|             return -1; | ||||
|     } | ||||
|  | ||||
|     /* try writing to input buffer for speed (state->size == 0 if buffer not | ||||
|        initialized) */ | ||||
|     if (strm->avail_in < state->size) { | ||||
|         if (strm->avail_in == 0) | ||||
|             strm->next_in = state->in; | ||||
|         strm->next_in[strm->avail_in++] = c; | ||||
|         state->pos++; | ||||
|         return c; | ||||
|     } | ||||
|  | ||||
|     /* no room in buffer or not initialized, use gz_write() */ | ||||
|     buf[0] = c; | ||||
|     if (gzwrite(file, buf, 1) != 1) | ||||
|         return -1; | ||||
|     return c; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzputs(file, str) | ||||
|     gzFile file; | ||||
|     const char *str; | ||||
| { | ||||
|     int ret; | ||||
|     unsigned len; | ||||
|  | ||||
|     /* write string */ | ||||
|     len = (unsigned)strlen(str); | ||||
|     ret = gzwrite(file, str, len); | ||||
|     return ret == 0 && len != 0 ? -1 : ret; | ||||
| } | ||||
|  | ||||
| #ifdef STDC | ||||
| #include <stdarg.h> | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORTVA gzprintf (gzFile file, const char *format, ...) | ||||
| { | ||||
|     int size, len; | ||||
|     gz_statep state; | ||||
|     z_streamp strm; | ||||
|     va_list va; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|     strm = &(state->strm); | ||||
|  | ||||
|     /* check that we're writing and that there's no error */ | ||||
|     if (state->mode != GZ_WRITE || state->err != Z_OK) | ||||
|         return 0; | ||||
|  | ||||
|     /* make sure we have some buffer space */ | ||||
|     if (state->size == 0 && gz_init(state) == -1) | ||||
|         return 0; | ||||
|  | ||||
|     /* check for seek request */ | ||||
|     if (state->seek) { | ||||
|         state->seek = 0; | ||||
|         if (gz_zero(state, state->skip) == -1) | ||||
|             return 0; | ||||
|     } | ||||
|  | ||||
|     /* consume whatever's left in the input buffer */ | ||||
|     if (strm->avail_in && gz_comp(state, Z_NO_FLUSH) == -1) | ||||
|         return 0; | ||||
|  | ||||
|     /* do the printf() into the input buffer, put length in len */ | ||||
|     size = (int)(state->size); | ||||
|     state->in[size - 1] = 0; | ||||
|     va_start(va, format); | ||||
| #ifdef NO_vsnprintf | ||||
| #  ifdef HAS_vsprintf_void | ||||
|     (void)vsprintf(state->in, format, va); | ||||
|     va_end(va); | ||||
|     for (len = 0; len < size; len++) | ||||
|         if (state->in[len] == 0) break; | ||||
| #  else | ||||
|     len = vsprintf(state->in, format, va); | ||||
|     va_end(va); | ||||
| #  endif | ||||
| #else | ||||
| #  ifdef HAS_vsnprintf_void | ||||
|     (void)vsnprintf(state->in, size, format, va); | ||||
|     va_end(va); | ||||
|     len = strlen(state->in); | ||||
| #  else | ||||
|     len = vsnprintf((char *)(state->in), size, format, va); | ||||
|     va_end(va); | ||||
| #  endif | ||||
| #endif | ||||
|  | ||||
|     /* check that printf() results fit in buffer */ | ||||
|     if (len <= 0 || len >= (int)size || state->in[size - 1] != 0) | ||||
|         return 0; | ||||
|  | ||||
|     /* update buffer and position, defer compression until needed */ | ||||
|     strm->avail_in = (unsigned)len; | ||||
|     strm->next_in = state->in; | ||||
|     state->pos += len; | ||||
|     return len; | ||||
| } | ||||
|  | ||||
| #else /* !STDC */ | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORTVA gzprintf (file, format, a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, | ||||
|                        a11, a12, a13, a14, a15, a16, a17, a18, a19, a20) | ||||
|     gzFile file; | ||||
|     const char *format; | ||||
|     int a1, a2, a3, a4, a5, a6, a7, a8, a9, a10, | ||||
|         a11, a12, a13, a14, a15, a16, a17, a18, a19, a20; | ||||
| { | ||||
|     int size, len; | ||||
|     gz_statep state; | ||||
|     z_streamp strm; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|     strm = &(state->strm); | ||||
|  | ||||
|     /* check that we're writing and that there's no error */ | ||||
|     if (state->mode != GZ_WRITE || state->err != Z_OK) | ||||
|         return 0; | ||||
|  | ||||
|     /* make sure we have some buffer space */ | ||||
|     if (state->size == 0 && gz_init(state) == -1) | ||||
|         return 0; | ||||
|  | ||||
|     /* check for seek request */ | ||||
|     if (state->seek) { | ||||
|         state->seek = 0; | ||||
|         if (gz_zero(state, state->skip) == -1) | ||||
|             return 0; | ||||
|     } | ||||
|  | ||||
|     /* consume whatever's left in the input buffer */ | ||||
|     if (strm->avail_in && gz_comp(state, Z_NO_FLUSH) == -1) | ||||
|         return 0; | ||||
|  | ||||
|     /* do the printf() into the input buffer, put length in len */ | ||||
|     size = (int)(state->size); | ||||
|     state->in[size - 1] = 0; | ||||
| #ifdef NO_snprintf | ||||
| #  ifdef HAS_sprintf_void | ||||
|     sprintf(state->in, format, a1, a2, a3, a4, a5, a6, a7, a8, | ||||
|             a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); | ||||
|     for (len = 0; len < size; len++) | ||||
|         if (state->in[len] == 0) break; | ||||
| #  else | ||||
|     len = sprintf(state->in, format, a1, a2, a3, a4, a5, a6, a7, a8, | ||||
|                 a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); | ||||
| #  endif | ||||
| #else | ||||
| #  ifdef HAS_snprintf_void | ||||
|     snprintf(state->in, size, format, a1, a2, a3, a4, a5, a6, a7, a8, | ||||
|              a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); | ||||
|     len = strlen(state->in); | ||||
| #  else | ||||
|     len = snprintf(state->in, size, format, a1, a2, a3, a4, a5, a6, a7, a8, | ||||
|                  a9, a10, a11, a12, a13, a14, a15, a16, a17, a18, a19, a20); | ||||
| #  endif | ||||
| #endif | ||||
|  | ||||
|     /* check that printf() results fit in buffer */ | ||||
|     if (len <= 0 || len >= (int)size || state->in[size - 1] != 0) | ||||
|         return 0; | ||||
|  | ||||
|     /* update buffer and position, defer compression until needed */ | ||||
|     strm->avail_in = (unsigned)len; | ||||
|     strm->next_in = state->in; | ||||
|     state->pos += len; | ||||
|     return len; | ||||
| } | ||||
|  | ||||
| #endif | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzflush(file, flush) | ||||
|     gzFile file; | ||||
|     int flush; | ||||
| { | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return -1; | ||||
|     state = (gz_statep)file; | ||||
|  | ||||
|     /* check that we're writing and that there's no error */ | ||||
|     if (state->mode != GZ_WRITE || state->err != Z_OK) | ||||
|         return Z_STREAM_ERROR; | ||||
|  | ||||
|     /* check flush parameter */ | ||||
|     if (flush < 0 || flush > Z_FINISH) | ||||
|         return Z_STREAM_ERROR; | ||||
|  | ||||
|     /* check for seek request */ | ||||
|     if (state->seek) { | ||||
|         state->seek = 0; | ||||
|         if (gz_zero(state, state->skip) == -1) | ||||
|             return -1; | ||||
|     } | ||||
|  | ||||
|     /* compress remaining data with requested flush */ | ||||
|     gz_comp(state, flush); | ||||
|     return state->err; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzsetparams(file, level, strategy) | ||||
|     gzFile file; | ||||
|     int level; | ||||
|     int strategy; | ||||
| { | ||||
|     gz_statep state; | ||||
|     z_streamp strm; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return Z_STREAM_ERROR; | ||||
|     state = (gz_statep)file; | ||||
|     strm = &(state->strm); | ||||
|  | ||||
|     /* check that we're writing and that there's no error */ | ||||
|     if (state->mode != GZ_WRITE || state->err != Z_OK) | ||||
|         return Z_STREAM_ERROR; | ||||
|  | ||||
|     /* if no change is requested, then do nothing */ | ||||
|     if (level == state->level && strategy == state->strategy) | ||||
|         return Z_OK; | ||||
|  | ||||
|     /* check for seek request */ | ||||
|     if (state->seek) { | ||||
|         state->seek = 0; | ||||
|         if (gz_zero(state, state->skip) == -1) | ||||
|             return -1; | ||||
|     } | ||||
|  | ||||
|     /* change compression parameters for subsequent input */ | ||||
|     if (state->size) { | ||||
|         /* flush previous input with previous parameters before changing */ | ||||
|         if (strm->avail_in && gz_comp(state, Z_PARTIAL_FLUSH) == -1) | ||||
|             return state->err; | ||||
|         deflateParams(strm, level, strategy); | ||||
|     } | ||||
|     state->level = level; | ||||
|     state->strategy = strategy; | ||||
|     return Z_OK; | ||||
| } | ||||
|  | ||||
| /* -- see zlib.h -- */ | ||||
| int ZEXPORT gzclose_w(file) | ||||
|     gzFile file; | ||||
| { | ||||
|     int ret = 0; | ||||
|     gz_statep state; | ||||
|  | ||||
|     /* get internal structure */ | ||||
|     if (file == NULL) | ||||
|         return Z_STREAM_ERROR; | ||||
|     state = (gz_statep)file; | ||||
|  | ||||
|     /* check that we're writing */ | ||||
|     if (state->mode != GZ_WRITE) | ||||
|         return Z_STREAM_ERROR; | ||||
|  | ||||
|     /* check for seek request */ | ||||
|     if (state->seek) { | ||||
|         state->seek = 0; | ||||
|         ret += gz_zero(state, state->skip); | ||||
|     } | ||||
|  | ||||
|     /* flush, free memory, and close file */ | ||||
|     ret += gz_comp(state, Z_FINISH); | ||||
|     (void)deflateEnd(&(state->strm)); | ||||
|     free(state->out); | ||||
|     free(state->in); | ||||
|     gz_error(state, Z_OK, NULL); | ||||
|     free(state->path); | ||||
|     ret += close(state->fd); | ||||
|     free(state); | ||||
|     return ret ? Z_ERRNO : Z_OK; | ||||
| } | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* infback.c -- inflate using a call-back interface | ||||
|  * Copyright (C) 1995-2005 Mark Adler | ||||
|  * Copyright (C) 1995-2009 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| @@ -55,7 +55,7 @@ int stream_size; | ||||
|     state->wbits = windowBits; | ||||
|     state->wsize = 1U << windowBits; | ||||
|     state->window = window; | ||||
|     state->write = 0; | ||||
|     state->wnext = 0; | ||||
|     state->whave = 0; | ||||
|     return Z_OK; | ||||
| } | ||||
| @@ -253,7 +253,7 @@ void FAR *out_desc; | ||||
|     unsigned bits;              /* bits in bit buffer */ | ||||
|     unsigned copy;              /* number of stored or match bytes to copy */ | ||||
|     unsigned char FAR *from;    /* where to copy match bytes from */ | ||||
|     code this;                  /* current decoding table entry */ | ||||
|     code here;                  /* current decoding table entry */ | ||||
|     code last;                  /* parent table entry */ | ||||
|     unsigned len;               /* length to copy for repeats, bits to drop */ | ||||
|     int ret;                    /* return code */ | ||||
| @@ -389,19 +389,19 @@ void FAR *out_desc; | ||||
|             state->have = 0; | ||||
|             while (state->have < state->nlen + state->ndist) { | ||||
|                 for (;;) { | ||||
|                     this = state->lencode[BITS(state->lenbits)]; | ||||
|                     if ((unsigned)(this.bits) <= bits) break; | ||||
|                     here = state->lencode[BITS(state->lenbits)]; | ||||
|                     if ((unsigned)(here.bits) <= bits) break; | ||||
|                     PULLBYTE(); | ||||
|                 } | ||||
|                 if (this.val < 16) { | ||||
|                     NEEDBITS(this.bits); | ||||
|                     DROPBITS(this.bits); | ||||
|                     state->lens[state->have++] = this.val; | ||||
|                 if (here.val < 16) { | ||||
|                     NEEDBITS(here.bits); | ||||
|                     DROPBITS(here.bits); | ||||
|                     state->lens[state->have++] = here.val; | ||||
|                 } | ||||
|                 else { | ||||
|                     if (this.val == 16) { | ||||
|                         NEEDBITS(this.bits + 2); | ||||
|                         DROPBITS(this.bits); | ||||
|                     if (here.val == 16) { | ||||
|                         NEEDBITS(here.bits + 2); | ||||
|                         DROPBITS(here.bits); | ||||
|                         if (state->have == 0) { | ||||
|                             strm->msg = (char *)"invalid bit length repeat"; | ||||
|                             state->mode = BAD; | ||||
| @@ -411,16 +411,16 @@ void FAR *out_desc; | ||||
|                         copy = 3 + BITS(2); | ||||
|                         DROPBITS(2); | ||||
|                     } | ||||
|                     else if (this.val == 17) { | ||||
|                         NEEDBITS(this.bits + 3); | ||||
|                         DROPBITS(this.bits); | ||||
|                     else if (here.val == 17) { | ||||
|                         NEEDBITS(here.bits + 3); | ||||
|                         DROPBITS(here.bits); | ||||
|                         len = 0; | ||||
|                         copy = 3 + BITS(3); | ||||
|                         DROPBITS(3); | ||||
|                     } | ||||
|                     else { | ||||
|                         NEEDBITS(this.bits + 7); | ||||
|                         DROPBITS(this.bits); | ||||
|                         NEEDBITS(here.bits + 7); | ||||
|                         DROPBITS(here.bits); | ||||
|                         len = 0; | ||||
|                         copy = 11 + BITS(7); | ||||
|                         DROPBITS(7); | ||||
| @@ -438,7 +438,16 @@ void FAR *out_desc; | ||||
|             /* handle error breaks in while */ | ||||
|             if (state->mode == BAD) break; | ||||
|  | ||||
|             /* build code tables */ | ||||
|             /* check for end-of-block code (better have one) */ | ||||
|             if (state->lens[256] == 0) { | ||||
|                 strm->msg = (char *)"invalid code -- missing end-of-block"; | ||||
|                 state->mode = BAD; | ||||
|                 break; | ||||
|             } | ||||
|  | ||||
|             /* build code tables -- note: do not change the lenbits or distbits | ||||
|                values here (9 and 6) without reading the comments in inftrees.h | ||||
|                concerning the ENOUGH constants, which depend on those values */ | ||||
|             state->next = state->codes; | ||||
|             state->lencode = (code const FAR *)(state->next); | ||||
|             state->lenbits = 9; | ||||
| @@ -474,28 +483,28 @@ void FAR *out_desc; | ||||
|  | ||||
|             /* get a literal, length, or end-of-block code */ | ||||
|             for (;;) { | ||||
|                 this = state->lencode[BITS(state->lenbits)]; | ||||
|                 if ((unsigned)(this.bits) <= bits) break; | ||||
|                 here = state->lencode[BITS(state->lenbits)]; | ||||
|                 if ((unsigned)(here.bits) <= bits) break; | ||||
|                 PULLBYTE(); | ||||
|             } | ||||
|             if (this.op && (this.op & 0xf0) == 0) { | ||||
|                 last = this; | ||||
|             if (here.op && (here.op & 0xf0) == 0) { | ||||
|                 last = here; | ||||
|                 for (;;) { | ||||
|                     this = state->lencode[last.val + | ||||
|                     here = state->lencode[last.val + | ||||
|                             (BITS(last.bits + last.op) >> last.bits)]; | ||||
|                     if ((unsigned)(last.bits + this.bits) <= bits) break; | ||||
|                     if ((unsigned)(last.bits + here.bits) <= bits) break; | ||||
|                     PULLBYTE(); | ||||
|                 } | ||||
|                 DROPBITS(last.bits); | ||||
|             } | ||||
|             DROPBITS(this.bits); | ||||
|             state->length = (unsigned)this.val; | ||||
|             DROPBITS(here.bits); | ||||
|             state->length = (unsigned)here.val; | ||||
|  | ||||
|             /* process literal */ | ||||
|             if (this.op == 0) { | ||||
|                 Tracevv((stderr, this.val >= 0x20 && this.val < 0x7f ? | ||||
|             if (here.op == 0) { | ||||
|                 Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ? | ||||
|                         "inflate:         literal '%c'\n" : | ||||
|                         "inflate:         literal 0x%02x\n", this.val)); | ||||
|                         "inflate:         literal 0x%02x\n", here.val)); | ||||
|                 ROOM(); | ||||
|                 *put++ = (unsigned char)(state->length); | ||||
|                 left--; | ||||
| @@ -504,21 +513,21 @@ void FAR *out_desc; | ||||
|             } | ||||
|  | ||||
|             /* process end of block */ | ||||
|             if (this.op & 32) { | ||||
|             if (here.op & 32) { | ||||
|                 Tracevv((stderr, "inflate:         end of block\n")); | ||||
|                 state->mode = TYPE; | ||||
|                 break; | ||||
|             } | ||||
|  | ||||
|             /* invalid code */ | ||||
|             if (this.op & 64) { | ||||
|             if (here.op & 64) { | ||||
|                 strm->msg = (char *)"invalid literal/length code"; | ||||
|                 state->mode = BAD; | ||||
|                 break; | ||||
|             } | ||||
|  | ||||
|             /* length code -- get extra bits, if any */ | ||||
|             state->extra = (unsigned)(this.op) & 15; | ||||
|             state->extra = (unsigned)(here.op) & 15; | ||||
|             if (state->extra != 0) { | ||||
|                 NEEDBITS(state->extra); | ||||
|                 state->length += BITS(state->extra); | ||||
| @@ -528,30 +537,30 @@ void FAR *out_desc; | ||||
|  | ||||
|             /* get distance code */ | ||||
|             for (;;) { | ||||
|                 this = state->distcode[BITS(state->distbits)]; | ||||
|                 if ((unsigned)(this.bits) <= bits) break; | ||||
|                 here = state->distcode[BITS(state->distbits)]; | ||||
|                 if ((unsigned)(here.bits) <= bits) break; | ||||
|                 PULLBYTE(); | ||||
|             } | ||||
|             if ((this.op & 0xf0) == 0) { | ||||
|                 last = this; | ||||
|             if ((here.op & 0xf0) == 0) { | ||||
|                 last = here; | ||||
|                 for (;;) { | ||||
|                     this = state->distcode[last.val + | ||||
|                     here = state->distcode[last.val + | ||||
|                             (BITS(last.bits + last.op) >> last.bits)]; | ||||
|                     if ((unsigned)(last.bits + this.bits) <= bits) break; | ||||
|                     if ((unsigned)(last.bits + here.bits) <= bits) break; | ||||
|                     PULLBYTE(); | ||||
|                 } | ||||
|                 DROPBITS(last.bits); | ||||
|             } | ||||
|             DROPBITS(this.bits); | ||||
|             if (this.op & 64) { | ||||
|             DROPBITS(here.bits); | ||||
|             if (here.op & 64) { | ||||
|                 strm->msg = (char *)"invalid distance code"; | ||||
|                 state->mode = BAD; | ||||
|                 break; | ||||
|             } | ||||
|             state->offset = (unsigned)this.val; | ||||
|             state->offset = (unsigned)here.val; | ||||
|  | ||||
|             /* get distance extra bits, if any */ | ||||
|             state->extra = (unsigned)(this.op) & 15; | ||||
|             state->extra = (unsigned)(here.op) & 15; | ||||
|             if (state->extra != 0) { | ||||
|                 NEEDBITS(state->extra); | ||||
|                 state->offset += BITS(state->extra); | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* inffast.c -- fast decoding | ||||
|  * Copyright (C) 1995-2004 Mark Adler | ||||
|  * Copyright (C) 1995-2008, 2010 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| @@ -64,7 +64,7 @@ | ||||
|       requires strm->avail_out >= 258 for each loop to avoid checking for | ||||
|       output space. | ||||
|  */ | ||||
| void inflate_fast(strm, start) | ||||
| void ZLIB_INTERNAL inflate_fast(strm, start) | ||||
| z_streamp strm; | ||||
| unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
| { | ||||
| @@ -79,7 +79,7 @@ unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
| #endif | ||||
|     unsigned wsize;             /* window size or zero if not using window */ | ||||
|     unsigned whave;             /* valid bytes in the window */ | ||||
|     unsigned write;             /* window write index */ | ||||
|     unsigned wnext;             /* window write index */ | ||||
|     unsigned char FAR *window;  /* allocated sliding window, if wsize != 0 */ | ||||
|     unsigned long hold;         /* local strm->hold */ | ||||
|     unsigned bits;              /* local strm->bits */ | ||||
| @@ -87,7 +87,7 @@ unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
|     code const FAR *dcode;      /* local strm->distcode */ | ||||
|     unsigned lmask;             /* mask for first level of length codes */ | ||||
|     unsigned dmask;             /* mask for first level of distance codes */ | ||||
|     code this;                  /* retrieved table entry */ | ||||
|     code here;                  /* retrieved table entry */ | ||||
|     unsigned op;                /* code bits, operation, extra bits, or */ | ||||
|                                 /*  window position, window bytes to copy */ | ||||
|     unsigned len;               /* match length, unused bytes */ | ||||
| @@ -106,7 +106,7 @@ unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
| #endif | ||||
|     wsize = state->wsize; | ||||
|     whave = state->whave; | ||||
|     write = state->write; | ||||
|     wnext = state->wnext; | ||||
|     window = state->window; | ||||
|     hold = state->hold; | ||||
|     bits = state->bits; | ||||
| @@ -124,20 +124,20 @@ unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
|             hold += (unsigned long)(PUP(in)) << bits; | ||||
|             bits += 8; | ||||
|         } | ||||
|         this = lcode[hold & lmask]; | ||||
|         here = lcode[hold & lmask]; | ||||
|       dolen: | ||||
|         op = (unsigned)(this.bits); | ||||
|         op = (unsigned)(here.bits); | ||||
|         hold >>= op; | ||||
|         bits -= op; | ||||
|         op = (unsigned)(this.op); | ||||
|         op = (unsigned)(here.op); | ||||
|         if (op == 0) {                          /* literal */ | ||||
|             Tracevv((stderr, this.val >= 0x20 && this.val < 0x7f ? | ||||
|             Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ? | ||||
|                     "inflate:         literal '%c'\n" : | ||||
|                     "inflate:         literal 0x%02x\n", this.val)); | ||||
|             PUP(out) = (unsigned char)(this.val); | ||||
|                     "inflate:         literal 0x%02x\n", here.val)); | ||||
|             PUP(out) = (unsigned char)(here.val); | ||||
|         } | ||||
|         else if (op & 16) {                     /* length base */ | ||||
|             len = (unsigned)(this.val); | ||||
|             len = (unsigned)(here.val); | ||||
|             op &= 15;                           /* number of extra bits */ | ||||
|             if (op) { | ||||
|                 if (bits < op) { | ||||
| @@ -155,14 +155,14 @@ unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
|                 hold += (unsigned long)(PUP(in)) << bits; | ||||
|                 bits += 8; | ||||
|             } | ||||
|             this = dcode[hold & dmask]; | ||||
|             here = dcode[hold & dmask]; | ||||
|           dodist: | ||||
|             op = (unsigned)(this.bits); | ||||
|             op = (unsigned)(here.bits); | ||||
|             hold >>= op; | ||||
|             bits -= op; | ||||
|             op = (unsigned)(this.op); | ||||
|             op = (unsigned)(here.op); | ||||
|             if (op & 16) {                      /* distance base */ | ||||
|                 dist = (unsigned)(this.val); | ||||
|                 dist = (unsigned)(here.val); | ||||
|                 op &= 15;                       /* number of extra bits */ | ||||
|                 if (bits < op) { | ||||
|                     hold += (unsigned long)(PUP(in)) << bits; | ||||
| @@ -187,12 +187,34 @@ unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
|                 if (dist > op) {                /* see if copy from window */ | ||||
|                     op = dist - op;             /* distance back in window */ | ||||
|                     if (op > whave) { | ||||
|                         strm->msg = (char *)"invalid distance too far back"; | ||||
|                         state->mode = BAD; | ||||
|                         break; | ||||
|                         if (state->sane) { | ||||
|                             strm->msg = | ||||
|                                 (char *)"invalid distance too far back"; | ||||
|                             state->mode = BAD; | ||||
|                             break; | ||||
|                         } | ||||
| #ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR | ||||
|                         if (len <= op - whave) { | ||||
|                             do { | ||||
|                                 PUP(out) = 0; | ||||
|                             } while (--len); | ||||
|                             continue; | ||||
|                         } | ||||
|                         len -= op - whave; | ||||
|                         do { | ||||
|                             PUP(out) = 0; | ||||
|                         } while (--op > whave); | ||||
|                         if (op == 0) { | ||||
|                             from = out - dist; | ||||
|                             do { | ||||
|                                 PUP(out) = PUP(from); | ||||
|                             } while (--len); | ||||
|                             continue; | ||||
|                         } | ||||
| #endif | ||||
|                     } | ||||
|                     from = window - OFF; | ||||
|                     if (write == 0) {           /* very common case */ | ||||
|                     if (wnext == 0) {           /* very common case */ | ||||
|                         from += wsize - op; | ||||
|                         if (op < len) {         /* some from window */ | ||||
|                             len -= op; | ||||
| @@ -202,17 +224,17 @@ unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
|                             from = out - dist;  /* rest from output */ | ||||
|                         } | ||||
|                     } | ||||
|                     else if (write < op) {      /* wrap around window */ | ||||
|                         from += wsize + write - op; | ||||
|                         op -= write; | ||||
|                     else if (wnext < op) {      /* wrap around window */ | ||||
|                         from += wsize + wnext - op; | ||||
|                         op -= wnext; | ||||
|                         if (op < len) {         /* some from end of window */ | ||||
|                             len -= op; | ||||
|                             do { | ||||
|                                 PUP(out) = PUP(from); | ||||
|                             } while (--op); | ||||
|                             from = window - OFF; | ||||
|                             if (write < len) {  /* some from start of window */ | ||||
|                                 op = write; | ||||
|                             if (wnext < len) {  /* some from start of window */ | ||||
|                                 op = wnext; | ||||
|                                 len -= op; | ||||
|                                 do { | ||||
|                                     PUP(out) = PUP(from); | ||||
| @@ -222,7 +244,7 @@ unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
|                         } | ||||
|                     } | ||||
|                     else {                      /* contiguous in window */ | ||||
|                         from += write - op; | ||||
|                         from += wnext - op; | ||||
|                         if (op < len) {         /* some from window */ | ||||
|                             len -= op; | ||||
|                             do { | ||||
| @@ -259,7 +281,7 @@ unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
|                 } | ||||
|             } | ||||
|             else if ((op & 64) == 0) {          /* 2nd level distance code */ | ||||
|                 this = dcode[this.val + (hold & ((1U << op) - 1))]; | ||||
|                 here = dcode[here.val + (hold & ((1U << op) - 1))]; | ||||
|                 goto dodist; | ||||
|             } | ||||
|             else { | ||||
| @@ -269,7 +291,7 @@ unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
|             } | ||||
|         } | ||||
|         else if ((op & 64) == 0) {              /* 2nd level length code */ | ||||
|             this = lcode[this.val + (hold & ((1U << op) - 1))]; | ||||
|             here = lcode[here.val + (hold & ((1U << op) - 1))]; | ||||
|             goto dolen; | ||||
|         } | ||||
|         else if (op & 32) {                     /* end-of-block */ | ||||
| @@ -305,7 +327,7 @@ unsigned start;         /* inflate()'s starting value for strm->avail_out */ | ||||
|    inflate_fast() speedups that turned out slower (on a PowerPC G3 750CXe): | ||||
|    - Using bit fields for code structure | ||||
|    - Different op definition to avoid & for extra bits (do & for table bits) | ||||
|    - Three separate decoding do-loops for direct, window, and write == 0 | ||||
|    - Three separate decoding do-loops for direct, window, and wnext == 0 | ||||
|    - Special case for distance > 1 copies to do overlapped load and store copy | ||||
|    - Explicit branch predictions (based on measured branch probabilities) | ||||
|    - Deferring match copy and interspersed it with decoding subsequent codes | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* inffast.h -- header to use inffast.c | ||||
|  * Copyright (C) 1995-2003 Mark Adler | ||||
|  * Copyright (C) 1995-2003, 2010 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| @@ -8,4 +8,4 @@ | ||||
|    subject to change. Applications should only use zlib.h. | ||||
|  */ | ||||
|  | ||||
| void inflate_fast OF((z_streamp strm, unsigned start)); | ||||
| void ZLIB_INTERNAL inflate_fast OF((z_streamp strm, unsigned start)); | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* inflate.c -- zlib decompression | ||||
|  * Copyright (C) 1995-2005 Mark Adler | ||||
|  * Copyright (C) 1995-2010 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| @@ -45,7 +45,7 @@ | ||||
|  * - Rearrange window copies in inflate_fast() for speed and simplification | ||||
|  * - Unroll last copy for window match in inflate_fast() | ||||
|  * - Use local copies of window variables in inflate_fast() for speed | ||||
|  * - Pull out common write == 0 case for speed in inflate_fast() | ||||
|  * - Pull out common wnext == 0 case for speed in inflate_fast() | ||||
|  * - Make op and len in inflate_fast() unsigned for consistency | ||||
|  * - Add FAR to lcode and dcode declarations in inflate_fast() | ||||
|  * - Simplified bad distance check in inflate_fast() | ||||
| @@ -117,28 +117,52 @@ z_streamp strm; | ||||
|     state->head = Z_NULL; | ||||
|     state->wsize = 0; | ||||
|     state->whave = 0; | ||||
|     state->write = 0; | ||||
|     state->wnext = 0; | ||||
|     state->hold = 0; | ||||
|     state->bits = 0; | ||||
|     state->lencode = state->distcode = state->next = state->codes; | ||||
|     state->sane = 1; | ||||
|     state->back = -1; | ||||
|     Tracev((stderr, "inflate: reset\n")); | ||||
|     return Z_OK; | ||||
| } | ||||
|  | ||||
| int ZEXPORT inflatePrime(strm, bits, value) | ||||
| int ZEXPORT inflateReset2(strm, windowBits) | ||||
| z_streamp strm; | ||||
| int bits; | ||||
| int value; | ||||
| int windowBits; | ||||
| { | ||||
|     int wrap; | ||||
|     struct inflate_state FAR *state; | ||||
|  | ||||
|     /* get the state */ | ||||
|     if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; | ||||
|     state = (struct inflate_state FAR *)strm->state; | ||||
|     if (bits > 16 || state->bits + bits > 32) return Z_STREAM_ERROR; | ||||
|     value &= (1L << bits) - 1; | ||||
|     state->hold += value << state->bits; | ||||
|     state->bits += bits; | ||||
|     return Z_OK; | ||||
|  | ||||
|     /* extract wrap request from windowBits parameter */ | ||||
|     if (windowBits < 0) { | ||||
|         wrap = 0; | ||||
|         windowBits = -windowBits; | ||||
|     } | ||||
|     else { | ||||
|         wrap = (windowBits >> 4) + 1; | ||||
| #ifdef GUNZIP | ||||
|         if (windowBits < 48) | ||||
|             windowBits &= 15; | ||||
| #endif | ||||
|     } | ||||
|  | ||||
|     /* set number of window bits, free window if different */ | ||||
|     if (windowBits && (windowBits < 8 || windowBits > 15)) | ||||
|         return Z_STREAM_ERROR; | ||||
|     if (state->window != Z_NULL && state->wbits != (unsigned)windowBits) { | ||||
|         ZFREE(strm, state->window); | ||||
|         state->window = Z_NULL; | ||||
|     } | ||||
|  | ||||
|     /* update state and reset the rest of it */ | ||||
|     state->wrap = wrap; | ||||
|     state->wbits = (unsigned)windowBits; | ||||
|     return inflateReset(strm); | ||||
| } | ||||
|  | ||||
| int ZEXPORT inflateInit2_(strm, windowBits, version, stream_size) | ||||
| @@ -147,6 +171,7 @@ int windowBits; | ||||
| const char *version; | ||||
| int stream_size; | ||||
| { | ||||
|     int ret; | ||||
|     struct inflate_state FAR *state; | ||||
|  | ||||
|     if (version == Z_NULL || version[0] != ZLIB_VERSION[0] || | ||||
| @@ -164,24 +189,13 @@ int stream_size; | ||||
|     if (state == Z_NULL) return Z_MEM_ERROR; | ||||
|     Tracev((stderr, "inflate: allocated\n")); | ||||
|     strm->state = (struct internal_state FAR *)state; | ||||
|     if (windowBits < 0) { | ||||
|         state->wrap = 0; | ||||
|         windowBits = -windowBits; | ||||
|     } | ||||
|     else { | ||||
|         state->wrap = (windowBits >> 4) + 1; | ||||
| #ifdef GUNZIP | ||||
|         if (windowBits < 48) windowBits &= 15; | ||||
| #endif | ||||
|     } | ||||
|     if (windowBits < 8 || windowBits > 15) { | ||||
|     state->window = Z_NULL; | ||||
|     ret = inflateReset2(strm, windowBits); | ||||
|     if (ret != Z_OK) { | ||||
|         ZFREE(strm, state); | ||||
|         strm->state = Z_NULL; | ||||
|         return Z_STREAM_ERROR; | ||||
|     } | ||||
|     state->wbits = (unsigned)windowBits; | ||||
|     state->window = Z_NULL; | ||||
|     return inflateReset(strm); | ||||
|     return ret; | ||||
| } | ||||
|  | ||||
| int ZEXPORT inflateInit_(strm, version, stream_size) | ||||
| @@ -192,6 +206,27 @@ int stream_size; | ||||
|     return inflateInit2_(strm, DEF_WBITS, version, stream_size); | ||||
| } | ||||
|  | ||||
| int ZEXPORT inflatePrime(strm, bits, value) | ||||
| z_streamp strm; | ||||
| int bits; | ||||
| int value; | ||||
| { | ||||
|     struct inflate_state FAR *state; | ||||
|  | ||||
|     if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; | ||||
|     state = (struct inflate_state FAR *)strm->state; | ||||
|     if (bits < 0) { | ||||
|         state->hold = 0; | ||||
|         state->bits = 0; | ||||
|         return Z_OK; | ||||
|     } | ||||
|     if (bits > 16 || state->bits + bits > 32) return Z_STREAM_ERROR; | ||||
|     value &= (1L << bits) - 1; | ||||
|     state->hold += value << state->bits; | ||||
|     state->bits += bits; | ||||
|     return Z_OK; | ||||
| } | ||||
|  | ||||
| /* | ||||
|    Return state with length and distance decoding tables and index sizes set to | ||||
|    fixed code decoding.  Normally this returns fixed tables from inffixed.h. | ||||
| @@ -340,7 +375,7 @@ unsigned out; | ||||
|     /* if window not in use yet, initialize */ | ||||
|     if (state->wsize == 0) { | ||||
|         state->wsize = 1U << state->wbits; | ||||
|         state->write = 0; | ||||
|         state->wnext = 0; | ||||
|         state->whave = 0; | ||||
|     } | ||||
|  | ||||
| @@ -348,22 +383,22 @@ unsigned out; | ||||
|     copy = out - strm->avail_out; | ||||
|     if (copy >= state->wsize) { | ||||
|         zmemcpy(state->window, strm->next_out - state->wsize, state->wsize); | ||||
|         state->write = 0; | ||||
|         state->wnext = 0; | ||||
|         state->whave = state->wsize; | ||||
|     } | ||||
|     else { | ||||
|         dist = state->wsize - state->write; | ||||
|         dist = state->wsize - state->wnext; | ||||
|         if (dist > copy) dist = copy; | ||||
|         zmemcpy(state->window + state->write, strm->next_out - copy, dist); | ||||
|         zmemcpy(state->window + state->wnext, strm->next_out - copy, dist); | ||||
|         copy -= dist; | ||||
|         if (copy) { | ||||
|             zmemcpy(state->window, strm->next_out - copy, copy); | ||||
|             state->write = copy; | ||||
|             state->wnext = copy; | ||||
|             state->whave = state->wsize; | ||||
|         } | ||||
|         else { | ||||
|             state->write += dist; | ||||
|             if (state->write == state->wsize) state->write = 0; | ||||
|             state->wnext += dist; | ||||
|             if (state->wnext == state->wsize) state->wnext = 0; | ||||
|             if (state->whave < state->wsize) state->whave += dist; | ||||
|         } | ||||
|     } | ||||
| @@ -564,7 +599,7 @@ int flush; | ||||
|     unsigned in, out;           /* save starting available input and output */ | ||||
|     unsigned copy;              /* number of stored or match bytes to copy */ | ||||
|     unsigned char FAR *from;    /* where to copy match bytes from */ | ||||
|     code this;                  /* current decoding table entry */ | ||||
|     code here;                  /* current decoding table entry */ | ||||
|     code last;                  /* parent table entry */ | ||||
|     unsigned len;               /* length to copy for repeats, bits to drop */ | ||||
|     int ret;                    /* return code */ | ||||
| @@ -619,7 +654,9 @@ int flush; | ||||
|             } | ||||
|             DROPBITS(4); | ||||
|             len = BITS(4) + 8; | ||||
|             if (len > state->wbits) { | ||||
|             if (state->wbits == 0) | ||||
|                 state->wbits = len; | ||||
|             else if (len > state->wbits) { | ||||
|                 strm->msg = (char *)"invalid window size"; | ||||
|                 state->mode = BAD; | ||||
|                 break; | ||||
| @@ -771,7 +808,7 @@ int flush; | ||||
|             strm->adler = state->check = adler32(0L, Z_NULL, 0); | ||||
|             state->mode = TYPE; | ||||
|         case TYPE: | ||||
|             if (flush == Z_BLOCK) goto inf_leave; | ||||
|             if (flush == Z_BLOCK || flush == Z_TREES) goto inf_leave; | ||||
|         case TYPEDO: | ||||
|             if (state->last) { | ||||
|                 BYTEBITS(); | ||||
| @@ -791,7 +828,11 @@ int flush; | ||||
|                 fixedtables(state); | ||||
|                 Tracev((stderr, "inflate:     fixed codes block%s\n", | ||||
|                         state->last ? " (last)" : "")); | ||||
|                 state->mode = LEN;              /* decode codes */ | ||||
|                 state->mode = LEN_;             /* decode codes */ | ||||
|                 if (flush == Z_TREES) { | ||||
|                     DROPBITS(2); | ||||
|                     goto inf_leave; | ||||
|                 } | ||||
|                 break; | ||||
|             case 2:                             /* dynamic block */ | ||||
|                 Tracev((stderr, "inflate:     dynamic codes block%s\n", | ||||
| @@ -816,6 +857,9 @@ int flush; | ||||
|             Tracev((stderr, "inflate:       stored length %u\n", | ||||
|                     state->length)); | ||||
|             INITBITS(); | ||||
|             state->mode = COPY_; | ||||
|             if (flush == Z_TREES) goto inf_leave; | ||||
|         case COPY_: | ||||
|             state->mode = COPY; | ||||
|         case COPY: | ||||
|             copy = state->length; | ||||
| @@ -876,19 +920,19 @@ int flush; | ||||
|         case CODELENS: | ||||
|             while (state->have < state->nlen + state->ndist) { | ||||
|                 for (;;) { | ||||
|                     this = state->lencode[BITS(state->lenbits)]; | ||||
|                     if ((unsigned)(this.bits) <= bits) break; | ||||
|                     here = state->lencode[BITS(state->lenbits)]; | ||||
|                     if ((unsigned)(here.bits) <= bits) break; | ||||
|                     PULLBYTE(); | ||||
|                 } | ||||
|                 if (this.val < 16) { | ||||
|                     NEEDBITS(this.bits); | ||||
|                     DROPBITS(this.bits); | ||||
|                     state->lens[state->have++] = this.val; | ||||
|                 if (here.val < 16) { | ||||
|                     NEEDBITS(here.bits); | ||||
|                     DROPBITS(here.bits); | ||||
|                     state->lens[state->have++] = here.val; | ||||
|                 } | ||||
|                 else { | ||||
|                     if (this.val == 16) { | ||||
|                         NEEDBITS(this.bits + 2); | ||||
|                         DROPBITS(this.bits); | ||||
|                     if (here.val == 16) { | ||||
|                         NEEDBITS(here.bits + 2); | ||||
|                         DROPBITS(here.bits); | ||||
|                         if (state->have == 0) { | ||||
|                             strm->msg = (char *)"invalid bit length repeat"; | ||||
|                             state->mode = BAD; | ||||
| @@ -898,16 +942,16 @@ int flush; | ||||
|                         copy = 3 + BITS(2); | ||||
|                         DROPBITS(2); | ||||
|                     } | ||||
|                     else if (this.val == 17) { | ||||
|                         NEEDBITS(this.bits + 3); | ||||
|                         DROPBITS(this.bits); | ||||
|                     else if (here.val == 17) { | ||||
|                         NEEDBITS(here.bits + 3); | ||||
|                         DROPBITS(here.bits); | ||||
|                         len = 0; | ||||
|                         copy = 3 + BITS(3); | ||||
|                         DROPBITS(3); | ||||
|                     } | ||||
|                     else { | ||||
|                         NEEDBITS(this.bits + 7); | ||||
|                         DROPBITS(this.bits); | ||||
|                         NEEDBITS(here.bits + 7); | ||||
|                         DROPBITS(here.bits); | ||||
|                         len = 0; | ||||
|                         copy = 11 + BITS(7); | ||||
|                         DROPBITS(7); | ||||
| @@ -925,7 +969,16 @@ int flush; | ||||
|             /* handle error breaks in while */ | ||||
|             if (state->mode == BAD) break; | ||||
|  | ||||
|             /* build code tables */ | ||||
|             /* check for end-of-block code (better have one) */ | ||||
|             if (state->lens[256] == 0) { | ||||
|                 strm->msg = (char *)"invalid code -- missing end-of-block"; | ||||
|                 state->mode = BAD; | ||||
|                 break; | ||||
|             } | ||||
|  | ||||
|             /* build code tables -- note: do not change the lenbits or distbits | ||||
|                values here (9 and 6) without reading the comments in inftrees.h | ||||
|                concerning the ENOUGH constants, which depend on those values */ | ||||
|             state->next = state->codes; | ||||
|             state->lencode = (code const FAR *)(state->next); | ||||
|             state->lenbits = 9; | ||||
| @@ -946,88 +999,102 @@ int flush; | ||||
|                 break; | ||||
|             } | ||||
|             Tracev((stderr, "inflate:       codes ok\n")); | ||||
|             state->mode = LEN_; | ||||
|             if (flush == Z_TREES) goto inf_leave; | ||||
|         case LEN_: | ||||
|             state->mode = LEN; | ||||
|         case LEN: | ||||
|             if (have >= 6 && left >= 258) { | ||||
|                 RESTORE(); | ||||
|                 inflate_fast(strm, out); | ||||
|                 LOAD(); | ||||
|                 if (state->mode == TYPE) | ||||
|                     state->back = -1; | ||||
|                 break; | ||||
|             } | ||||
|             state->back = 0; | ||||
|             for (;;) { | ||||
|                 this = state->lencode[BITS(state->lenbits)]; | ||||
|                 if ((unsigned)(this.bits) <= bits) break; | ||||
|                 here = state->lencode[BITS(state->lenbits)]; | ||||
|                 if ((unsigned)(here.bits) <= bits) break; | ||||
|                 PULLBYTE(); | ||||
|             } | ||||
|             if (this.op && (this.op & 0xf0) == 0) { | ||||
|                 last = this; | ||||
|             if (here.op && (here.op & 0xf0) == 0) { | ||||
|                 last = here; | ||||
|                 for (;;) { | ||||
|                     this = state->lencode[last.val + | ||||
|                     here = state->lencode[last.val + | ||||
|                             (BITS(last.bits + last.op) >> last.bits)]; | ||||
|                     if ((unsigned)(last.bits + this.bits) <= bits) break; | ||||
|                     if ((unsigned)(last.bits + here.bits) <= bits) break; | ||||
|                     PULLBYTE(); | ||||
|                 } | ||||
|                 DROPBITS(last.bits); | ||||
|                 state->back += last.bits; | ||||
|             } | ||||
|             DROPBITS(this.bits); | ||||
|             state->length = (unsigned)this.val; | ||||
|             if ((int)(this.op) == 0) { | ||||
|                 Tracevv((stderr, this.val >= 0x20 && this.val < 0x7f ? | ||||
|             DROPBITS(here.bits); | ||||
|             state->back += here.bits; | ||||
|             state->length = (unsigned)here.val; | ||||
|             if ((int)(here.op) == 0) { | ||||
|                 Tracevv((stderr, here.val >= 0x20 && here.val < 0x7f ? | ||||
|                         "inflate:         literal '%c'\n" : | ||||
|                         "inflate:         literal 0x%02x\n", this.val)); | ||||
|                         "inflate:         literal 0x%02x\n", here.val)); | ||||
|                 state->mode = LIT; | ||||
|                 break; | ||||
|             } | ||||
|             if (this.op & 32) { | ||||
|             if (here.op & 32) { | ||||
|                 Tracevv((stderr, "inflate:         end of block\n")); | ||||
|                 state->back = -1; | ||||
|                 state->mode = TYPE; | ||||
|                 break; | ||||
|             } | ||||
|             if (this.op & 64) { | ||||
|             if (here.op & 64) { | ||||
|                 strm->msg = (char *)"invalid literal/length code"; | ||||
|                 state->mode = BAD; | ||||
|                 break; | ||||
|             } | ||||
|             state->extra = (unsigned)(this.op) & 15; | ||||
|             state->extra = (unsigned)(here.op) & 15; | ||||
|             state->mode = LENEXT; | ||||
|         case LENEXT: | ||||
|             if (state->extra) { | ||||
|                 NEEDBITS(state->extra); | ||||
|                 state->length += BITS(state->extra); | ||||
|                 DROPBITS(state->extra); | ||||
|                 state->back += state->extra; | ||||
|             } | ||||
|             Tracevv((stderr, "inflate:         length %u\n", state->length)); | ||||
|             state->was = state->length; | ||||
|             state->mode = DIST; | ||||
|         case DIST: | ||||
|             for (;;) { | ||||
|                 this = state->distcode[BITS(state->distbits)]; | ||||
|                 if ((unsigned)(this.bits) <= bits) break; | ||||
|                 here = state->distcode[BITS(state->distbits)]; | ||||
|                 if ((unsigned)(here.bits) <= bits) break; | ||||
|                 PULLBYTE(); | ||||
|             } | ||||
|             if ((this.op & 0xf0) == 0) { | ||||
|                 last = this; | ||||
|             if ((here.op & 0xf0) == 0) { | ||||
|                 last = here; | ||||
|                 for (;;) { | ||||
|                     this = state->distcode[last.val + | ||||
|                     here = state->distcode[last.val + | ||||
|                             (BITS(last.bits + last.op) >> last.bits)]; | ||||
|                     if ((unsigned)(last.bits + this.bits) <= bits) break; | ||||
|                     if ((unsigned)(last.bits + here.bits) <= bits) break; | ||||
|                     PULLBYTE(); | ||||
|                 } | ||||
|                 DROPBITS(last.bits); | ||||
|                 state->back += last.bits; | ||||
|             } | ||||
|             DROPBITS(this.bits); | ||||
|             if (this.op & 64) { | ||||
|             DROPBITS(here.bits); | ||||
|             state->back += here.bits; | ||||
|             if (here.op & 64) { | ||||
|                 strm->msg = (char *)"invalid distance code"; | ||||
|                 state->mode = BAD; | ||||
|                 break; | ||||
|             } | ||||
|             state->offset = (unsigned)this.val; | ||||
|             state->extra = (unsigned)(this.op) & 15; | ||||
|             state->offset = (unsigned)here.val; | ||||
|             state->extra = (unsigned)(here.op) & 15; | ||||
|             state->mode = DISTEXT; | ||||
|         case DISTEXT: | ||||
|             if (state->extra) { | ||||
|                 NEEDBITS(state->extra); | ||||
|                 state->offset += BITS(state->extra); | ||||
|                 DROPBITS(state->extra); | ||||
|                 state->back += state->extra; | ||||
|             } | ||||
| #ifdef INFLATE_STRICT | ||||
|             if (state->offset > state->dmax) { | ||||
| @@ -1036,11 +1103,6 @@ int flush; | ||||
|                 break; | ||||
|             } | ||||
| #endif | ||||
|             if (state->offset > state->whave + out - left) { | ||||
|                 strm->msg = (char *)"invalid distance too far back"; | ||||
|                 state->mode = BAD; | ||||
|                 break; | ||||
|             } | ||||
|             Tracevv((stderr, "inflate:         distance %u\n", state->offset)); | ||||
|             state->mode = MATCH; | ||||
|         case MATCH: | ||||
| @@ -1048,12 +1110,32 @@ int flush; | ||||
|             copy = out - left; | ||||
|             if (state->offset > copy) {         /* copy from window */ | ||||
|                 copy = state->offset - copy; | ||||
|                 if (copy > state->write) { | ||||
|                     copy -= state->write; | ||||
|                 if (copy > state->whave) { | ||||
|                     if (state->sane) { | ||||
|                         strm->msg = (char *)"invalid distance too far back"; | ||||
|                         state->mode = BAD; | ||||
|                         break; | ||||
|                     } | ||||
| #ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR | ||||
|                     Trace((stderr, "inflate.c too far\n")); | ||||
|                     copy -= state->whave; | ||||
|                     if (copy > state->length) copy = state->length; | ||||
|                     if (copy > left) copy = left; | ||||
|                     left -= copy; | ||||
|                     state->length -= copy; | ||||
|                     do { | ||||
|                         *put++ = 0; | ||||
|                     } while (--copy); | ||||
|                     if (state->length == 0) state->mode = LEN; | ||||
|                     break; | ||||
| #endif | ||||
|                 } | ||||
|                 if (copy > state->wnext) { | ||||
|                     copy -= state->wnext; | ||||
|                     from = state->window + (state->wsize - copy); | ||||
|                 } | ||||
|                 else | ||||
|                     from = state->window + (state->write - copy); | ||||
|                     from = state->window + (state->wnext - copy); | ||||
|                 if (copy > state->length) copy = state->length; | ||||
|             } | ||||
|             else {                              /* copy from output */ | ||||
| @@ -1146,7 +1228,8 @@ int flush; | ||||
|         strm->adler = state->check = | ||||
|             UPDATE(state->check, strm->next_out - out, out); | ||||
|     strm->data_type = state->bits + (state->last ? 64 : 0) + | ||||
|                       (state->mode == TYPE ? 128 : 0); | ||||
|                       (state->mode == TYPE ? 128 : 0) + | ||||
|                       (state->mode == LEN_ || state->mode == COPY_ ? 256 : 0); | ||||
|     if (((in == 0 && out == 0) || flush == Z_FINISH) && ret == Z_OK) | ||||
|         ret = Z_BUF_ERROR; | ||||
|     return ret; | ||||
| @@ -1366,3 +1449,32 @@ z_streamp source; | ||||
|     dest->state = (struct internal_state FAR *)copy; | ||||
|     return Z_OK; | ||||
| } | ||||
|  | ||||
| int ZEXPORT inflateUndermine(strm, subvert) | ||||
| z_streamp strm; | ||||
| int subvert; | ||||
| { | ||||
|     struct inflate_state FAR *state; | ||||
|  | ||||
|     if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR; | ||||
|     state = (struct inflate_state FAR *)strm->state; | ||||
|     state->sane = !subvert; | ||||
| #ifdef INFLATE_ALLOW_INVALID_DISTANCE_TOOFAR_ARRR | ||||
|     return Z_OK; | ||||
| #else | ||||
|     state->sane = 1; | ||||
|     return Z_DATA_ERROR; | ||||
| #endif | ||||
| } | ||||
|  | ||||
| long ZEXPORT inflateMark(strm) | ||||
| z_streamp strm; | ||||
| { | ||||
|     struct inflate_state FAR *state; | ||||
|  | ||||
|     if (strm == Z_NULL || strm->state == Z_NULL) return -1L << 16; | ||||
|     state = (struct inflate_state FAR *)strm->state; | ||||
|     return ((long)(state->back) << 16) + | ||||
|         (state->mode == COPY ? state->length : | ||||
|             (state->mode == MATCH ? state->was - state->length : 0)); | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* inflate.h -- internal inflate state definition | ||||
|  * Copyright (C) 1995-2004 Mark Adler | ||||
|  * Copyright (C) 1995-2009 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| @@ -32,11 +32,13 @@ typedef enum { | ||||
|         TYPE,       /* i: waiting for type bits, including last-flag bit */ | ||||
|         TYPEDO,     /* i: same, but skip check to exit inflate on new block */ | ||||
|         STORED,     /* i: waiting for stored size (length and complement) */ | ||||
|         COPY_,      /* i/o: same as COPY below, but only first time in */ | ||||
|         COPY,       /* i/o: waiting for input or output to copy stored block */ | ||||
|         TABLE,      /* i: waiting for dynamic block table lengths */ | ||||
|         LENLENS,    /* i: waiting for code length code lengths */ | ||||
|         CODELENS,   /* i: waiting for length/lit and distance code lengths */ | ||||
|             LEN,        /* i: waiting for length/lit code */ | ||||
|             LEN_,       /* i: same as LEN below, but only first time in */ | ||||
|             LEN,        /* i: waiting for length/lit/eob code */ | ||||
|             LENEXT,     /* i: waiting for length extra bits */ | ||||
|             DIST,       /* i: waiting for distance code */ | ||||
|             DISTEXT,    /* i: waiting for distance extra bits */ | ||||
| @@ -53,19 +55,21 @@ typedef enum { | ||||
| /* | ||||
|     State transitions between above modes - | ||||
|  | ||||
|     (most modes can go to the BAD or MEM mode -- not shown for clarity) | ||||
|     (most modes can go to BAD or MEM on error -- not shown for clarity) | ||||
|  | ||||
|     Process header: | ||||
|         HEAD -> (gzip) or (zlib) | ||||
|         (gzip) -> FLAGS -> TIME -> OS -> EXLEN -> EXTRA -> NAME | ||||
|         NAME -> COMMENT -> HCRC -> TYPE | ||||
|         HEAD -> (gzip) or (zlib) or (raw) | ||||
|         (gzip) -> FLAGS -> TIME -> OS -> EXLEN -> EXTRA -> NAME -> COMMENT -> | ||||
|                   HCRC -> TYPE | ||||
|         (zlib) -> DICTID or TYPE | ||||
|         DICTID -> DICT -> TYPE | ||||
|         (raw) -> TYPEDO | ||||
|     Read deflate blocks: | ||||
|             TYPE -> STORED or TABLE or LEN or CHECK | ||||
|             STORED -> COPY -> TYPE | ||||
|             TABLE -> LENLENS -> CODELENS -> LEN | ||||
|     Read deflate codes: | ||||
|             TYPE -> TYPEDO -> STORED or TABLE or LEN_ or CHECK | ||||
|             STORED -> COPY_ -> COPY -> TYPE | ||||
|             TABLE -> LENLENS -> CODELENS -> LEN_ | ||||
|             LEN_ -> LEN | ||||
|     Read deflate codes in fixed or dynamic block: | ||||
|                 LEN -> LENEXT or LIT or TYPE | ||||
|                 LENEXT -> DIST -> DISTEXT -> MATCH -> LEN | ||||
|                 LIT -> LEN | ||||
| @@ -73,7 +77,7 @@ typedef enum { | ||||
|         CHECK -> LENGTH -> DONE | ||||
|  */ | ||||
|  | ||||
| /* state maintained between inflate() calls.  Approximately 7K bytes. */ | ||||
| /* state maintained between inflate() calls.  Approximately 10K bytes. */ | ||||
| struct inflate_state { | ||||
|     inflate_mode mode;          /* current inflate mode */ | ||||
|     int last;                   /* true if processing last block */ | ||||
| @@ -88,7 +92,7 @@ struct inflate_state { | ||||
|     unsigned wbits;             /* log base 2 of requested window size */ | ||||
|     unsigned wsize;             /* window size or zero if not using window */ | ||||
|     unsigned whave;             /* valid bytes in the window */ | ||||
|     unsigned write;             /* window write index */ | ||||
|     unsigned wnext;             /* window write index */ | ||||
|     unsigned char FAR *window;  /* allocated sliding window, if needed */ | ||||
|         /* bit accumulator */ | ||||
|     unsigned long hold;         /* input bit accumulator */ | ||||
| @@ -112,4 +116,7 @@ struct inflate_state { | ||||
|     unsigned short lens[320];   /* temporary storage for code lengths */ | ||||
|     unsigned short work[288];   /* work area for code table building */ | ||||
|     code codes[ENOUGH];         /* space for code tables */ | ||||
|     int sane;                   /* if false, allow invalid distance too far */ | ||||
|     int back;                   /* bits back of last unprocessed length/lit */ | ||||
|     unsigned was;               /* initial length of match */ | ||||
| }; | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* inftrees.c -- generate Huffman trees for efficient decoding | ||||
|  * Copyright (C) 1995-2005 Mark Adler | ||||
|  * Copyright (C) 1995-2010 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| @@ -9,7 +9,7 @@ | ||||
| #define MAXBITS 15 | ||||
|  | ||||
| const char inflate_copyright[] = | ||||
|    " inflate 1.2.3 Copyright 1995-2005 Mark Adler "; | ||||
|    " inflate 1.2.5 Copyright 1995-2010 Mark Adler "; | ||||
| /* | ||||
|   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 | ||||
| @@ -29,7 +29,7 @@ const char inflate_copyright[] = | ||||
|    table index bits.  It will differ if the request is greater than the | ||||
|    longest code or if it is less than the shortest code. | ||||
|  */ | ||||
| int inflate_table(type, lens, codes, table, bits, work) | ||||
| int ZLIB_INTERNAL inflate_table(type, lens, codes, table, bits, work) | ||||
| codetype type; | ||||
| unsigned short FAR *lens; | ||||
| unsigned codes; | ||||
| @@ -50,7 +50,7 @@ unsigned short FAR *work; | ||||
|     unsigned fill;              /* index for replicating entries */ | ||||
|     unsigned low;               /* low bits for current root entry */ | ||||
|     unsigned mask;              /* mask for low root bits */ | ||||
|     code this;                  /* table entry for duplication */ | ||||
|     code here;                  /* table entry for duplication */ | ||||
|     code FAR *next;             /* next available space in table */ | ||||
|     const unsigned short FAR *base;     /* base value table to use */ | ||||
|     const unsigned short FAR *extra;    /* extra bits table to use */ | ||||
| @@ -62,7 +62,7 @@ unsigned short FAR *work; | ||||
|         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 */ | ||||
|         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, 201, 196}; | ||||
|         19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 73, 195}; | ||||
|     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, | ||||
|         257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145, | ||||
| @@ -115,15 +115,15 @@ unsigned short FAR *work; | ||||
|         if (count[max] != 0) break; | ||||
|     if (root > max) root = max; | ||||
|     if (max == 0) {                     /* no symbols to code at all */ | ||||
|         this.op = (unsigned char)64;    /* invalid code marker */ | ||||
|         this.bits = (unsigned char)1; | ||||
|         this.val = (unsigned short)0; | ||||
|         *(*table)++ = this;             /* make a table to force an error */ | ||||
|         *(*table)++ = this; | ||||
|         here.op = (unsigned char)64;    /* invalid code marker */ | ||||
|         here.bits = (unsigned char)1; | ||||
|         here.val = (unsigned short)0; | ||||
|         *(*table)++ = here;             /* make a table to force an error */ | ||||
|         *(*table)++ = here; | ||||
|         *bits = 1; | ||||
|         return 0;     /* no symbols, but wait for decoding to report error */ | ||||
|     } | ||||
|     for (min = 1; min <= MAXBITS; min++) | ||||
|     for (min = 1; min < max; min++) | ||||
|         if (count[min] != 0) break; | ||||
|     if (root < min) root = min; | ||||
|  | ||||
| @@ -166,11 +166,10 @@ unsigned short FAR *work; | ||||
|        entered in the tables. | ||||
|  | ||||
|        used keeps track of how many table entries have been allocated from the | ||||
|        provided *table space.  It is checked when a LENS table is being made | ||||
|        against the space in *table, ENOUGH, minus the maximum space needed by | ||||
|        the worst case distance code, MAXD.  This should never happen, but the | ||||
|        sufficiency of ENOUGH has not been proven exhaustively, hence the check. | ||||
|        This assumes that when type == LENS, bits == 9. | ||||
|        provided *table space.  It is checked for LENS and DIST tables against | ||||
|        the constants ENOUGH_LENS and ENOUGH_DISTS to guard against changes in | ||||
|        the initial root table size constants.  See the comments in inftrees.h | ||||
|        for more information. | ||||
|  | ||||
|        sym increments through all symbols, and the loop terminates when | ||||
|        all codes of length max, i.e. all codes, have been processed.  This | ||||
| @@ -209,24 +208,25 @@ unsigned short FAR *work; | ||||
|     mask = used - 1;            /* mask for comparing low */ | ||||
|  | ||||
|     /* check available table space */ | ||||
|     if (type == LENS && used >= ENOUGH - MAXD) | ||||
|     if ((type == LENS && used >= ENOUGH_LENS) || | ||||
|         (type == DISTS && used >= ENOUGH_DISTS)) | ||||
|         return 1; | ||||
|  | ||||
|     /* process all codes and make table entries */ | ||||
|     for (;;) { | ||||
|         /* create table entry */ | ||||
|         this.bits = (unsigned char)(len - drop); | ||||
|         here.bits = (unsigned char)(len - drop); | ||||
|         if ((int)(work[sym]) < end) { | ||||
|             this.op = (unsigned char)0; | ||||
|             this.val = work[sym]; | ||||
|             here.op = (unsigned char)0; | ||||
|             here.val = work[sym]; | ||||
|         } | ||||
|         else if ((int)(work[sym]) > end) { | ||||
|             this.op = (unsigned char)(extra[work[sym]]); | ||||
|             this.val = base[work[sym]]; | ||||
|             here.op = (unsigned char)(extra[work[sym]]); | ||||
|             here.val = base[work[sym]]; | ||||
|         } | ||||
|         else { | ||||
|             this.op = (unsigned char)(32 + 64);         /* end of block */ | ||||
|             this.val = 0; | ||||
|             here.op = (unsigned char)(32 + 64);         /* end of block */ | ||||
|             here.val = 0; | ||||
|         } | ||||
|  | ||||
|         /* replicate for those indices with low len bits equal to huff */ | ||||
| @@ -235,7 +235,7 @@ unsigned short FAR *work; | ||||
|         min = fill;                 /* save offset to next table */ | ||||
|         do { | ||||
|             fill -= incr; | ||||
|             next[(huff >> drop) + fill] = this; | ||||
|             next[(huff >> drop) + fill] = here; | ||||
|         } while (fill != 0); | ||||
|  | ||||
|         /* backwards increment the len-bit code huff */ | ||||
| @@ -277,7 +277,8 @@ unsigned short FAR *work; | ||||
|  | ||||
|             /* check for enough space */ | ||||
|             used += 1U << curr; | ||||
|             if (type == LENS && used >= ENOUGH - MAXD) | ||||
|             if ((type == LENS && used >= ENOUGH_LENS) || | ||||
|                 (type == DISTS && used >= ENOUGH_DISTS)) | ||||
|                 return 1; | ||||
|  | ||||
|             /* point entry in root table to sub-table */ | ||||
| @@ -295,20 +296,20 @@ unsigned short FAR *work; | ||||
|        through high index bits.  When the current sub-table is filled, the loop | ||||
|        drops back to the root table to fill in any remaining entries there. | ||||
|      */ | ||||
|     this.op = (unsigned char)64;                /* invalid code marker */ | ||||
|     this.bits = (unsigned char)(len - drop); | ||||
|     this.val = (unsigned short)0; | ||||
|     here.op = (unsigned char)64;                /* invalid code marker */ | ||||
|     here.bits = (unsigned char)(len - drop); | ||||
|     here.val = (unsigned short)0; | ||||
|     while (huff != 0) { | ||||
|         /* when done with sub-table, drop back to root table */ | ||||
|         if (drop != 0 && (huff & mask) != low) { | ||||
|             drop = 0; | ||||
|             len = root; | ||||
|             next = *table; | ||||
|             this.bits = (unsigned char)len; | ||||
|             here.bits = (unsigned char)len; | ||||
|         } | ||||
|  | ||||
|         /* put invalid code marker in table */ | ||||
|         next[huff >> drop] = this; | ||||
|         next[huff >> drop] = here; | ||||
|  | ||||
|         /* backwards increment the len-bit code huff */ | ||||
|         incr = 1U << (len - 1); | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* inftrees.h -- header to use inftrees.c | ||||
|  * Copyright (C) 1995-2005 Mark Adler | ||||
|  * Copyright (C) 1995-2005, 2010 Mark Adler | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| @@ -35,21 +35,28 @@ typedef struct { | ||||
|     01000000 - invalid code | ||||
|  */ | ||||
|  | ||||
| /* Maximum size of dynamic tree.  The maximum found in a long but non- | ||||
|    exhaustive search was 1444 code structures (852 for length/literals | ||||
|    and 592 for distances, the latter actually the result of an | ||||
|    exhaustive search).  The true maximum is not known, but the value | ||||
|    below is more than safe. */ | ||||
| #define ENOUGH 2048 | ||||
| #define MAXD 592 | ||||
| /* Maximum size of the dynamic table.  The maximum number of code structures is | ||||
|    1444, which is the sum of 852 for literal/length codes and 592 for distance | ||||
|    codes.  These values were found by exhaustive searches using the program | ||||
|    examples/enough.c found in the zlib distribtution.  The arguments to that | ||||
|    program are the number of symbols, the initial root table size, and the | ||||
|    maximum bit length of a code.  "enough 286 9 15" for literal/length codes | ||||
|    returns returns 852, and "enough 30 6 15" for distance codes returns 592. | ||||
|    The initial root table size (9 or 6) is found in the fifth argument of the | ||||
|    inflate_table() calls in inflate.c and infback.c.  If the root table size is | ||||
|    changed, then these maximum sizes would be need to be recalculated and | ||||
|    updated. */ | ||||
| #define ENOUGH_LENS 852 | ||||
| #define ENOUGH_DISTS 592 | ||||
| #define ENOUGH (ENOUGH_LENS+ENOUGH_DISTS) | ||||
|  | ||||
| /* Type of code to build for inftable() */ | ||||
| /* Type of code to build for inflate_table() */ | ||||
| typedef enum { | ||||
|     CODES, | ||||
|     LENS, | ||||
|     DISTS | ||||
| } codetype; | ||||
|  | ||||
| extern int inflate_table OF((codetype type, unsigned short FAR *lens, | ||||
| int ZLIB_INTERNAL inflate_table OF((codetype type, unsigned short FAR *lens, | ||||
|                              unsigned codes, code FAR * FAR *table, | ||||
|                              unsigned FAR *bits, unsigned short FAR *work)); | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| /* trees.c -- output deflated data using Huffman coding | ||||
|  * Copyright (C) 1995-2005 Jean-loup Gailly | ||||
|  * Copyright (C) 1995-2010 Jean-loup Gailly | ||||
|  * detect_data_type() function provided freely by Cosmin Truta, 2006 | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| @@ -29,14 +30,10 @@ | ||||
|  *          Addison-Wesley, 1983. ISBN 0-201-06672-6. | ||||
|  */ | ||||
|  | ||||
| /* @(#) $Id: //poco/svn/Foundation/src/trees.c#2 $ */ | ||||
| /* @(#) $Id$ */ | ||||
|  | ||||
| /* #define GEN_TREES_H */ | ||||
|  | ||||
| #if defined(_MSC_VER) | ||||
| 	#pragma warning(disable:4267) // conversion from ... possble loss of data | ||||
| #endif | ||||
|  | ||||
| #include "deflate.h" | ||||
|  | ||||
| #ifdef DEBUG | ||||
| @@ -156,7 +153,7 @@ local void send_all_trees OF((deflate_state *s, int lcodes, int dcodes, | ||||
|                               int blcodes)); | ||||
| local void compress_block OF((deflate_state *s, ct_data *ltree, | ||||
|                               ct_data *dtree)); | ||||
| local void set_data_type  OF((deflate_state *s)); | ||||
| local int  detect_data_type OF((deflate_state *s)); | ||||
| local unsigned bi_reverse OF((unsigned value, int length)); | ||||
| local void bi_windup      OF((deflate_state *s)); | ||||
| local void bi_flush       OF((deflate_state *s)); | ||||
| @@ -207,12 +204,12 @@ local void send_bits(s, value, length) | ||||
|      * unused bits in value. | ||||
|      */ | ||||
|     if (s->bi_valid > (int)Buf_size - length) { | ||||
|         s->bi_buf |= (value << s->bi_valid); | ||||
|         s->bi_buf |= (ush)value << s->bi_valid; | ||||
|         put_short(s, s->bi_buf); | ||||
|         s->bi_buf = (ush)value >> (Buf_size - s->bi_valid); | ||||
|         s->bi_valid += length - Buf_size; | ||||
|     } else { | ||||
|         s->bi_buf |= value << s->bi_valid; | ||||
|         s->bi_buf |= (ush)value << s->bi_valid; | ||||
|         s->bi_valid += length; | ||||
|     } | ||||
| } | ||||
| @@ -222,12 +219,12 @@ local void send_bits(s, value, length) | ||||
| { int len = length;\ | ||||
|   if (s->bi_valid > (int)Buf_size - len) {\ | ||||
|     int val = value;\ | ||||
|     s->bi_buf |= (val << s->bi_valid);\ | ||||
|     s->bi_buf |= (ush)val << s->bi_valid;\ | ||||
|     put_short(s, s->bi_buf);\ | ||||
|     s->bi_buf = (ush)val >> (Buf_size - s->bi_valid);\ | ||||
|     s->bi_valid += len - Buf_size;\ | ||||
|   } else {\ | ||||
|     s->bi_buf |= (value) << s->bi_valid;\ | ||||
|     s->bi_buf |= (ush)(value) << s->bi_valid;\ | ||||
|     s->bi_valid += len;\ | ||||
|   }\ | ||||
| } | ||||
| @@ -254,11 +251,13 @@ local void tr_static_init() | ||||
|     if (static_init_done) return; | ||||
|  | ||||
|     /* For some embedded targets, global variables are not initialized: */ | ||||
| #ifdef NO_INIT_GLOBAL_POINTERS | ||||
|     static_l_desc.static_tree = static_ltree; | ||||
|     static_l_desc.extra_bits = extra_lbits; | ||||
|     static_d_desc.static_tree = static_dtree; | ||||
|     static_d_desc.extra_bits = extra_dbits; | ||||
|     static_bl_desc.extra_bits = extra_blbits; | ||||
| #endif | ||||
|  | ||||
|     /* Initialize the mapping length (0..255) -> length code (0..28) */ | ||||
|     length = 0; | ||||
| @@ -352,13 +351,14 @@ void gen_trees_header() | ||||
|                 static_dtree[i].Len, SEPARATOR(i, D_CODES-1, 5)); | ||||
|     } | ||||
|  | ||||
|     fprintf(header, "const uch _dist_code[DIST_CODE_LEN] = {\n"); | ||||
|     fprintf(header, "const uch ZLIB_INTERNAL _dist_code[DIST_CODE_LEN] = {\n"); | ||||
|     for (i = 0; i < DIST_CODE_LEN; i++) { | ||||
|         fprintf(header, "%2u%s", _dist_code[i], | ||||
|                 SEPARATOR(i, DIST_CODE_LEN-1, 20)); | ||||
|     } | ||||
|  | ||||
|     fprintf(header, "const uch _length_code[MAX_MATCH-MIN_MATCH+1]= {\n"); | ||||
|     fprintf(header, | ||||
|         "const uch ZLIB_INTERNAL _length_code[MAX_MATCH-MIN_MATCH+1]= {\n"); | ||||
|     for (i = 0; i < MAX_MATCH-MIN_MATCH+1; i++) { | ||||
|         fprintf(header, "%2u%s", _length_code[i], | ||||
|                 SEPARATOR(i, MAX_MATCH-MIN_MATCH, 20)); | ||||
| @@ -383,7 +383,7 @@ void gen_trees_header() | ||||
| /* =========================================================================== | ||||
|  * Initialize the tree data structures for a new zlib stream. | ||||
|  */ | ||||
| void _tr_init(s) | ||||
| void ZLIB_INTERNAL _tr_init(s) | ||||
|     deflate_state *s; | ||||
| { | ||||
|     tr_static_init(); | ||||
| @@ -868,13 +868,13 @@ local void send_all_trees(s, lcodes, dcodes, blcodes) | ||||
| /* =========================================================================== | ||||
|  * Send a stored block | ||||
|  */ | ||||
| void _tr_stored_block(s, buf, stored_len, eof) | ||||
| void ZLIB_INTERNAL _tr_stored_block(s, buf, stored_len, last) | ||||
|     deflate_state *s; | ||||
|     charf *buf;       /* input block */ | ||||
|     ulg stored_len;   /* length of input block */ | ||||
|     int eof;          /* true if this is the last block for a file */ | ||||
|     int last;         /* one if this is the last block for a file */ | ||||
| { | ||||
|     send_bits(s, (STORED_BLOCK<<1)+eof, 3);  /* send block type */ | ||||
|     send_bits(s, (STORED_BLOCK<<1)+last, 3);    /* send block type */ | ||||
| #ifdef DEBUG | ||||
|     s->compressed_len = (s->compressed_len + 3 + 7) & (ulg)~7L; | ||||
|     s->compressed_len += (stored_len + 4) << 3; | ||||
| @@ -893,7 +893,7 @@ void _tr_stored_block(s, buf, stored_len, eof) | ||||
|  * To simplify the code, we assume the worst case of last real code encoded | ||||
|  * on one bit only. | ||||
|  */ | ||||
| void _tr_align(s) | ||||
| void ZLIB_INTERNAL _tr_align(s) | ||||
|     deflate_state *s; | ||||
| { | ||||
|     send_bits(s, STATIC_TREES<<1, 3); | ||||
| @@ -922,11 +922,11 @@ void _tr_align(s) | ||||
|  * Determine the best encoding for the current block: dynamic trees, static | ||||
|  * trees or store, and output the encoded block to the zip file. | ||||
|  */ | ||||
| void _tr_flush_block(s, buf, stored_len, eof) | ||||
| void ZLIB_INTERNAL _tr_flush_block(s, buf, stored_len, last) | ||||
|     deflate_state *s; | ||||
|     charf *buf;       /* input block, or NULL if too old */ | ||||
|     ulg stored_len;   /* length of input block */ | ||||
|     int eof;          /* true if this is the last block for a file */ | ||||
|     int last;         /* one if this is the last block for a file */ | ||||
| { | ||||
|     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 */ | ||||
| @@ -935,8 +935,8 @@ void _tr_flush_block(s, buf, stored_len, eof) | ||||
|     if (s->level > 0) { | ||||
|  | ||||
|         /* Check if the file is binary or text */ | ||||
|         if (stored_len > 0 && s->strm->data_type == Z_UNKNOWN) | ||||
|             set_data_type(s); | ||||
|         if (s->strm->data_type == Z_UNKNOWN) | ||||
|             s->strm->data_type = detect_data_type(s); | ||||
|  | ||||
|         /* Construct the literal and distance trees */ | ||||
|         build_tree(s, (tree_desc *)(&(s->l_desc))); | ||||
| @@ -982,20 +982,20 @@ void _tr_flush_block(s, buf, stored_len, eof) | ||||
|          * successful. If LIT_BUFSIZE <= WSIZE, it is never too late to | ||||
|          * transform a block into a stored block. | ||||
|          */ | ||||
|         _tr_stored_block(s, buf, stored_len, eof); | ||||
|         _tr_stored_block(s, buf, stored_len, last); | ||||
|  | ||||
| #ifdef FORCE_STATIC | ||||
|     } else if (static_lenb >= 0) { /* force static trees */ | ||||
| #else | ||||
|     } else if (s->strategy == Z_FIXED || static_lenb == opt_lenb) { | ||||
| #endif | ||||
|         send_bits(s, (STATIC_TREES<<1)+eof, 3); | ||||
|         send_bits(s, (STATIC_TREES<<1)+last, 3); | ||||
|         compress_block(s, (ct_data *)static_ltree, (ct_data *)static_dtree); | ||||
| #ifdef DEBUG | ||||
|         s->compressed_len += 3 + s->static_len; | ||||
| #endif | ||||
|     } else { | ||||
|         send_bits(s, (DYN_TREES<<1)+eof, 3); | ||||
|         send_bits(s, (DYN_TREES<<1)+last, 3); | ||||
|         send_all_trees(s, s->l_desc.max_code+1, s->d_desc.max_code+1, | ||||
|                        max_blindex+1); | ||||
|         compress_block(s, (ct_data *)s->dyn_ltree, (ct_data *)s->dyn_dtree); | ||||
| @@ -1009,21 +1009,21 @@ void _tr_flush_block(s, buf, stored_len, eof) | ||||
|      */ | ||||
|     init_block(s); | ||||
|  | ||||
|     if (eof) { | ||||
|     if (last) { | ||||
|         bi_windup(s); | ||||
| #ifdef DEBUG | ||||
|         s->compressed_len += 7;  /* align on byte boundary */ | ||||
| #endif | ||||
|     } | ||||
|     Tracev((stderr,"\ncomprlen %lu(%lu) ", s->compressed_len>>3, | ||||
|            s->compressed_len-7*eof)); | ||||
|            s->compressed_len-7*last)); | ||||
| } | ||||
|  | ||||
| /* =========================================================================== | ||||
|  * Save the match info and tally the frequency counts. Return true if | ||||
|  * the current block must be flushed. | ||||
|  */ | ||||
| int _tr_tally (s, dist, lc) | ||||
| int ZLIB_INTERNAL _tr_tally (s, dist, lc) | ||||
|     deflate_state *s; | ||||
|     unsigned dist;  /* distance of matched string */ | ||||
|     unsigned lc;    /* match length-MIN_MATCH or unmatched char (if dist==0) */ | ||||
| @@ -1122,24 +1122,45 @@ local void compress_block(s, ltree, dtree) | ||||
| } | ||||
|  | ||||
| /* =========================================================================== | ||||
|  * Set the data type to BINARY or TEXT, using a crude approximation: | ||||
|  * set it to Z_TEXT if all symbols are either printable characters (33 to 255) | ||||
|  * or white spaces (9 to 13, or 32); or set it to Z_BINARY otherwise. | ||||
|  * 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 | ||||
|  *       "black list" (0..6, 14..25, 28..31). | ||||
|  *    b) There is at least one printable character belonging to the | ||||
|  *       "white 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 void set_data_type(s) | ||||
| local int detect_data_type(s) | ||||
|     deflate_state *s; | ||||
| { | ||||
|     /* black_mask is the bit mask of black-listed bytes | ||||
|      * set bits 0..6, 14..25, and 28..31 | ||||
|      * 0xf3ffc07f = binary 11110011111111111100000001111111 | ||||
|      */ | ||||
|     unsigned long black_mask = 0xf3ffc07fUL; | ||||
|     int n; | ||||
|  | ||||
|     for (n = 0; n < 9; n++) | ||||
|     /* Check for non-textual ("black-listed") bytes. */ | ||||
|     for (n = 0; n <= 31; n++, black_mask >>= 1) | ||||
|         if ((black_mask & 1) && (s->dyn_ltree[n].Freq != 0)) | ||||
|             return Z_BINARY; | ||||
|  | ||||
|     /* Check for textual ("white-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) | ||||
|             break; | ||||
|     if (n == 9) | ||||
|         for (n = 14; n < 32; n++) | ||||
|             if (s->dyn_ltree[n].Freq != 0) | ||||
|                 break; | ||||
|     s->strm->data_type = (n == 32) ? Z_TEXT : Z_BINARY; | ||||
|             return Z_TEXT; | ||||
|  | ||||
|     /* There are no "black-listed" or "white-listed" bytes: | ||||
|      * this stream either is empty or has tolerated ("gray-listed") bytes only. | ||||
|      */ | ||||
|     return Z_BINARY; | ||||
| } | ||||
|  | ||||
| /* =========================================================================== | ||||
|   | ||||
| @@ -70,7 +70,7 @@ local const ct_data static_dtree[D_CODES] = { | ||||
| {{19},{ 5}}, {{11},{ 5}}, {{27},{ 5}}, {{ 7},{ 5}}, {{23},{ 5}} | ||||
| }; | ||||
|  | ||||
| const uch _dist_code[DIST_CODE_LEN] = { | ||||
| const uch ZLIB_INTERNAL _dist_code[DIST_CODE_LEN] = { | ||||
|  0,  1,  2,  3,  4,  4,  5,  5,  6,  6,  6,  6,  7,  7,  7,  7,  8,  8,  8,  8, | ||||
|  8,  8,  8,  8,  9,  9,  9,  9,  9,  9,  9,  9, 10, 10, 10, 10, 10, 10, 10, 10, | ||||
| 10, 10, 10, 10, 10, 10, 10, 10, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, 11, | ||||
| @@ -99,7 +99,7 @@ const uch _dist_code[DIST_CODE_LEN] = { | ||||
| 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29, 29 | ||||
| }; | ||||
|  | ||||
| const uch _length_code[MAX_MATCH-MIN_MATCH+1]= { | ||||
| const uch ZLIB_INTERNAL _length_code[MAX_MATCH-MIN_MATCH+1]= { | ||||
|  0,  1,  2,  3,  4,  5,  6,  7,  8,  8,  9,  9, 10, 10, 11, 11, 12, 12, 12, 12, | ||||
| 13, 13, 13, 13, 14, 14, 14, 14, 15, 15, 15, 15, 16, 16, 16, 16, 16, 16, 16, 16, | ||||
| 17, 17, 17, 17, 17, 17, 17, 17, 18, 18, 18, 18, 18, 18, 18, 18, 19, 19, 19, 19, | ||||
|   | ||||
							
								
								
									
										59
									
								
								Foundation/src/uncompr.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								Foundation/src/uncompr.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,59 @@ | ||||
| /* uncompr.c -- decompress a memory buffer | ||||
|  * Copyright (C) 1995-2003, 2010 Jean-loup Gailly. | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| /* @(#) $Id$ */ | ||||
|  | ||||
| #define ZLIB_INTERNAL | ||||
| #include "zlib.h" | ||||
|  | ||||
| /* =========================================================================== | ||||
|      Decompresses the source buffer into the destination buffer.  sourceLen is | ||||
|    the byte length of the source buffer. Upon entry, destLen is the total | ||||
|    size of the destination buffer, which must be large enough to hold the | ||||
|    entire uncompressed data. (The size of the uncompressed data must have | ||||
|    been saved previously by the compressor and transmitted to the decompressor | ||||
|    by some mechanism outside the scope of this compression library.) | ||||
|    Upon exit, destLen is the actual size of the compressed buffer. | ||||
|  | ||||
|      uncompress returns Z_OK if success, Z_MEM_ERROR if there was not | ||||
|    enough memory, Z_BUF_ERROR if there was not enough room in the output | ||||
|    buffer, or Z_DATA_ERROR if the input data was corrupted. | ||||
| */ | ||||
| int ZEXPORT uncompress (dest, destLen, source, sourceLen) | ||||
|     Bytef *dest; | ||||
|     uLongf *destLen; | ||||
|     const Bytef *source; | ||||
|     uLong sourceLen; | ||||
| { | ||||
|     z_stream stream; | ||||
|     int err; | ||||
|  | ||||
|     stream.next_in = (Bytef*)source; | ||||
|     stream.avail_in = (uInt)sourceLen; | ||||
|     /* Check for source > 64K on 16-bit machine: */ | ||||
|     if ((uLong)stream.avail_in != sourceLen) return Z_BUF_ERROR; | ||||
|  | ||||
|     stream.next_out = dest; | ||||
|     stream.avail_out = (uInt)*destLen; | ||||
|     if ((uLong)stream.avail_out != *destLen) return Z_BUF_ERROR; | ||||
|  | ||||
|     stream.zalloc = (alloc_func)0; | ||||
|     stream.zfree = (free_func)0; | ||||
|  | ||||
|     err = inflateInit(&stream); | ||||
|     if (err != Z_OK) return err; | ||||
|  | ||||
|     err = inflate(&stream, Z_FINISH); | ||||
|     if (err != Z_STREAM_END) { | ||||
|         inflateEnd(&stream); | ||||
|         if (err == Z_NEED_DICT || (err == Z_BUF_ERROR && stream.avail_in == 0)) | ||||
|             return Z_DATA_ERROR; | ||||
|         return err; | ||||
|     } | ||||
|     *destLen = stream.total_out; | ||||
|  | ||||
|     err = inflateEnd(&stream); | ||||
|     return err; | ||||
| } | ||||
| @@ -1,9 +1,9 @@ | ||||
| /* zconf.h -- configuration of the zlib compression library | ||||
|  * Copyright (C) 1995-2005 Jean-loup Gailly. | ||||
|  * Copyright (C) 1995-2010 Jean-loup Gailly. | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| /* @(#) $Id: //poco/svn/Foundation/src/zconf.h#2 $ */ | ||||
| /* @(#) $Id$ */ | ||||
|  | ||||
| #ifndef ZCONF_H | ||||
| #define ZCONF_H | ||||
| @@ -11,52 +11,124 @@ | ||||
| /* | ||||
|  * If you *really* need a unique prefix for all types and library functions, | ||||
|  * compile with -DZ_PREFIX. The "standard" zlib should be compiled without it. | ||||
|  * Even better than compiling with -DZ_PREFIX would be to use configure to set | ||||
|  * this permanently in zconf.h using "./configure --zprefix". | ||||
|  */ | ||||
| #ifdef Z_PREFIX | ||||
| #  define deflateInit_          z_deflateInit_ | ||||
| #  define deflate               z_deflate | ||||
| #  define deflateEnd            z_deflateEnd | ||||
| #  define inflateInit_          z_inflateInit_ | ||||
| #  define inflate               z_inflate | ||||
| #  define inflateEnd            z_inflateEnd | ||||
| #  define deflateInit2_         z_deflateInit2_ | ||||
| #  define deflateSetDictionary  z_deflateSetDictionary | ||||
| #  define deflateCopy           z_deflateCopy | ||||
| #  define deflateReset          z_deflateReset | ||||
| #  define deflateParams         z_deflateParams | ||||
| #  define deflateBound          z_deflateBound | ||||
| #  define deflatePrime          z_deflatePrime | ||||
| #  define inflateInit2_         z_inflateInit2_ | ||||
| #  define inflateSetDictionary  z_inflateSetDictionary | ||||
| #  define inflateSync           z_inflateSync | ||||
| #  define inflateSyncPoint      z_inflateSyncPoint | ||||
| #  define inflateCopy           z_inflateCopy | ||||
| #  define inflateReset          z_inflateReset | ||||
| #  define inflateBack           z_inflateBack | ||||
| #  define inflateBackEnd        z_inflateBackEnd | ||||
| #ifdef Z_PREFIX     /* may be set to #if 1 by ./configure */ | ||||
|  | ||||
| /* all linked symbols */ | ||||
| #  define _dist_code            z__dist_code | ||||
| #  define _length_code          z__length_code | ||||
| #  define _tr_align             z__tr_align | ||||
| #  define _tr_flush_block       z__tr_flush_block | ||||
| #  define _tr_init              z__tr_init | ||||
| #  define _tr_stored_block      z__tr_stored_block | ||||
| #  define _tr_tally             z__tr_tally | ||||
| #  define adler32               z_adler32 | ||||
| #  define adler32_combine       z_adler32_combine | ||||
| #  define adler32_combine64     z_adler32_combine64 | ||||
| #  define compress              z_compress | ||||
| #  define compress2             z_compress2 | ||||
| #  define compressBound         z_compressBound | ||||
| #  define uncompress            z_uncompress | ||||
| #  define adler32               z_adler32 | ||||
| #  define crc32                 z_crc32 | ||||
| #  define crc32_combine         z_crc32_combine | ||||
| #  define crc32_combine64       z_crc32_combine64 | ||||
| #  define deflate               z_deflate | ||||
| #  define deflateBound          z_deflateBound | ||||
| #  define deflateCopy           z_deflateCopy | ||||
| #  define deflateEnd            z_deflateEnd | ||||
| #  define deflateInit2_         z_deflateInit2_ | ||||
| #  define deflateInit_          z_deflateInit_ | ||||
| #  define deflateParams         z_deflateParams | ||||
| #  define deflatePrime          z_deflatePrime | ||||
| #  define deflateReset          z_deflateReset | ||||
| #  define deflateSetDictionary  z_deflateSetDictionary | ||||
| #  define deflateSetHeader      z_deflateSetHeader | ||||
| #  define deflateTune           z_deflateTune | ||||
| #  define deflate_copyright     z_deflate_copyright | ||||
| #  define get_crc_table         z_get_crc_table | ||||
| #  define gz_error              z_gz_error | ||||
| #  define gz_intmax             z_gz_intmax | ||||
| #  define gz_strwinerror        z_gz_strwinerror | ||||
| #  define gzbuffer              z_gzbuffer | ||||
| #  define gzclearerr            z_gzclearerr | ||||
| #  define gzclose               z_gzclose | ||||
| #  define gzclose_r             z_gzclose_r | ||||
| #  define gzclose_w             z_gzclose_w | ||||
| #  define gzdirect              z_gzdirect | ||||
| #  define gzdopen               z_gzdopen | ||||
| #  define gzeof                 z_gzeof | ||||
| #  define gzerror               z_gzerror | ||||
| #  define gzflush               z_gzflush | ||||
| #  define gzgetc                z_gzgetc | ||||
| #  define gzgets                z_gzgets | ||||
| #  define gzoffset              z_gzoffset | ||||
| #  define gzoffset64            z_gzoffset64 | ||||
| #  define gzopen                z_gzopen | ||||
| #  define gzopen64              z_gzopen64 | ||||
| #  define gzprintf              z_gzprintf | ||||
| #  define gzputc                z_gzputc | ||||
| #  define gzputs                z_gzputs | ||||
| #  define gzread                z_gzread | ||||
| #  define gzrewind              z_gzrewind | ||||
| #  define gzseek                z_gzseek | ||||
| #  define gzseek64              z_gzseek64 | ||||
| #  define gzsetparams           z_gzsetparams | ||||
| #  define gztell                z_gztell | ||||
| #  define gztell64              z_gztell64 | ||||
| #  define gzungetc              z_gzungetc | ||||
| #  define gzwrite               z_gzwrite | ||||
| #  define inflate               z_inflate | ||||
| #  define inflateBack           z_inflateBack | ||||
| #  define inflateBackEnd        z_inflateBackEnd | ||||
| #  define inflateBackInit_      z_inflateBackInit_ | ||||
| #  define inflateCopy           z_inflateCopy | ||||
| #  define inflateEnd            z_inflateEnd | ||||
| #  define inflateGetHeader      z_inflateGetHeader | ||||
| #  define inflateInit2_         z_inflateInit2_ | ||||
| #  define inflateInit_          z_inflateInit_ | ||||
| #  define inflateMark           z_inflateMark | ||||
| #  define inflatePrime          z_inflatePrime | ||||
| #  define inflateReset          z_inflateReset | ||||
| #  define inflateReset2         z_inflateReset2 | ||||
| #  define inflateSetDictionary  z_inflateSetDictionary | ||||
| #  define inflateSync           z_inflateSync | ||||
| #  define inflateSyncPoint      z_inflateSyncPoint | ||||
| #  define inflateUndermine      z_inflateUndermine | ||||
| #  define inflate_copyright     z_inflate_copyright | ||||
| #  define inflate_fast          z_inflate_fast | ||||
| #  define inflate_table         z_inflate_table | ||||
| #  define uncompress            z_uncompress | ||||
| #  define zError                z_zError | ||||
| #  define zcalloc               z_zcalloc | ||||
| #  define zcfree                z_zcfree | ||||
| #  define zlibCompileFlags      z_zlibCompileFlags | ||||
| #  define zlibVersion           z_zlibVersion | ||||
|  | ||||
| #  define alloc_func            z_alloc_func | ||||
| #  define free_func             z_free_func | ||||
| #  define in_func               z_in_func | ||||
| #  define out_func              z_out_func | ||||
| /* all zlib typedefs in zlib.h and zconf.h */ | ||||
| #  define Byte                  z_Byte | ||||
| #  define uInt                  z_uInt | ||||
| #  define uLong                 z_uLong | ||||
| #  define Bytef                 z_Bytef | ||||
| #  define alloc_func            z_alloc_func | ||||
| #  define charf                 z_charf | ||||
| #  define free_func             z_free_func | ||||
| #  define gzFile                z_gzFile | ||||
| #  define gz_header             z_gz_header | ||||
| #  define gz_headerp            z_gz_headerp | ||||
| #  define in_func               z_in_func | ||||
| #  define intf                  z_intf | ||||
| #  define out_func              z_out_func | ||||
| #  define uInt                  z_uInt | ||||
| #  define uIntf                 z_uIntf | ||||
| #  define uLong                 z_uLong | ||||
| #  define uLongf                z_uLongf | ||||
| #  define voidpf                z_voidpf | ||||
| #  define voidp                 z_voidp | ||||
| #  define voidpc                z_voidpc | ||||
| #  define voidpf                z_voidpf | ||||
|  | ||||
| /* all zlib structs in zlib.h and zconf.h */ | ||||
| #  define gz_header_s           z_gz_header_s | ||||
| #  define internal_state        z_internal_state | ||||
|  | ||||
| #endif | ||||
|  | ||||
| #if defined(__MSDOS__) && !defined(MSDOS) | ||||
| @@ -285,22 +357,29 @@ typedef uLong FAR uLongf; | ||||
| #endif | ||||
|  | ||||
| #if 0           /* HAVE_UNISTD_H -- this line is updated by ./configure */ | ||||
| #  include <sys/types.h> /* for off_t */ | ||||
| #  include <unistd.h>    /* for SEEK_* and off_t */ | ||||
| #  include <sys/types.h>    /* for off_t */ | ||||
| #  include <unistd.h>       /* for SEEK_* and off_t */ | ||||
| #  ifdef VMS | ||||
| #    include <unixio.h>   /* for off_t */ | ||||
| #    include <unixio.h>     /* for off_t */ | ||||
| #  endif | ||||
| #    define z_off_t off_t | ||||
| #  endif | ||||
| #  define z_off_t off_t | ||||
| #endif | ||||
| #ifndef SEEK_SET | ||||
| #  define SEEK_SET        0       /* Seek from beginning of file.  */ | ||||
| #  define SEEK_CUR        1       /* Seek from current position.  */ | ||||
| #  define SEEK_END        2       /* Set file pointer to EOF plus "offset" */ | ||||
| #endif | ||||
|  | ||||
| #ifndef z_off_t | ||||
| #  define z_off_t long | ||||
| #endif | ||||
|  | ||||
| #if defined(_LARGEFILE64_SOURCE) && _LFS64_LARGEFILE-0 | ||||
| #  define z_off64_t off64_t | ||||
| #else | ||||
| #  define z_off64_t z_off_t | ||||
| #endif | ||||
|  | ||||
| #if defined(__OS400__) | ||||
| #  define NO_vsnprintf | ||||
| #endif | ||||
| @@ -314,19 +393,19 @@ typedef uLong FAR uLongf; | ||||
|  | ||||
| /* MVS linker does not support external names larger than 8 bytes */ | ||||
| #if defined(__MVS__) | ||||
| #   pragma map(deflateInit_,"DEIN") | ||||
| #   pragma map(deflateInit2_,"DEIN2") | ||||
| #   pragma map(deflateEnd,"DEEND") | ||||
| #   pragma map(deflateBound,"DEBND") | ||||
| #   pragma map(inflateInit_,"ININ") | ||||
| #   pragma map(inflateInit2_,"ININ2") | ||||
| #   pragma map(inflateEnd,"INEND") | ||||
| #   pragma map(inflateSync,"INSY") | ||||
| #   pragma map(inflateSetDictionary,"INSEDI") | ||||
| #   pragma map(compressBound,"CMBND") | ||||
| #   pragma map(inflate_table,"INTABL") | ||||
| #   pragma map(inflate_fast,"INFA") | ||||
| #   pragma map(inflate_copyright,"INCOPY") | ||||
|   #pragma map(deflateInit_,"DEIN") | ||||
|   #pragma map(deflateInit2_,"DEIN2") | ||||
|   #pragma map(deflateEnd,"DEEND") | ||||
|   #pragma map(deflateBound,"DEBND") | ||||
|   #pragma map(inflateInit_,"ININ") | ||||
|   #pragma map(inflateInit2_,"ININ2") | ||||
|   #pragma map(inflateEnd,"INEND") | ||||
|   #pragma map(inflateSync,"INSY") | ||||
|   #pragma map(inflateSetDictionary,"INSEDI") | ||||
|   #pragma map(compressBound,"CMBND") | ||||
|   #pragma map(inflate_table,"INTABL") | ||||
|   #pragma map(inflate_fast,"INFA") | ||||
|   #pragma map(inflate_copyright,"INCOPY") | ||||
| #endif | ||||
|  | ||||
| #endif /* ZCONF_H */ | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,9 +1,9 @@ | ||||
| /* zutil.c -- target dependent utility functions for the compression library | ||||
|  * Copyright (C) 1995-2005 Jean-loup Gailly. | ||||
|  * Copyright (C) 1995-2005, 2010 Jean-loup Gailly. | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| /* @(#) $Id: //poco/svn/Foundation/src/zutil.c#2 $ */ | ||||
| /* @(#) $Id$ */ | ||||
|  | ||||
| #include "zutil.h" | ||||
|  | ||||
| @@ -34,25 +34,25 @@ uLong ZEXPORT zlibCompileFlags() | ||||
|     uLong flags; | ||||
|  | ||||
|     flags = 0; | ||||
|     switch (sizeof(uInt)) { | ||||
|     switch ((int)(sizeof(uInt))) { | ||||
|     case 2:     break; | ||||
|     case 4:     flags += 1;     break; | ||||
|     case 8:     flags += 2;     break; | ||||
|     default:    flags += 3; | ||||
|     } | ||||
|     switch (sizeof(uLong)) { | ||||
|     switch ((int)(sizeof(uLong))) { | ||||
|     case 2:     break; | ||||
|     case 4:     flags += 1 << 2;        break; | ||||
|     case 8:     flags += 2 << 2;        break; | ||||
|     default:    flags += 3 << 2; | ||||
|     } | ||||
|     switch (sizeof(voidpf)) { | ||||
|     switch ((int)(sizeof(voidpf))) { | ||||
|     case 2:     break; | ||||
|     case 4:     flags += 1 << 4;        break; | ||||
|     case 8:     flags += 2 << 4;        break; | ||||
|     default:    flags += 3 << 4; | ||||
|     } | ||||
|     switch (sizeof(z_off_t)) { | ||||
|     switch ((int)(sizeof(z_off_t))) { | ||||
|     case 2:     break; | ||||
|     case 4:     flags += 1 << 6;        break; | ||||
|     case 8:     flags += 2 << 6;        break; | ||||
| @@ -117,9 +117,9 @@ uLong ZEXPORT zlibCompileFlags() | ||||
| #  ifndef verbose | ||||
| #    define verbose 0 | ||||
| #  endif | ||||
| int z_verbose = verbose; | ||||
| int ZLIB_INTERNAL z_verbose = verbose; | ||||
|  | ||||
| void z_error (m) | ||||
| void ZLIB_INTERNAL z_error (m) | ||||
|     char *m; | ||||
| { | ||||
|     fprintf(stderr, "%s\n", m); | ||||
| @@ -146,7 +146,7 @@ const char * ZEXPORT zError(err) | ||||
|  | ||||
| #ifndef HAVE_MEMCPY | ||||
|  | ||||
| void zmemcpy(dest, source, len) | ||||
| void ZLIB_INTERNAL zmemcpy(dest, source, len) | ||||
|     Bytef* dest; | ||||
|     const Bytef* source; | ||||
|     uInt  len; | ||||
| @@ -157,7 +157,7 @@ void zmemcpy(dest, source, len) | ||||
|     } while (--len != 0); | ||||
| } | ||||
|  | ||||
| int zmemcmp(s1, s2, len) | ||||
| int ZLIB_INTERNAL zmemcmp(s1, s2, len) | ||||
|     const Bytef* s1; | ||||
|     const Bytef* s2; | ||||
|     uInt  len; | ||||
| @@ -170,7 +170,7 @@ int zmemcmp(s1, s2, len) | ||||
|     return 0; | ||||
| } | ||||
|  | ||||
| void zmemzero(dest, len) | ||||
| void ZLIB_INTERNAL zmemzero(dest, len) | ||||
|     Bytef* dest; | ||||
|     uInt  len; | ||||
| { | ||||
| @@ -213,7 +213,7 @@ local ptr_table table[MAX_PTR]; | ||||
|  * a protected system like OS/2. Use Microsoft C instead. | ||||
|  */ | ||||
|  | ||||
| voidpf zcalloc (voidpf opaque, unsigned items, unsigned size) | ||||
| voidpf ZLIB_INTERNAL zcalloc (voidpf opaque, unsigned items, unsigned size) | ||||
| { | ||||
|     voidpf buf = opaque; /* just to make some compilers happy */ | ||||
|     ulg bsize = (ulg)items*size; | ||||
| @@ -237,7 +237,7 @@ voidpf zcalloc (voidpf opaque, unsigned items, unsigned size) | ||||
|     return buf; | ||||
| } | ||||
|  | ||||
| void  zcfree (voidpf opaque, voidpf ptr) | ||||
| void ZLIB_INTERNAL zcfree (voidpf opaque, voidpf ptr) | ||||
| { | ||||
|     int n; | ||||
|     if (*(ush*)&ptr != 0) { /* object < 64K */ | ||||
| @@ -272,13 +272,13 @@ void  zcfree (voidpf opaque, voidpf ptr) | ||||
| #  define _hfree   hfree | ||||
| #endif | ||||
|  | ||||
| voidpf zcalloc (voidpf opaque, unsigned items, unsigned size) | ||||
| voidpf ZLIB_INTERNAL zcalloc (voidpf opaque, uInt items, uInt size) | ||||
| { | ||||
|     if (opaque) opaque = 0; /* to make compiler happy */ | ||||
|     return _halloc((long)items, size); | ||||
| } | ||||
|  | ||||
| void  zcfree (voidpf opaque, voidpf ptr) | ||||
| void ZLIB_INTERNAL zcfree (voidpf opaque, voidpf ptr) | ||||
| { | ||||
|     if (opaque) opaque = 0; /* to make compiler happy */ | ||||
|     _hfree(ptr); | ||||
| @@ -297,7 +297,7 @@ extern voidp  calloc OF((uInt items, uInt size)); | ||||
| extern void   free   OF((voidpf ptr)); | ||||
| #endif | ||||
|  | ||||
| voidpf zcalloc (opaque, items, size) | ||||
| voidpf ZLIB_INTERNAL zcalloc (opaque, items, size) | ||||
|     voidpf opaque; | ||||
|     unsigned items; | ||||
|     unsigned size; | ||||
| @@ -307,7 +307,7 @@ voidpf zcalloc (opaque, items, size) | ||||
|                               (voidpf)calloc(items, size); | ||||
| } | ||||
|  | ||||
| void  zcfree (opaque, ptr) | ||||
| void ZLIB_INTERNAL zcfree (opaque, ptr) | ||||
|     voidpf opaque; | ||||
|     voidpf ptr; | ||||
| { | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| /* zutil.h -- internal interface and configuration of the compression library | ||||
|  * Copyright (C) 1995-2005 Jean-loup Gailly. | ||||
|  * Copyright (C) 1995-2010 Jean-loup Gailly. | ||||
|  * For conditions of distribution and use, see copyright notice in zlib.h | ||||
|  */ | ||||
|  | ||||
| @@ -8,36 +8,26 @@ | ||||
|    subject to change. Applications should only use zlib.h. | ||||
|  */ | ||||
|  | ||||
| /* @(#) $Id: //poco/svn/Foundation/src/zutil.h#2 $ */ | ||||
| /* @(#) $Id$ */ | ||||
|  | ||||
| #ifndef ZUTIL_H | ||||
| #define ZUTIL_H | ||||
|  | ||||
| #define ZLIB_INTERNAL | ||||
| #if ((__GNUC__-0) * 10 + __GNUC_MINOR__-0 >= 33) && !defined(NO_VIZ) | ||||
| #  define ZLIB_INTERNAL __attribute__((visibility ("hidden"))) | ||||
| #else | ||||
| #  define ZLIB_INTERNAL | ||||
| #endif | ||||
|  | ||||
| #include "zlib.h" | ||||
|  | ||||
| #ifdef STDC | ||||
| #  ifndef _WIN32_WCE | ||||
| #  if !(defined(_WIN32_WCE) && defined(_MSC_VER)) | ||||
| #    include <stddef.h> | ||||
| #  endif | ||||
| #  include <string.h> | ||||
| #  include <stdlib.h> | ||||
| #endif | ||||
| #ifdef NO_ERRNO_H | ||||
| #   ifdef _WIN32_WCE | ||||
|       /* The Microsoft C Run-Time Library for Windows CE doesn't have | ||||
|        * errno.  We define it as a global variable to simplify porting. | ||||
|        * Its value is always 0 and should not be used.  We rename it to | ||||
|        * avoid conflict with other libraries that use the same workaround. | ||||
|        */ | ||||
| #     define errno z_errno | ||||
| #   endif | ||||
|     extern int errno; | ||||
| #else | ||||
| #  ifndef _WIN32_WCE | ||||
| #    include <errno.h> | ||||
| #  endif | ||||
| #endif | ||||
|  | ||||
| #ifndef local | ||||
| #  define local static | ||||
| @@ -89,7 +79,7 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ | ||||
| #if defined(MSDOS) || (defined(WINDOWS) && !defined(WIN32)) | ||||
| #  define OS_CODE  0x00 | ||||
| #  if defined(__TURBOC__) || defined(__BORLANDC__) | ||||
| #    if(__STDC__ == 1) && (defined(__LARGE__) || defined(__COMPACT__)) | ||||
| #    if (__STDC__ == 1) && (defined(__LARGE__) || defined(__COMPACT__)) | ||||
|        /* Allow compilation with ANSI keywords only enabled */ | ||||
|        void _Cdecl farfree( void *block ); | ||||
|        void *_Cdecl farmalloc( unsigned long nbytes ); | ||||
| @@ -118,7 +108,7 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ | ||||
| #ifdef OS2 | ||||
| #  define OS_CODE  0x06 | ||||
| #  ifdef M_I86 | ||||
|      #include <malloc.h> | ||||
| #    include <malloc.h> | ||||
| #  endif | ||||
| #endif | ||||
|  | ||||
| @@ -151,7 +141,7 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ | ||||
| #  define fdopen(fd,mode) NULL /* No fdopen() */ | ||||
| #endif | ||||
|  | ||||
| #if (defined(_MSC_VER) && (_MSC_VER > 600)) | ||||
| #if (defined(_MSC_VER) && (_MSC_VER > 600)) && !defined __INTERIX | ||||
| #  if defined(_WIN32_WCE) | ||||
| #    define fdopen(fd,mode) NULL /* No fdopen() */ | ||||
| #    ifndef _PTRDIFF_T_DEFINED | ||||
| @@ -163,6 +153,18 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ | ||||
| #  endif | ||||
| #endif | ||||
|  | ||||
| #if defined(__BORLANDC__) | ||||
|   #pragma warn -8004 | ||||
|   #pragma warn -8008 | ||||
|   #pragma warn -8066 | ||||
| #endif | ||||
|  | ||||
| /* provide prototypes for these when building zlib without LFS */ | ||||
| #if !defined(_LARGEFILE64_SOURCE) || _LFS64_LARGEFILE-0 == 0 | ||||
|     ZEXTERN uLong ZEXPORT adler32_combine64 OF((uLong, uLong, z_off_t)); | ||||
|     ZEXTERN uLong ZEXPORT crc32_combine64 OF((uLong, uLong, z_off_t)); | ||||
| #endif | ||||
|  | ||||
|         /* common defaults */ | ||||
|  | ||||
| #ifndef OS_CODE | ||||
| @@ -197,7 +199,9 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ | ||||
| #  ifdef WIN32 | ||||
|      /* In Win32, vsnprintf is available as the "non-ANSI" _vsnprintf. */ | ||||
| #    if !defined(vsnprintf) && !defined(NO_vsnprintf) | ||||
| #      define vsnprintf _vsnprintf | ||||
| #      if !defined(_MSC_VER) || ( defined(_MSC_VER) && _MSC_VER < 1500 ) | ||||
| #         define vsnprintf _vsnprintf | ||||
| #      endif | ||||
| #    endif | ||||
| #  endif | ||||
| #  ifdef __SASC | ||||
| @@ -232,16 +236,16 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ | ||||
| #    define zmemzero(dest, len) memset(dest, 0, len) | ||||
| #  endif | ||||
| #else | ||||
|    extern void zmemcpy  OF((Bytef* dest, const Bytef* source, uInt len)); | ||||
|    extern int  zmemcmp  OF((const Bytef* s1, const Bytef* s2, uInt len)); | ||||
|    extern void zmemzero OF((Bytef* dest, uInt len)); | ||||
|    void ZLIB_INTERNAL zmemcpy OF((Bytef* dest, const Bytef* source, uInt len)); | ||||
|    int ZLIB_INTERNAL zmemcmp OF((const Bytef* s1, const Bytef* s2, uInt len)); | ||||
|    void ZLIB_INTERNAL zmemzero OF((Bytef* dest, uInt len)); | ||||
| #endif | ||||
|  | ||||
| /* Diagnostic functions */ | ||||
| #ifdef DEBUG | ||||
| #  include <stdio.h> | ||||
|    extern int z_verbose; | ||||
|    extern void z_error    OF((char *m)); | ||||
|    extern int ZLIB_INTERNAL z_verbose; | ||||
|    extern void ZLIB_INTERNAL z_error OF((char *m)); | ||||
| #  define Assert(cond,msg) {if(!(cond)) z_error(msg);} | ||||
| #  define Trace(x) {if (z_verbose>=0) fprintf x ;} | ||||
| #  define Tracev(x) {if (z_verbose>0) fprintf x ;} | ||||
| @@ -258,8 +262,9 @@ extern const char * const z_errmsg[10]; /* indexed by 2-zlib_error */ | ||||
| #endif | ||||
|  | ||||
|  | ||||
| voidpf zcalloc OF((voidpf opaque, unsigned items, unsigned size)); | ||||
| void   zcfree  OF((voidpf opaque, voidpf ptr)); | ||||
| voidpf ZLIB_INTERNAL zcalloc OF((voidpf opaque, unsigned items, | ||||
|                         unsigned size)); | ||||
| void ZLIB_INTERNAL zcfree  OF((voidpf opaque, voidpf ptr)); | ||||
|  | ||||
| #define ZALLOC(strm, items, size) \ | ||||
|            (*((strm)->zalloc))((strm)->opaque, (items), (size)) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Marian Krivos
					Marian Krivos