|
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 |