Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
stenzek
GitHub Repository: stenzek/duckstation
Path: blob/master/dep/minizip/include/zip.h
4253 views
1
/* zip.h -- IO on .zip files using zlib
2
Version 1.1, February 14h, 2010
3
part of the MiniZip project - ( http://www.winimage.com/zLibDll/minizip.html )
4
5
Copyright (C) 1998-2010 Gilles Vollant (minizip) ( http://www.winimage.com/zLibDll/minizip.html )
6
7
Modifications for Zip64 support
8
Copyright (C) 2009-2010 Mathias Svensson ( http://result42.com )
9
10
For more info read MiniZip_info.txt
11
12
---------------------------------------------------------------------------
13
14
Condition of use and distribution are the same than zlib :
15
16
This software is provided 'as-is', without any express or implied
17
warranty. In no event will the authors be held liable for any damages
18
arising from the use of this software.
19
20
Permission is granted to anyone to use this software for any purpose,
21
including commercial applications, and to alter it and redistribute it
22
freely, subject to the following restrictions:
23
24
1. The origin of this software must not be misrepresented; you must not
25
claim that you wrote the original software. If you use this software
26
in a product, an acknowledgment in the product documentation would be
27
appreciated but is not required.
28
2. Altered source versions must be plainly marked as such, and must not be
29
misrepresented as being the original software.
30
3. This notice may not be removed or altered from any source distribution.
31
32
---------------------------------------------------------------------------
33
34
Changes
35
36
See header of zip.h
37
38
*/
39
40
#ifndef _zip12_H
41
#define _zip12_H
42
43
#ifdef __cplusplus
44
extern "C" {
45
#endif
46
47
//#define HAVE_BZIP2
48
49
#ifndef _ZLIB_H
50
#include "zlib.h"
51
#endif
52
53
#ifndef _ZLIBIOAPI_H
54
#include "ioapi.h"
55
#endif
56
57
#ifdef HAVE_BZIP2
58
#include "bzlib.h"
59
#endif
60
61
#define Z_BZIP2ED 12
62
63
#if defined(STRICTZIP) || defined(STRICTZIPUNZIP)
64
/* like the STRICT of WIN32, we define a pointer that cannot be converted
65
from (void*) without cast */
66
typedef struct TagzipFile__ { int unused; } zipFile__;
67
typedef zipFile__ *zipFile;
68
#else
69
typedef voidp zipFile;
70
#endif
71
72
#define ZIP_OK (0)
73
#define ZIP_EOF (0)
74
#define ZIP_ERRNO (Z_ERRNO)
75
#define ZIP_PARAMERROR (-102)
76
#define ZIP_BADZIPFILE (-103)
77
#define ZIP_INTERNALERROR (-104)
78
79
#ifndef DEF_MEM_LEVEL
80
# if MAX_MEM_LEVEL >= 8
81
# define DEF_MEM_LEVEL 8
82
# else
83
# define DEF_MEM_LEVEL MAX_MEM_LEVEL
84
# endif
85
#endif
86
/* default memLevel */
87
88
/* tm_zip contain date/time info */
89
typedef struct tm_zip_s
90
{
91
uInt tm_sec; /* seconds after the minute - [0,59] */
92
uInt tm_min; /* minutes after the hour - [0,59] */
93
uInt tm_hour; /* hours since midnight - [0,23] */
94
uInt tm_mday; /* day of the month - [1,31] */
95
uInt tm_mon; /* months since January - [0,11] */
96
uInt tm_year; /* years - [1980..2044] */
97
} tm_zip;
98
99
typedef struct
100
{
101
tm_zip tmz_date; /* date in understandable format */
102
uLong dosDate; /* if dos_date == 0, tmu_date is used */
103
/* uLong flag; */ /* general purpose bit flag 2 bytes */
104
105
uLong internal_fa; /* internal file attributes 2 bytes */
106
uLong external_fa; /* external file attributes 4 bytes */
107
} zip_fileinfo;
108
109
typedef const char* zipcharpc;
110
111
112
#define APPEND_STATUS_CREATE (0)
113
#define APPEND_STATUS_CREATEAFTER (1)
114
#define APPEND_STATUS_ADDINZIP (2)
115
116
extern zipFile ZEXPORT zipOpen OF((const char *pathname, int append));
117
extern zipFile ZEXPORT zipOpen64 OF((const void *pathname, int append));
118
/*
119
Create a zipfile.
120
pathname contain on Windows XP a filename like "c:\\zlib\\zlib113.zip" or on
121
an Unix computer "zlib/zlib113.zip".
122
if the file pathname exist and append==APPEND_STATUS_CREATEAFTER, the zip
123
will be created at the end of the file.
124
(useful if the file contain a self extractor code)
125
if the file pathname exist and append==APPEND_STATUS_ADDINZIP, we will
126
add files in existing zip (be sure you don't add file that doesn't exist)
127
If the zipfile cannot be opened, the return value is NULL.
128
Else, the return value is a zipFile Handle, usable with other function
129
of this zip package.
130
*/
131
132
/* Note : there is no delete function into a zipfile.
133
If you want delete file into a zipfile, you must open a zipfile, and create another
134
Of couse, you can use RAW reading and writing to copy the file you did not want delte
135
*/
136
137
extern zipFile ZEXPORT zipOpen2 OF((const char *pathname,
138
int append,
139
zipcharpc* globalcomment,
140
zlib_filefunc_def* pzlib_filefunc_def));
141
142
extern zipFile ZEXPORT zipOpen2_64 OF((const void *pathname,
143
int append,
144
zipcharpc* globalcomment,
145
zlib_filefunc64_def* pzlib_filefunc_def));
146
147
extern int ZEXPORT zipOpenNewFileInZip OF((zipFile file,
148
const char* filename,
149
const zip_fileinfo* zipfi,
150
const void* extrafield_local,
151
uInt size_extrafield_local,
152
const void* extrafield_global,
153
uInt size_extrafield_global,
154
const char* comment,
155
int method,
156
int level));
157
158
extern int ZEXPORT zipOpenNewFileInZip64 OF((zipFile file,
159
const char* filename,
160
const zip_fileinfo* zipfi,
161
const void* extrafield_local,
162
uInt size_extrafield_local,
163
const void* extrafield_global,
164
uInt size_extrafield_global,
165
const char* comment,
166
int method,
167
int level,
168
int zip64));
169
170
/*
171
Open a file in the ZIP for writing.
172
filename : the filename in zip (if NULL, '-' without quote will be used
173
*zipfi contain supplemental information
174
if extrafield_local!=NULL and size_extrafield_local>0, extrafield_local
175
contains the extrafield data the the local header
176
if extrafield_global!=NULL and size_extrafield_global>0, extrafield_global
177
contains the extrafield data the the local header
178
if comment != NULL, comment contain the comment string
179
method contain the compression method (0 for store, Z_DEFLATED for deflate)
180
level contain the level of compression (can be Z_DEFAULT_COMPRESSION)
181
zip64 is set to 1 if a zip64 extended information block should be added to the local file header.
182
this MUST be '1' if the uncompressed size is >= 0xffffffff.
183
184
*/
185
186
187
extern int ZEXPORT zipOpenNewFileInZip2 OF((zipFile file,
188
const char* filename,
189
const zip_fileinfo* zipfi,
190
const void* extrafield_local,
191
uInt size_extrafield_local,
192
const void* extrafield_global,
193
uInt size_extrafield_global,
194
const char* comment,
195
int method,
196
int level,
197
int raw));
198
199
200
extern int ZEXPORT zipOpenNewFileInZip2_64 OF((zipFile file,
201
const char* filename,
202
const zip_fileinfo* zipfi,
203
const void* extrafield_local,
204
uInt size_extrafield_local,
205
const void* extrafield_global,
206
uInt size_extrafield_global,
207
const char* comment,
208
int method,
209
int level,
210
int raw,
211
int zip64));
212
/*
213
Same than zipOpenNewFileInZip, except if raw=1, we write raw file
214
*/
215
216
extern int ZEXPORT zipOpenNewFileInZip3 OF((zipFile file,
217
const char* filename,
218
const zip_fileinfo* zipfi,
219
const void* extrafield_local,
220
uInt size_extrafield_local,
221
const void* extrafield_global,
222
uInt size_extrafield_global,
223
const char* comment,
224
int method,
225
int level,
226
int raw,
227
int windowBits,
228
int memLevel,
229
int strategy,
230
const char* password,
231
uLong crcForCrypting));
232
233
extern int ZEXPORT zipOpenNewFileInZip3_64 OF((zipFile file,
234
const char* filename,
235
const zip_fileinfo* zipfi,
236
const void* extrafield_local,
237
uInt size_extrafield_local,
238
const void* extrafield_global,
239
uInt size_extrafield_global,
240
const char* comment,
241
int method,
242
int level,
243
int raw,
244
int windowBits,
245
int memLevel,
246
int strategy,
247
const char* password,
248
uLong crcForCrypting,
249
int zip64
250
));
251
252
/*
253
Same than zipOpenNewFileInZip2, except
254
windowBits,memLevel,,strategy : see parameter strategy in deflateInit2
255
password : crypting password (NULL for no crypting)
256
crcForCrypting : crc of file to compress (needed for crypting)
257
*/
258
259
extern int ZEXPORT zipOpenNewFileInZip4 OF((zipFile file,
260
const char* filename,
261
const zip_fileinfo* zipfi,
262
const void* extrafield_local,
263
uInt size_extrafield_local,
264
const void* extrafield_global,
265
uInt size_extrafield_global,
266
const char* comment,
267
int method,
268
int level,
269
int raw,
270
int windowBits,
271
int memLevel,
272
int strategy,
273
const char* password,
274
uLong crcForCrypting,
275
uLong versionMadeBy,
276
uLong flagBase
277
));
278
279
280
extern int ZEXPORT zipOpenNewFileInZip4_64 OF((zipFile file,
281
const char* filename,
282
const zip_fileinfo* zipfi,
283
const void* extrafield_local,
284
uInt size_extrafield_local,
285
const void* extrafield_global,
286
uInt size_extrafield_global,
287
const char* comment,
288
int method,
289
int level,
290
int raw,
291
int windowBits,
292
int memLevel,
293
int strategy,
294
const char* password,
295
uLong crcForCrypting,
296
uLong versionMadeBy,
297
uLong flagBase,
298
int zip64
299
));
300
/*
301
Same than zipOpenNewFileInZip4, except
302
versionMadeBy : value for Version made by field
303
flag : value for flag field (compression level info will be added)
304
*/
305
306
307
extern int ZEXPORT zipWriteInFileInZip OF((zipFile file,
308
const void* buf,
309
unsigned len));
310
/*
311
Write data in the zipfile
312
*/
313
314
extern int ZEXPORT zipCloseFileInZip OF((zipFile file));
315
/*
316
Close the current file in the zipfile
317
*/
318
319
extern int ZEXPORT zipCloseFileInZipRaw OF((zipFile file,
320
uLong uncompressed_size,
321
uLong crc32));
322
323
extern int ZEXPORT zipCloseFileInZipRaw64 OF((zipFile file,
324
ZPOS64_T uncompressed_size,
325
uLong crc32));
326
327
/*
328
Close the current file in the zipfile, for file opened with
329
parameter raw=1 in zipOpenNewFileInZip2
330
uncompressed_size and crc32 are value for the uncompressed size
331
*/
332
333
extern int ZEXPORT zipClose OF((zipFile file,
334
const char* global_comment));
335
/*
336
Close the zipfile
337
*/
338
339
340
extern int ZEXPORT zipRemoveExtraInfoBlock OF((char* pData, int* dataLen, short sHeader));
341
/*
342
zipRemoveExtraInfoBlock - Added by Mathias Svensson
343
344
Remove extra information block from a extra information data for the local file header or central directory header
345
346
It is needed to remove ZIP64 extra information blocks when before data is written if using RAW mode.
347
348
0x0001 is the signature header for the ZIP64 extra information blocks
349
350
usage.
351
Remove ZIP64 Extra information from a central director extra field data
352
zipRemoveExtraInfoBlock(pCenDirExtraFieldData, &nCenDirExtraFieldDataLen, 0x0001);
353
354
Remove ZIP64 Extra information from a Local File Header extra field data
355
zipRemoveExtraInfoBlock(pLocalHeaderExtraFieldData, &nLocalHeaderExtraFieldDataLen, 0x0001);
356
*/
357
358
#ifdef __cplusplus
359
}
360
#endif
361
362
#endif /* _zip64_H */
363
364