ZLIB
Loading...
Searching...
No Matches
gzguts.h
Go to the documentation of this file.
1
8#ifdef _LARGEFILE64_SOURCE
9# ifndef _LARGEFILE_SOURCE
10# define _LARGEFILE_SOURCE 1
11# endif
12# undef _FILE_OFFSET_BITS
13# undef _TIME_BITS
14#endif
15
16#ifdef HAVE_HIDDEN
17# define ZLIB_INTERNAL __attribute__((visibility ("hidden")))
18#else
19# define ZLIB_INTERNAL
20#endif
21
22#include <stdio.h>
23#include <zlib/zlib.h>
24#ifdef STDC
25# include <string.h>
26# include <stdlib.h>
27# include <limits.h>
28#endif
29
30#ifndef _POSIX_SOURCE
31# define _POSIX_SOURCE
32#endif
33#include <fcntl.h>
34
35#ifdef _WIN32
36# include <stddef.h>
37#endif
38
39#if defined(__TURBOC__) || defined(_MSC_VER) || defined(_WIN32)
40# include <io.h>
41#endif
42
43#if defined(_WIN32)
44# define WIDECHAR
45#endif
46
47#ifdef WINAPI_FAMILY
48# define open _open
49# define read _read
50# define write _write
51# define close _close
52#endif
53
54#ifdef NO_DEFLATE /* for compatibility with old definition */
55# define NO_GZCOMPRESS
56#endif
57
58#if defined(STDC99) || (defined(__TURBOC__) && __TURBOC__ >= 0x550)
59# ifndef HAVE_VSNPRINTF
60# define HAVE_VSNPRINTF
61# endif
62#endif
63
64#if defined(__CYGWIN__)
65# ifndef HAVE_VSNPRINTF
66# define HAVE_VSNPRINTF
67# endif
68#endif
69
70#if defined(MSDOS) && defined(__BORLANDC__) && (BORLANDC > 0x410)
71# ifndef HAVE_VSNPRINTF
72# define HAVE_VSNPRINTF
73# endif
74#endif
75
76#ifndef HAVE_VSNPRINTF
77# ifdef MSDOS
78/* vsnprintf may exist on some MS-DOS compilers (DJGPP?),
79 but for now we just assume it doesn't. */
80# define NO_vsnprintf
81# endif
82# ifdef __TURBOC__
83# define NO_vsnprintf
84# endif
85# ifdef WIN32
86/* In Win32, vsnprintf is available as the "non-ANSI" _vsnprintf. */
87# if !defined(vsnprintf) && !defined(NO_vsnprintf)
88# if !defined(_MSC_VER) || ( defined(_MSC_VER) && _MSC_VER < 1500 )
89# define vsnprintf _vsnprintf
90# endif
91# endif
92# endif
93# ifdef __SASC
94# define NO_vsnprintf
95# endif
96# ifdef VMS
97# define NO_vsnprintf
98# endif
99# ifdef __OS400__
100# define NO_vsnprintf
101# endif
102# ifdef __MVS__
103# define NO_vsnprintf
104# endif
105#endif
106
107/* unlike snprintf (which is required in C99), _snprintf does not guarantee
108 null termination of the result -- however this is only used in gzlib.c where
109 the result is assured to fit in the space provided */
110#if defined(_MSC_VER) && _MSC_VER < 1900
111# define snprintf _snprintf
112#endif
113
114#ifndef local
115# define local static
116#endif
117/* since "static" is used to mean two completely different things in C, we
118 define "local" for the non-static meaning of "static", for readability
119 (compile with -Dlocal if your debugger can't find static symbols) */
120
121/* gz* functions always use library allocation functions */
122#ifndef STDC
123 extern voidp malloc(uInt size);
124 extern void free(voidpf ptr);
125#endif
126
127/* get errno and strerror definition */
128#if defined UNDER_CE
129# include <windows.h>
130# define zstrerror() gz_strwinerror((DWORD)GetLastError())
131#else
132# ifndef NO_STRERROR
133# include <errno.h>
134# define zstrerror() strerror(errno)
135# else
136# define zstrerror() "stdio error (consult errno)"
137# endif
138#endif
139
140/* provide prototypes for these when building zlib without LFS */
141#if !defined(_LARGEFILE64_SOURCE) || _LFS64_LARGEFILE-0 == 0
142 ZEXTERN gzFile ZEXPORT gzopen64 (const char *, const char *);
143 ZEXTERN z_off64_t ZEXPORT gzseek64 (gzFile, z_off64_t, int);
144 ZEXTERN z_off64_t ZEXPORT gztell64 (gzFile);
145 ZEXTERN z_off64_t ZEXPORT gzoffset64 (gzFile);
146#endif
147
148/* default memLevel */
149#if MAX_MEM_LEVEL >= 8
150# define DEF_MEM_LEVEL 8
151#else
152# define DEF_MEM_LEVEL MAX_MEM_LEVEL
153#endif
154
155/* default i/o buffer size -- double this for output when reading (this and
156 twice this must be able to fit in an unsigned type) */
157#define GZBUFSIZE 8192
158
159/* gzip modes, also provide a little integrity check on the passed structure */
160#define GZ_NONE 0
161#define GZ_READ 7247
162#define GZ_WRITE 31153
163#define GZ_APPEND 1 /* mode set to GZ_WRITE after the file is opened */
164
165/* values for gz_state how */
166#define LOOK 0 /* look for a gzip header */
167#define COPY 1 /* copy input directly */
168#define GZIP 2 /* decompress a gzip stream */
169
171typedef struct {
177 struct gzFile_s x;
178
181 int mode;
182 int fd;
183 char *path;
184 unsigned size;
185 unsigned want;
186 unsigned char *in;
187 unsigned char *out;
188 int direct;
191 int how;
192 z_off64_t start;
193 int eof;
194 int past;
197 int level;
199 int reset;
202 z_off64_t skip;
203 int seek;
206 int err;
207 char *msg;
209 z_stream strm; /* stream structure in-place (not a pointer) */
210} gz_state;
211typedef gz_state FAR *gz_statep;
212
213/* shared functions */
214void ZLIB_INTERNAL gz_error (gz_statep, int, const char *);
215#if defined UNDER_CE
216char ZLIB_INTERNAL *gz_strwinerror (DWORD error);
217#endif
218
219/* GT_OFF(x), where x is an unsigned value, is true if x > maximum z_off64_t
220 value -- needed when comparing unsigned to z_off64_t, which is signed
221 (possible z_off64_t types off_t, off64_t, and long are all signed) */
222#ifdef INT_MAX
223# define GT_OFF(x) (sizeof(int) == sizeof(z_off64_t) && (x) > INT_MAX)
224#else
225unsigned ZLIB_INTERNAL gz_intmax(void);
226# define GT_OFF(x) (sizeof(int) == sizeof(z_off64_t) && (x) > gz_intmax())
227#endif
ZEXTERN z_off64_t ZEXPORT gztell64(gzFile)
Return the starting position for the next gzread or gzwrite on file.
Definition gzlib.c:550
void ZLIB_INTERNAL gz_error(gz_statep, int, const char *)
Create an error message in allocated memory and set state->err and state->msg accordingly.
Definition gzlib.c:721
ZEXTERN z_off64_t ZEXPORT gzoffset64(gzFile)
Return the current compressed (actual) read or write offset of file.
Definition gzlib.c:589
ZEXTERN z_off64_t ZEXPORT gzseek64(gzFile, z_off64_t, int)
Set the starting position to offset relative to whence for the next gzread or gzwrite on file.
Definition gzlib.c:445
internal gzip file state data structure
Definition gzguts.h:171
z_off64_t start
where the gzip data started, for rewinding
Definition gzguts.h:192
int strategy
compression strategy
Definition gzguts.h:198
unsigned size
buffer size, zero if not allocated yet
Definition gzguts.h:184
z_off64_t skip
seek request
Definition gzguts.h:202
int fd
file descriptor
Definition gzguts.h:182
z_stream strm
zlib inflate or deflate stream
Definition gzguts.h:209
int err
error code
Definition gzguts.h:206
int mode
see gzip modes above
Definition gzguts.h:181
int level
compression level
Definition gzguts.h:197
unsigned want
requested buffer size, default is GZBUFSIZE
Definition gzguts.h:185
int how
0: get header, 1: copy, 2: decompress
Definition gzguts.h:191
char * path
path or fd for error messages
Definition gzguts.h:183
unsigned char * out
output buffer (double-sized when reading)
Definition gzguts.h:187
int eof
true if end of input file reached
Definition gzguts.h:193
unsigned char * in
input buffer (double-sized when writing)
Definition gzguts.h:186
Semi-opaque gzip file descriptor structure.
Definition zlib.h:403
Compressed stream state information.
Definition zlib.h:136
interface of the `zlib`