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