]>
Commit | Line | Data |
---|---|---|
c4ab09ef | 1 | /* 7zTypes.h -- Basic types\r |
5ec5a236 | 2 | 2017-07-17 : Igor Pavlov : Public domain */\r |
30fdf114 LG |
3 | \r |
4 | #ifndef __7Z_TYPES_H\r | |
5 | #define __7Z_TYPES_H\r | |
6 | \r | |
c4ab09ef LG |
7 | #ifdef _WIN32\r |
8 | /* #include <windows.h> */\r | |
9 | #endif\r | |
10 | \r | |
30fdf114 LG |
11 | #include <stddef.h>\r |
12 | \r | |
c4ab09ef LG |
13 | #ifndef EXTERN_C_BEGIN\r |
14 | #ifdef __cplusplus\r | |
15 | #define EXTERN_C_BEGIN extern "C" {\r | |
16 | #define EXTERN_C_END }\r | |
17 | #else\r | |
18 | #define EXTERN_C_BEGIN\r | |
19 | #define EXTERN_C_END\r | |
20 | #endif\r | |
30fdf114 LG |
21 | #endif\r |
22 | \r | |
c4ab09ef LG |
23 | EXTERN_C_BEGIN\r |
24 | \r | |
30fdf114 LG |
25 | #define SZ_OK 0\r |
26 | \r | |
27 | #define SZ_ERROR_DATA 1\r | |
28 | #define SZ_ERROR_MEM 2\r | |
29 | #define SZ_ERROR_CRC 3\r | |
30 | #define SZ_ERROR_UNSUPPORTED 4\r | |
31 | #define SZ_ERROR_PARAM 5\r | |
32 | #define SZ_ERROR_INPUT_EOF 6\r | |
33 | #define SZ_ERROR_OUTPUT_EOF 7\r | |
34 | #define SZ_ERROR_READ 8\r | |
35 | #define SZ_ERROR_WRITE 9\r | |
36 | #define SZ_ERROR_PROGRESS 10\r | |
37 | #define SZ_ERROR_FAIL 11\r | |
38 | #define SZ_ERROR_THREAD 12\r | |
39 | \r | |
40 | #define SZ_ERROR_ARCHIVE 16\r | |
41 | #define SZ_ERROR_NO_ARCHIVE 17\r | |
42 | \r | |
43 | typedef int SRes;\r | |
44 | \r | |
5ec5a236 | 45 | \r |
30fdf114 | 46 | #ifdef _WIN32\r |
5ec5a236 | 47 | \r |
c4ab09ef LG |
48 | /* typedef DWORD WRes; */\r |
49 | typedef unsigned WRes;\r | |
5ec5a236 LG |
50 | #define MY_SRes_HRESULT_FROM_WRes(x) HRESULT_FROM_WIN32(x)\r |
51 | \r | |
30fdf114 | 52 | #else\r |
5ec5a236 | 53 | \r |
30fdf114 | 54 | typedef int WRes;\r |
5ec5a236 LG |
55 | #define MY__FACILITY_WIN32 7\r |
56 | #define MY__FACILITY__WRes MY__FACILITY_WIN32\r | |
57 | #define MY_SRes_HRESULT_FROM_WRes(x) ((HRESULT)(x) <= 0 ? ((HRESULT)(x)) : ((HRESULT) (((x) & 0x0000FFFF) | (MY__FACILITY__WRes << 16) | 0x80000000)))\r | |
58 | \r | |
30fdf114 LG |
59 | #endif\r |
60 | \r | |
5ec5a236 | 61 | \r |
30fdf114 LG |
62 | #ifndef RINOK\r |
63 | #define RINOK(x) { int __result__ = (x); if (__result__ != 0) return __result__; }\r | |
64 | #endif\r | |
65 | \r | |
66 | typedef unsigned char Byte;\r | |
67 | typedef short Int16;\r | |
68 | typedef unsigned short UInt16;\r | |
69 | \r | |
70 | #ifdef _LZMA_UINT32_IS_ULONG\r | |
71 | typedef long Int32;\r | |
72 | typedef unsigned long UInt32;\r | |
73 | #else\r | |
74 | typedef int Int32;\r | |
75 | typedef unsigned int UInt32;\r | |
76 | #endif\r | |
77 | \r | |
78 | #ifdef _SZ_NO_INT_64\r | |
79 | \r | |
80 | /* define _SZ_NO_INT_64, if your compiler doesn't support 64-bit integers.\r | |
81 | NOTES: Some code will work incorrectly in that case! */\r | |
82 | \r | |
83 | typedef long Int64;\r | |
84 | typedef unsigned long UInt64;\r | |
85 | \r | |
86 | #else\r | |
87 | \r | |
88 | #if defined(_MSC_VER) || defined(__BORLANDC__)\r | |
89 | typedef __int64 Int64;\r | |
90 | typedef unsigned __int64 UInt64;\r | |
c4ab09ef | 91 | #define UINT64_CONST(n) n\r |
30fdf114 LG |
92 | #else\r |
93 | typedef long long int Int64;\r | |
94 | typedef unsigned long long int UInt64;\r | |
c4ab09ef | 95 | #define UINT64_CONST(n) n ## ULL\r |
30fdf114 LG |
96 | #endif\r |
97 | \r | |
98 | #endif\r | |
99 | \r | |
100 | #ifdef _LZMA_NO_SYSTEM_SIZE_T\r | |
101 | typedef UInt32 SizeT;\r | |
102 | #else\r | |
103 | typedef size_t SizeT;\r | |
104 | #endif\r | |
105 | \r | |
106 | typedef int Bool;\r | |
107 | #define True 1\r | |
108 | #define False 0\r | |
109 | \r | |
110 | \r | |
c4ab09ef LG |
111 | #ifdef _WIN32\r |
112 | #define MY_STD_CALL __stdcall\r | |
113 | #else\r | |
114 | #define MY_STD_CALL\r | |
115 | #endif\r | |
116 | \r | |
30fdf114 LG |
117 | #ifdef _MSC_VER\r |
118 | \r | |
119 | #if _MSC_VER >= 1300\r | |
120 | #define MY_NO_INLINE __declspec(noinline)\r | |
121 | #else\r | |
122 | #define MY_NO_INLINE\r | |
123 | #endif\r | |
124 | \r | |
5ec5a236 LG |
125 | #define MY_FORCE_INLINE __forceinline\r |
126 | \r | |
30fdf114 | 127 | #define MY_CDECL __cdecl\r |
c4ab09ef | 128 | #define MY_FAST_CALL __fastcall\r |
30fdf114 LG |
129 | \r |
130 | #else\r | |
131 | \r | |
c4ab09ef | 132 | #define MY_NO_INLINE\r |
5ec5a236 | 133 | #define MY_FORCE_INLINE\r |
30fdf114 | 134 | #define MY_CDECL\r |
30fdf114 LG |
135 | #define MY_FAST_CALL\r |
136 | \r | |
5ec5a236 LG |
137 | /* inline keyword : for C++ / C99 */\r |
138 | \r | |
139 | /* GCC, clang: */\r | |
140 | /*\r | |
141 | #if defined (__GNUC__) && (__GNUC__ >= 4)\r | |
142 | #define MY_FORCE_INLINE __attribute__((always_inline))\r | |
143 | #define MY_NO_INLINE __attribute__((noinline))\r | |
144 | #endif\r | |
145 | */\r | |
146 | \r | |
30fdf114 LG |
147 | #endif\r |
148 | \r | |
149 | \r | |
150 | /* The following interfaces use first parameter as pointer to structure */\r | |
151 | \r | |
5ec5a236 LG |
152 | typedef struct IByteIn IByteIn;\r |
153 | struct IByteIn\r | |
c4ab09ef | 154 | {\r |
5ec5a236 LG |
155 | Byte (*Read)(const IByteIn *p); /* reads one byte, returns 0 in case of EOF or error */\r |
156 | };\r | |
157 | #define IByteIn_Read(p) (p)->Read(p)\r | |
c4ab09ef | 158 | \r |
5ec5a236 LG |
159 | \r |
160 | typedef struct IByteOut IByteOut;\r | |
161 | struct IByteOut\r | |
c4ab09ef | 162 | {\r |
5ec5a236 LG |
163 | void (*Write)(const IByteOut *p, Byte b);\r |
164 | };\r | |
165 | #define IByteOut_Write(p, b) (p)->Write(p, b)\r | |
c4ab09ef | 166 | \r |
5ec5a236 LG |
167 | \r |
168 | typedef struct ISeqInStream ISeqInStream;\r | |
169 | struct ISeqInStream\r | |
30fdf114 | 170 | {\r |
5ec5a236 | 171 | SRes (*Read)(const ISeqInStream *p, void *buf, size_t *size);\r |
30fdf114 LG |
172 | /* if (input(*size) != 0 && output(*size) == 0) means end_of_stream.\r |
173 | (output(*size) < input(*size)) is allowed */\r | |
5ec5a236 LG |
174 | };\r |
175 | #define ISeqInStream_Read(p, buf, size) (p)->Read(p, buf, size)\r | |
30fdf114 LG |
176 | \r |
177 | /* it can return SZ_ERROR_INPUT_EOF */\r | |
5ec5a236 LG |
178 | SRes SeqInStream_Read(const ISeqInStream *stream, void *buf, size_t size);\r |
179 | SRes SeqInStream_Read2(const ISeqInStream *stream, void *buf, size_t size, SRes errorType);\r | |
180 | SRes SeqInStream_ReadByte(const ISeqInStream *stream, Byte *buf);\r | |
30fdf114 | 181 | \r |
5ec5a236 LG |
182 | \r |
183 | typedef struct ISeqOutStream ISeqOutStream;\r | |
184 | struct ISeqOutStream\r | |
30fdf114 | 185 | {\r |
5ec5a236 | 186 | size_t (*Write)(const ISeqOutStream *p, const void *buf, size_t size);\r |
30fdf114 LG |
187 | /* Returns: result - the number of actually written bytes.\r |
188 | (result < size) means error */\r | |
5ec5a236 LG |
189 | };\r |
190 | #define ISeqOutStream_Write(p, buf, size) (p)->Write(p, buf, size)\r | |
30fdf114 LG |
191 | \r |
192 | typedef enum\r | |
193 | {\r | |
194 | SZ_SEEK_SET = 0,\r | |
195 | SZ_SEEK_CUR = 1,\r | |
196 | SZ_SEEK_END = 2\r | |
197 | } ESzSeek;\r | |
198 | \r | |
5ec5a236 LG |
199 | \r |
200 | typedef struct ISeekInStream ISeekInStream;\r | |
201 | struct ISeekInStream\r | |
30fdf114 | 202 | {\r |
5ec5a236 LG |
203 | SRes (*Read)(const ISeekInStream *p, void *buf, size_t *size); /* same as ISeqInStream::Read */\r |
204 | SRes (*Seek)(const ISeekInStream *p, Int64 *pos, ESzSeek origin);\r | |
205 | };\r | |
206 | #define ISeekInStream_Read(p, buf, size) (p)->Read(p, buf, size)\r | |
207 | #define ISeekInStream_Seek(p, pos, origin) (p)->Seek(p, pos, origin)\r | |
30fdf114 | 208 | \r |
5ec5a236 LG |
209 | \r |
210 | typedef struct ILookInStream ILookInStream;\r | |
211 | struct ILookInStream\r | |
30fdf114 | 212 | {\r |
5ec5a236 | 213 | SRes (*Look)(const ILookInStream *p, const void **buf, size_t *size);\r |
30fdf114 LG |
214 | /* if (input(*size) != 0 && output(*size) == 0) means end_of_stream.\r |
215 | (output(*size) > input(*size)) is not allowed\r | |
216 | (output(*size) < input(*size)) is allowed */\r | |
5ec5a236 | 217 | SRes (*Skip)(const ILookInStream *p, size_t offset);\r |
30fdf114 LG |
218 | /* offset must be <= output(*size) of Look */\r |
219 | \r | |
5ec5a236 | 220 | SRes (*Read)(const ILookInStream *p, void *buf, size_t *size);\r |
30fdf114 | 221 | /* reads directly (without buffer). It's same as ISeqInStream::Read */\r |
5ec5a236 LG |
222 | SRes (*Seek)(const ILookInStream *p, Int64 *pos, ESzSeek origin);\r |
223 | };\r | |
30fdf114 | 224 | \r |
5ec5a236 LG |
225 | #define ILookInStream_Look(p, buf, size) (p)->Look(p, buf, size)\r |
226 | #define ILookInStream_Skip(p, offset) (p)->Skip(p, offset)\r | |
227 | #define ILookInStream_Read(p, buf, size) (p)->Read(p, buf, size)\r | |
228 | #define ILookInStream_Seek(p, pos, origin) (p)->Seek(p, pos, origin)\r | |
229 | \r | |
230 | \r | |
231 | SRes LookInStream_LookRead(const ILookInStream *stream, void *buf, size_t *size);\r | |
232 | SRes LookInStream_SeekTo(const ILookInStream *stream, UInt64 offset);\r | |
30fdf114 LG |
233 | \r |
234 | /* reads via ILookInStream::Read */\r | |
5ec5a236 LG |
235 | SRes LookInStream_Read2(const ILookInStream *stream, void *buf, size_t size, SRes errorType);\r |
236 | SRes LookInStream_Read(const ILookInStream *stream, void *buf, size_t size);\r | |
237 | \r | |
30fdf114 | 238 | \r |
30fdf114 LG |
239 | \r |
240 | typedef struct\r | |
241 | {\r | |
5ec5a236 LG |
242 | ILookInStream vt;\r |
243 | const ISeekInStream *realStream;\r | |
244 | \r | |
30fdf114 | 245 | size_t pos;\r |
5ec5a236 LG |
246 | size_t size; /* it's data size */\r |
247 | \r | |
248 | /* the following variables must be set outside */\r | |
249 | Byte *buf;\r | |
250 | size_t bufSize;\r | |
251 | } CLookToRead2;\r | |
252 | \r | |
253 | void LookToRead2_CreateVTable(CLookToRead2 *p, int lookahead);\r | |
254 | \r | |
255 | #define LookToRead2_Init(p) { (p)->pos = (p)->size = 0; }\r | |
30fdf114 | 256 | \r |
30fdf114 LG |
257 | \r |
258 | typedef struct\r | |
259 | {\r | |
5ec5a236 LG |
260 | ISeqInStream vt;\r |
261 | const ILookInStream *realStream;\r | |
30fdf114 LG |
262 | } CSecToLook;\r |
263 | \r | |
264 | void SecToLook_CreateVTable(CSecToLook *p);\r | |
265 | \r | |
5ec5a236 LG |
266 | \r |
267 | \r | |
30fdf114 LG |
268 | typedef struct\r |
269 | {\r | |
5ec5a236 LG |
270 | ISeqInStream vt;\r |
271 | const ILookInStream *realStream;\r | |
30fdf114 LG |
272 | } CSecToRead;\r |
273 | \r | |
274 | void SecToRead_CreateVTable(CSecToRead *p);\r | |
275 | \r | |
5ec5a236 LG |
276 | \r |
277 | typedef struct ICompressProgress ICompressProgress;\r | |
278 | \r | |
279 | struct ICompressProgress\r | |
30fdf114 | 280 | {\r |
5ec5a236 | 281 | SRes (*Progress)(const ICompressProgress *p, UInt64 inSize, UInt64 outSize);\r |
30fdf114 LG |
282 | /* Returns: result. (result != SZ_OK) means break.\r |
283 | Value (UInt64)(Int64)-1 for size means unknown value. */\r | |
5ec5a236 LG |
284 | };\r |
285 | #define ICompressProgress_Progress(p, inSize, outSize) (p)->Progress(p, inSize, outSize)\r | |
30fdf114 | 286 | \r |
5ec5a236 LG |
287 | \r |
288 | \r | |
289 | typedef struct ISzAlloc ISzAlloc;\r | |
290 | typedef const ISzAlloc * ISzAllocPtr;\r | |
291 | \r | |
292 | struct ISzAlloc\r | |
30fdf114 | 293 | {\r |
5ec5a236 LG |
294 | void *(*Alloc)(ISzAllocPtr p, size_t size);\r |
295 | void (*Free)(ISzAllocPtr p, void *address); /* address can be 0 */\r | |
296 | };\r | |
297 | \r | |
298 | #define ISzAlloc_Alloc(p, size) (p)->Alloc(p, size)\r | |
299 | #define ISzAlloc_Free(p, a) (p)->Free(p, a)\r | |
300 | \r | |
301 | /* deprecated */\r | |
302 | #define IAlloc_Alloc(p, size) ISzAlloc_Alloc(p, size)\r | |
303 | #define IAlloc_Free(p, a) ISzAlloc_Free(p, a)\r | |
304 | \r | |
305 | \r | |
306 | \r | |
307 | \r | |
308 | \r | |
309 | #ifndef MY_offsetof\r | |
310 | #ifdef offsetof\r | |
311 | #define MY_offsetof(type, m) offsetof(type, m)\r | |
312 | /*\r | |
313 | #define MY_offsetof(type, m) FIELD_OFFSET(type, m)\r | |
314 | */\r | |
315 | #else\r | |
316 | #define MY_offsetof(type, m) ((size_t)&(((type *)0)->m))\r | |
317 | #endif\r | |
318 | #endif\r | |
319 | \r | |
320 | \r | |
321 | \r | |
322 | #ifndef MY_container_of\r | |
323 | \r | |
324 | /*\r | |
325 | #define MY_container_of(ptr, type, m) container_of(ptr, type, m)\r | |
326 | #define MY_container_of(ptr, type, m) CONTAINING_RECORD(ptr, type, m)\r | |
327 | #define MY_container_of(ptr, type, m) ((type *)((char *)(ptr) - offsetof(type, m)))\r | |
328 | #define MY_container_of(ptr, type, m) (&((type *)0)->m == (ptr), ((type *)(((char *)(ptr)) - MY_offsetof(type, m))))\r | |
329 | */\r | |
330 | \r | |
331 | /*\r | |
332 | GCC shows warning: "perhaps the 'offsetof' macro was used incorrectly"\r | |
333 | GCC 3.4.4 : classes with constructor\r | |
334 | GCC 4.8.1 : classes with non-public variable members"\r | |
335 | */\r | |
336 | \r | |
337 | #define MY_container_of(ptr, type, m) ((type *)((char *)(1 ? (ptr) : &((type *)0)->m) - MY_offsetof(type, m)))\r | |
338 | \r | |
339 | \r | |
340 | #endif\r | |
341 | \r | |
342 | #define CONTAINER_FROM_VTBL_SIMPLE(ptr, type, m) ((type *)(ptr))\r | |
343 | \r | |
344 | /*\r | |
345 | #define CONTAINER_FROM_VTBL(ptr, type, m) CONTAINER_FROM_VTBL_SIMPLE(ptr, type, m)\r | |
346 | */\r | |
347 | #define CONTAINER_FROM_VTBL(ptr, type, m) MY_container_of(ptr, type, m)\r | |
348 | \r | |
349 | #define CONTAINER_FROM_VTBL_CLS(ptr, type, m) CONTAINER_FROM_VTBL_SIMPLE(ptr, type, m)\r | |
350 | /*\r | |
351 | #define CONTAINER_FROM_VTBL_CLS(ptr, type, m) CONTAINER_FROM_VTBL(ptr, type, m)\r | |
352 | */\r | |
353 | \r | |
30fdf114 | 354 | \r |
30fdf114 | 355 | \r |
c4ab09ef LG |
356 | #ifdef _WIN32\r |
357 | \r | |
358 | #define CHAR_PATH_SEPARATOR '\\'\r | |
359 | #define WCHAR_PATH_SEPARATOR L'\\'\r | |
360 | #define STRING_PATH_SEPARATOR "\\"\r | |
361 | #define WSTRING_PATH_SEPARATOR L"\\"\r | |
362 | \r | |
363 | #else\r | |
364 | \r | |
365 | #define CHAR_PATH_SEPARATOR '/'\r | |
366 | #define WCHAR_PATH_SEPARATOR L'/'\r | |
367 | #define STRING_PATH_SEPARATOR "/"\r | |
368 | #define WSTRING_PATH_SEPARATOR L"/"\r | |
369 | \r | |
370 | #endif\r | |
371 | \r | |
372 | EXTERN_C_END\r | |
373 | \r | |
30fdf114 | 374 | #endif\r |