| 1 | 
 /* gzguts.h -- zlib internal header definitions for gz* operations | 
 
 
 
 
 
 | 2 | 
  * Copyright (C) 2004, 2005, 2010, 2011, 2012, 2013 Mark Adler | 
 
 
 
 
 
 | 3 | 
  * For conditions of distribution and use, see copyright notice in zlib.h | 
 
 
 
 
 
 | 4 | 
  */ | 
 
 
 
 
 
 | 5 | 
  | 
 
 
 
 
 
 | 6 | 
 #ifdef _LARGEFILE64_SOURCE | 
 
 
 
 
 
 | 7 | 
 #  ifndef _LARGEFILE_SOURCE | 
 
 
 
 
 
 | 8 | 
 #    define _LARGEFILE_SOURCE 1 | 
 
 
 
 
 
 | 9 | 
 #  endif | 
 
 
 
 
 
 | 10 | 
 #  ifdef _FILE_OFFSET_BITS | 
 
 
 
 
 
 | 11 | 
 #    undef _FILE_OFFSET_BITS | 
 
 
 
 
 
 | 12 | 
 #  endif | 
 
 
 
 
 
 | 13 | 
 #endif | 
 
 
 
 
 
 | 14 | 
  | 
 
 
 
 
 
 | 15 | 
 #ifdef HAVE_HIDDEN | 
 
 
 
 
 
 | 16 | 
 #  define ZLIB_INTERNAL __attribute__((visibility ("hidden"))) | 
 
 
 
 
 
 | 17 | 
 #else | 
 
 
 
 
 
 | 18 | 
 #  define ZLIB_INTERNAL | 
 
 
 
 
 
 | 19 | 
 #endif | 
 
 
 
 
 
 | 20 | 
  | 
 
 
 
 
 
 | 21 | 
 #include <stdio.h> | 
 
 
 
 
 
 | 22 | 
 #include "zlib.h" | 
 
 
 
 
 
 | 23 | 
 #ifdef STDC | 
 
 
 
 
 
 | 24 | 
 #  include <string.h> | 
 
 
 
 
 
 | 25 | 
 #  include <stdlib.h> | 
 
 
 
 
 
 | 26 | 
 #  include <limits.h> | 
 
 
 
 
 
 | 27 | 
 #endif | 
 
 
 
 
 
 | 28 | 
 #include <fcntl.h> | 
 
 
 
 
 
 | 29 | 
  | 
 
 
 
 
 
 | 30 | 
 #ifdef _WIN32 | 
 
 
 
 
 
 | 31 | 
 #  include <stddef.h> | 
 
 
 
 
 
 | 32 | 
 #endif | 
 
 
 
 
 
 | 33 | 
  | 
 
 
 
 
 
 | 34 | 
 #if defined(__TURBOC__) || defined(_MSC_VER) || defined(_WIN32) | 
 
 
 
 
 
 | 35 | 
 #  include <io.h> | 
 
 
 
 
 
 | 36 | 
 #endif | 
 
 
 
 
 
 | 37 | 
  | 
 
 
 
 
 
 | 38 | 
 #ifdef WINAPI_FAMILY | 
 
 
 
 
 
 | 39 | 
 #  define open _open | 
 
 
 
 
 
 | 40 | 
 #  define read _read | 
 
 
 
 
 
 | 41 | 
 #  define write _write | 
 
 
 
 
 
 | 42 | 
 #  define close _close | 
 
 
 
 
 
 | 43 | 
 #endif | 
 
 
 
 
 
 | 44 | 
  | 
 
 
 
 
 
 | 45 | 
 #ifdef NO_DEFLATE       /* for compatibility with old definition */ | 
 
 
 
 
 
 | 46 | 
 #  define NO_GZCOMPRESS | 
 
 
 
 
 
 | 47 | 
 #endif | 
 
 
 
 
 
 | 48 | 
  | 
 
 
 
 
 
 | 49 | 
 #if defined(STDC99) || (defined(__TURBOC__) && __TURBOC__ >= 0x550) | 
 
 
 
 
 
 | 50 | 
 #  ifndef HAVE_VSNPRINTF | 
 
 
 
 
 
 | 51 | 
 #    define HAVE_VSNPRINTF | 
 
 
 
 
 
 | 52 | 
 #  endif | 
 
 
 
 
 
 | 53 | 
 #endif | 
 
 
 
 
 
 | 54 | 
  | 
 
 
 
 
 
 | 55 | 
 #if defined(__CYGWIN__) | 
 
 
 
 
 
 | 56 | 
 #  ifndef HAVE_VSNPRINTF | 
 
 
 
 
 
 | 57 | 
 #    define HAVE_VSNPRINTF | 
 
 
 
 
 
 | 58 | 
 #  endif | 
 
 
 
 
 
 | 59 | 
 #endif | 
 
 
 
 
 
 | 60 | 
  | 
 
 
 
 
 
 | 61 | 
 #if defined(MSDOS) && defined(__BORLANDC__) && (BORLANDC > 0x410) | 
 
 
 
 
 
 | 62 | 
 #  ifndef HAVE_VSNPRINTF | 
 
 
 
 
 
 | 63 | 
 #    define HAVE_VSNPRINTF | 
 
 
 
 
 
 | 64 | 
 #  endif | 
 
 
 
 
 
 | 65 | 
 #endif | 
 
 
 
 
 
 | 66 | 
  | 
 
 
 
 
 
 | 67 | 
 #ifndef HAVE_VSNPRINTF | 
 
 
 
 
 
 | 68 | 
 #  ifdef MSDOS | 
 
 
 
 
 
 | 69 | 
 /* vsnprintf may exist on some MS-DOS compilers (DJGPP?), | 
 
 
 
 
 
 | 70 | 
    but for now we just assume it doesn't. */ | 
 
 
 
 
 
 | 71 | 
 #    define NO_vsnprintf | 
 
 
 
 
 
 | 72 | 
 #  endif | 
 
 
 
 
 
 | 73 | 
 #  ifdef __TURBOC__ | 
 
 
 
 
 
 | 74 | 
 #    define NO_vsnprintf | 
 
 
 
 
 
 | 75 | 
 #  endif | 
 
 
 
 
 
 | 76 | 
 #  ifdef WIN32 | 
 
 
 
 
 
 | 77 | 
 /* In Win32, vsnprintf is available as the "non-ANSI" _vsnprintf. */ | 
 
 
 
 
 
 | 78 | 
 #    if !defined(vsnprintf) && !defined(NO_vsnprintf) | 
 
 
 
 
 
 | 79 | 
 #      if !defined(_MSC_VER) || ( defined(_MSC_VER) && _MSC_VER < 1500 ) | 
 
 
 
 
 
 | 80 | 
 #         define vsnprintf _vsnprintf | 
 
 
 
 
 
 | 81 | 
 #      endif | 
 
 
 
 
 
 | 82 | 
 #    endif | 
 
 
 
 
 
 | 83 | 
 #  endif | 
 
 
 
 
 
 | 84 | 
 #  ifdef __SASC | 
 
 
 
 
 
 | 85 | 
 #    define NO_vsnprintf | 
 
 
 
 
 
 | 86 | 
 #  endif | 
 
 
 
 
 
 | 87 | 
 #  ifdef VMS | 
 
 
 
 
 
 | 88 | 
 #    define NO_vsnprintf | 
 
 
 
 
 
 | 89 | 
 #  endif | 
 
 
 
 
 
 | 90 | 
 #  ifdef __OS400__ | 
 
 
 
 
 
 | 91 | 
 #    define NO_vsnprintf | 
 
 
 
 
 
 | 92 | 
 #  endif | 
 
 
 
 
 
 | 93 | 
 #  ifdef __MVS__ | 
 
 
 
 
 
 | 94 | 
 #    define NO_vsnprintf | 
 
 
 
 
 
 | 95 | 
 #  endif | 
 
 
 
 
 
 | 96 | 
 #endif | 
 
 
 
 
 
 | 97 | 
  | 
 
 
 
 
 
 | 98 | 
 /* unlike snprintf (which is required in C99, yet still not supported by | 
 
 
 
 
 
 | 99 | 
    Microsoft more than a decade later!), _snprintf does not guarantee null | 
 
 
 
 
 
 | 100 | 
    termination of the result -- however this is only used in gzlib.c where | 
 
 
 
 
 
 | 101 | 
    the result is assured to fit in the space provided */ | 
 
 
 
 
 
 | 102 | 
 #ifdef _MSC_VER | 
 
 
 
 
 
 | 103 | 
 #  define snprintf _snprintf | 
 
 
 
 
 
 | 104 | 
 #endif | 
 
 
 
 
 
 | 105 | 
  | 
 
 
 
 
 
 | 106 | 
 #ifndef local | 
 
 
 
 
 
 | 107 | 
 #  define local static | 
 
 
 
 
 
 | 108 | 
 #endif | 
 
 
 
 
 
 | 109 | 
 /* compile with -Dlocal if your debugger can't find static symbols */ | 
 
 
 
 
 
 | 110 | 
  | 
 
 
 
 
 
 | 111 | 
 /* gz* functions always use library allocation functions */ | 
 
 
 
 
 
 | 112 | 
 #ifndef STDC | 
 
 
 
 
 
 | 113 | 
   extern voidp  malloc OF((uInt size)); | 
 
 
 
 
 
 | 114 | 
   extern void   free   OF((voidpf ptr)); | 
 
 
 
 
 
 | 115 | 
 #endif | 
 
 
 
 
 
 | 116 | 
  | 
 
 
 
 
 
 | 117 | 
 /* get errno and strerror definition */ | 
 
 
 
 
 
 | 118 | 
 #if defined UNDER_CE | 
 
 
 
 
 
 | 119 | 
 #  include <windows.h> | 
 
 
 
 
 
 | 120 | 
 #  define zstrerror() gz_strwinerror((DWORD)GetLastError()) | 
 
 
 
 
 
 | 121 | 
 #else | 
 
 
 
 
 
 | 122 | 
 #  ifndef NO_STRERROR | 
 
 
 
 
 
 | 123 | 
 #    include <errno.h> | 
 
 
 
 
 
 | 124 | 
 #    define zstrerror() strerror(errno) | 
 
 
 
 
 
 | 125 | 
 #  else | 
 
 
 
 
 
 | 126 | 
 #    define zstrerror() "stdio error (consult errno)" | 
 
 
 
 
 
 | 127 | 
 #  endif | 
 
 
 
 
 
 | 128 | 
 #endif | 
 
 
 
 
 
 | 129 | 
  | 
 
 
 
 
 
 | 130 | 
 /* provide prototypes for these when building zlib without LFS */ | 
 
 
 
 
 
 | 131 | 
 #if !defined(_LARGEFILE64_SOURCE) || _LFS64_LARGEFILE-0 == 0 | 
 
 
 
 
 
 | 132 | 
     ZEXTERN gzFile ZEXPORT gzopen64 OF((const char *, const char *)); | 
 
 
 
 
 
 | 133 | 
     ZEXTERN z_off64_t ZEXPORT gzseek64 OF((gzFile, z_off64_t, int)); | 
 
 
 
 
 
 | 134 | 
     ZEXTERN z_off64_t ZEXPORT gztell64 OF((gzFile)); | 
 
 
 
 
 
 | 135 | 
     ZEXTERN z_off64_t ZEXPORT gzoffset64 OF((gzFile)); | 
 
 
 
 
 
 | 136 | 
 #endif | 
 
 
 
 
 
 | 137 | 
  | 
 
 
 
 
 
 | 138 | 
 /* default memLevel */ | 
 
 
 
 
 
 | 139 | 
 #if MAX_MEM_LEVEL >= 8 | 
 
 
 
 
 
 | 140 | 
 #  define DEF_MEM_LEVEL 8 | 
 
 
 
 
 
 | 141 | 
 #else | 
 
 
 
 
 
 | 142 | 
 #  define DEF_MEM_LEVEL  MAX_MEM_LEVEL | 
 
 
 
 
 
 | 143 | 
 #endif | 
 
 
 
 
 
 | 144 | 
  | 
 
 
 
 
 
 | 145 | 
 /* default i/o buffer size -- double this for output when reading (this and | 
 
 
 
 
 
 | 146 | 
    twice this must be able to fit in an unsigned type) */ | 
 
 
 
 
 
 | 147 | 
 #define GZBUFSIZE 8192 | 
 
 
 
 
 
 | 148 | 
  | 
 
 
 
 
 
 | 149 | 
 /* gzip modes, also provide a little integrity check on the passed structure */ | 
 
 
 
 
 
 | 150 | 
 #define GZ_NONE 0 | 
 
 
 
 
 
 | 151 | 
 #define GZ_READ 7247 | 
 
 
 
 
 
 | 152 | 
 #define GZ_WRITE 31153 | 
 
 
 
 
 
 | 153 | 
 #define GZ_APPEND 1     /* mode set to GZ_WRITE after the file is opened */ | 
 
 
 
 
 
 | 154 | 
  | 
 
 
 
 
 
 | 155 | 
 /* values for gz_state how */ | 
 
 
 
 
 
 | 156 | 
 #define LOOK 0      /* look for a gzip header */ | 
 
 
 
 
 
 | 157 | 
 #define COPY 1      /* copy input directly */ | 
 
 
 
 
 
 | 158 | 
 #define GZIP 2      /* decompress a gzip stream */ | 
 
 
 
 
 
 | 159 | 
  | 
 
 
 
 
 
 | 160 | 
 /* internal gzip file state data structure */ | 
 
 
 
 
 
 | 161 | 
 typedef struct { | 
 
 
 
 
 
 | 162 | 
         /* exposed contents for gzgetc() macro */ | 
 
 
 
 
 
 | 163 | 
     struct gzFile_s x;      /* "x" for exposed */ | 
 
 
 
 
 
 | 164 | 
                             /* x.have: number of bytes available at x.next */ | 
 
 
 
 
 
 | 165 | 
                             /* x.next: next output data to deliver or write */ | 
 
 
 
 
 
 | 166 | 
                             /* x.pos: current position in uncompressed data */ | 
 
 
 
 
 
 | 167 | 
         /* used for both reading and writing */ | 
 
 
 
 
 
 | 168 | 
     int mode;               /* see gzip modes above */ | 
 
 
 
 
 
 | 169 | 
     int fd;                 /* file descriptor */ | 
 
 
 
 
 
 | 170 | 
     char *path;             /* path or fd for error messages */ | 
 
 
 
 
 
 | 171 | 
     unsigned size;          /* buffer size, zero if not allocated yet */ | 
 
 
 
 
 
 | 172 | 
     unsigned want;          /* requested buffer size, default is GZBUFSIZE */ | 
 
 
 
 
 
 | 173 | 
     unsigned char *in;      /* input buffer */ | 
 
 
 
 
 
 | 174 | 
     unsigned char *out;     /* output buffer (double-sized when reading) */ | 
 
 
 
 
 
 | 175 | 
     int direct;             /* 0 if processing gzip, 1 if transparent */ | 
 
 
 
 
 
 | 176 | 
         /* just for reading */ | 
 
 
 
 
 
 | 177 | 
     int how;                /* 0: get header, 1: copy, 2: decompress */ | 
 
 
 
 
 
 | 178 | 
     z_off64_t start;        /* where the gzip data started, for rewinding */ | 
 
 
 
 
 
 | 179 | 
     int eof;                /* true if end of input file reached */ | 
 
 
 
 
 
 | 180 | 
     int past;               /* true if read requested past end */ | 
 
 
 
 
 
 | 181 | 
         /* just for writing */ | 
 
 
 
 
 
 | 182 | 
     int level;              /* compression level */ | 
 
 
 
 
 
 | 183 | 
     int strategy;           /* compression strategy */ | 
 
 
 
 
 
 | 184 | 
         /* seek request */ | 
 
 
 
 
 
 | 185 | 
     z_off64_t skip;         /* amount to skip (already rewound if backwards) */ | 
 
 
 
 
 
 | 186 | 
     int seek;               /* true if seek request pending */ | 
 
 
 
 
 
 | 187 | 
         /* error information */ | 
 
 
 
 
 
 | 188 | 
     int err;                /* error code */ | 
 
 
 
 
 
 | 189 | 
     char *msg;              /* error message */ | 
 
 
 
 
 
 | 190 | 
         /* zlib inflate or deflate stream */ | 
 
 
 
 
 
 | 191 | 
     z_stream strm;          /* stream structure in-place (not a pointer) */ | 
 
 
 
 
 
 | 192 | 
 } gz_state; | 
 
 
 
 
 
 | 193 | 
 typedef gz_state FAR *gz_statep; | 
 
 
 
 
 
 | 194 | 
  | 
 
 
 
 
 
 | 195 | 
 /* shared functions */ | 
 
 
 
 
 
 | 196 | 
 void ZLIB_INTERNAL gz_error OF((gz_statep, int, const char *)); | 
 
 
 
 
 
 | 197 | 
 #if defined UNDER_CE | 
 
 
 
 
 
 | 198 | 
 char ZLIB_INTERNAL *gz_strwinerror OF((DWORD error)); | 
 
 
 
 
 
 | 199 | 
 #endif | 
 
 
 
 
 
 | 200 | 
  | 
 
 
 
 
 
 | 201 | 
 /* GT_OFF(x), where x is an unsigned value, is true if x > maximum z_off64_t | 
 
 
 
 
 
 | 202 | 
    value -- needed when comparing unsigned to z_off64_t, which is signed | 
 
 
 
 
 
 | 203 | 
    (possible z_off64_t types off_t, off64_t, and long are all signed) */ | 
 
 
 
 
 
 | 204 | 
 #ifdef INT_MAX | 
 
 
 
 
 
 | 205 | 
 #  define GT_OFF(x) (sizeof(int) == sizeof(z_off64_t) && (x) > INT_MAX) | 
 
 
 
 
 
 | 206 | 
 #else | 
 
 
 
 
 
 | 207 | 
 unsigned ZLIB_INTERNAL gz_intmax OF((void)); | 
 
 
 
 
 
 | 208 | 
 #  define GT_OFF(x) (sizeof(int) == sizeof(z_off64_t) && (x) > gz_intmax()) | 
 
 
 
 
 
 | 209 | 
 #endif |