GDAL
cpl_minizip_zip.h
1/******************************************************************************
2 * $Id$
3 *
4 * Project: CPL - Common Portability Library
5 * Author: Frank Warmerdam, warmerdam@pobox.com
6 * Purpose: Adjusted minizip "zip.h" include file for zip services.
7 *
8 * Modified version by Even Rouault. :
9 * - Decoration of symbol names unz* -> cpl_unz*
10 * - Undef EXPORT so that we are sure the symbols are not exported
11 * - Remove old C style function prototypes
12 * - Added CPL* simplified API at bottom.
13 *
14 * Original licence available in port/LICENCE_minizip
15 *
16 *****************************************************************************/
17
18/* zip.h -- IO for compress .zip files using zlib
19 Version 1.01e, February 12th, 2005
20
21 Copyright (C) 1998-2005 Gilles Vollant
22
23 This unzip package allow creates .ZIP file, compatible with PKZip 2.04g
24 WinZip, InfoZip tools and compatible.
25 Multi volume ZipFile (span) are not supported.
26 Encryption compatible with pkzip 2.04g only supported
27 Old compressions used by old PKZip 1.x are not supported
28
29 For uncompress .zip file, look at unzip.h
30
31 I WAIT FEEDBACK at mail info@winimage.com
32 Visit also http://www.winimage.com/zLibDll/unzip.html for evolution
33
34 Condition of use and distribution are the same than zlib :
35
36 This software is provided 'as-is', without any express or implied
37 warranty. In no event will the authors be held liable for any damages
38 arising from the use of this software.
39
40 Permission is granted to anyone to use this software for any purpose,
41 including commercial applications, and to alter it and redistribute it
42 freely, subject to the following restrictions:
43
44 1. The origin of this software must not be misrepresented; you must not
45 claim that you wrote the original software. If you use this software
46 in a product, an acknowledgment in the product documentation would be
47 appreciated but is not required.
48 2. Altered source versions must be plainly marked as such, and must not be
49 misrepresented as being the original software.
50 3. This notice may not be removed or altered from any source distribution.
51*/
52
53/* for more info about .ZIP format, see
54 http://www.info-zip.org/pub/infozip/doc/appnote-981119-iz.zip
55 http://www.info-zip.org/pub/infozip/doc/
56 PkWare has also a specification at :
57 ftp://ftp.pkware.com/probdesc.zip
58*/
59
60#ifndef CPL_MINIZIP_ZIP_H_INCLUDED
61#define CPL_MINIZIP_ZIP_H_INCLUDED
62
63#ifndef DOXYGEN_SKIP
64
65#include "cpl_vsi.h"
66#define uLong64 vsi_l_offset
67typedef vsi_l_offset ZPOS64_T;
68
69#ifdef __cplusplus
70extern "C"
71{
72#endif
73
74#ifndef _ZLIB_H
75#include "cpl_zlib_header.h" // to avoid warnings when including zlib.h
76#endif
77
78#ifndef CPL_MINIZIP_IOAPI_H_INCLUDED
79#include "cpl_minizip_ioapi.h"
80#endif
81
82#include <stdbool.h>
83
84#define NOCRYPT
85#undef ZEXPORT
86#define ZEXPORT
87
88#if defined(STRICTZIP) || defined(STRICTZIPUNZIP)
89 /* like the STRICT of WIN32, we define a pointer that cannot be converted
90 from (void*) without cast */
91 typedef struct TagzipFile__
92 {
93 int unused;
94 } zipFile__;
95
96 typedef zipFile__ *zipFile;
97#else
98typedef voidp zipFile;
99#endif
100
101#define ZIP_OK (0)
102#define ZIP_EOF (0)
103#define ZIP_ERRNO (Z_ERRNO)
104#define ZIP_PARAMERROR (-102)
105#define ZIP_BADZIPFILE (-103)
106#define ZIP_INTERNALERROR (-104)
107
108#ifndef DEF_MEM_LEVEL
109#if MAX_MEM_LEVEL >= 8
110#define DEF_MEM_LEVEL 8
111#else
112#define DEF_MEM_LEVEL MAX_MEM_LEVEL
113#endif
114#endif
115 /* default memLevel */
116
117 /* tm_zip contain date/time info */
118 typedef struct tm_zip_s
119 {
120 uInt tm_sec; /* seconds after the minute - [0,59] */
121 uInt tm_min; /* minutes after the hour - [0,59] */
122 uInt tm_hour; /* hours since midnight - [0,23] */
123 uInt tm_mday; /* day of the month - [1,31] */
124 uInt tm_mon; /* months since January - [0,11] */
125 uInt tm_year; /* years - [1980..2044] */
126 } tm_zip;
127
128 typedef struct
129 {
130 tm_zip tmz_date; /* date in understandable format */
131 uLong dosDate; /* if dos_date == 0, tmu_date is used */
132 /* uLong flag; */ /* general purpose bit flag 2
133 bytes */
134
135 uLong internal_fa; /* internal file attributes 2 bytes */
136 uLong external_fa; /* external file attributes 4 bytes */
137 } zip_fileinfo;
138
139 typedef const char *zipcharpc;
140
141#define APPEND_STATUS_CREATE (0)
142#define APPEND_STATUS_CREATEAFTER (1)
143#define APPEND_STATUS_ADDINZIP (2)
144
145 extern zipFile ZEXPORT cpl_zipOpen(const char *pathname, int append);
146 /*
147 Create a zipfile.
148 pathname contain on Windows XP a filename like "c:\\zlib\\zlib113.zip"
149 or on an Unix computer "zlib/zlib113.zip". if the file pathname exist and
150 append==APPEND_STATUS_CREATEAFTER, the zip will be created at the end of
151 the file. (useful if the file contain a self extractor code) if the file
152 pathname exist and append==APPEND_STATUS_ADDINZIP, we will add files in
153 existing zip (be sure you don't add file that doesn't exist) If the
154 zipfile cannot be opened, the return value is NULL. Else, the return value
155 is a zipFile Handle, usable with other function of this zip package.
156 */
157
158 /* Note : there is no delete function for a zipfile.
159 If you want delete file in a zipfile, you must open a zipfile, and create
160 another. Of course, you can use RAW reading and writing to copy the file
161 you did not want delete.
162 */
163
164 extern zipFile ZEXPORT cpl_zipOpen2(const char *pathname, int append,
165 zipcharpc *globalcomment,
166 zlib_filefunc_def *pzlib_filefunc_def);
167
168 extern int ZEXPORT cpl_zipOpenNewFileInZip(
169 zipFile file, const char *filename, const zip_fileinfo *zipfi,
170 const void *extrafield_local, uInt size_extrafield_local,
171 const void *extrafield_global, uInt size_extrafield_global,
172 const char *comment, int method, int level);
173 /*
174 Open a file in the ZIP for writing.
175 filename : the filename in zip (if NULL, '-' without quote will be used
176 *zipfi contain supplemental information
177 if extrafield_local!=NULL and size_extrafield_local>0, extrafield_local
178 contains the extrafield data the local header
179 if extrafield_global!=NULL and size_extrafield_global>0, extrafield_global
180 contains the extrafield data the local header
181 if comment != NULL, comment contain the comment string
182 method contain the compression method (0 for store, Z_DEFLATED for
183 deflate) level contain the level of compression (can be
184 Z_DEFAULT_COMPRESSION)
185 */
186
187 extern int ZEXPORT cpl_zipOpenNewFileInZip2(
188 zipFile file, const char *filename, const zip_fileinfo *zipfi,
189 const void *extrafield_local, uInt size_extrafield_local,
190 const void *extrafield_global, uInt size_extrafield_global,
191 const char *comment, int method, int level, int raw);
192
193 /*
194 Same than zipOpenNewFileInZip, except if raw=1, we write raw file
195 */
196
197 extern int ZEXPORT cpl_zipOpenNewFileInZip3(
198 zipFile file, const char *filename, const zip_fileinfo *zipfi,
199 const void *extrafield_local, uInt size_extrafield_local,
200 const void *extrafield_global, uInt size_extrafield_global,
201 const char *comment, int method, int level, int raw, int windowBits,
202 int memLevel, int strategy, const char *password, uLong crcForCtypting,
203 bool bZip64, bool bIncludeInCentralDirectory);
204
205 /*
206 Same than zipOpenNewFileInZip2, except
207 windowBits,memLevel,,strategy : see parameter strategy in deflateInit2
208 password : crypting password (NULL for no crypting)
209 crcForCtypting : crc of file to compress (needed for crypting)
210 */
211
212 extern int ZEXPORT cpl_zipWriteInFileInZip(zipFile file, const void *buf,
213 unsigned len);
214 /*
215 Write data in the zipfile
216 */
217
218 extern int ZEXPORT cpl_zipCloseFileInZip(zipFile file);
219 /*
220 Close the current file in the zipfile
221 */
222
223 extern int ZEXPORT cpl_zipCloseFileInZipRaw(zipFile file,
224 ZPOS64_T uncompressed_size,
225 uLong crc32);
226 /*
227 Close the current file in the zipfile, for file opened with
228 parameter raw=1 in zipOpenNewFileInZip2
229 uncompressed_size and crc32 are value for the uncompressed size
230 */
231
232 extern int ZEXPORT cpl_zipClose(zipFile file, const char *global_comment);
233 /*
234 Close the zipfile
235 */
236
237#ifdef __cplusplus
238}
239#endif
240
241#endif /* #ifndef DOXYGEN_SKIP */
242
243#endif /* _zip_H */
Standard C Covers.
GUIntBig vsi_l_offset
Type for a file offset.
Definition: cpl_vsi.h:146