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 |