]> git.proxmox.com Git - mirror_edk2.git/blame - BaseTools/Source/C/LzmaCompress/Sdk/C/7zTypes.h
BaseTools Lzma: Update LZMA SDK version to 18.05
[mirror_edk2.git] / BaseTools / Source / C / LzmaCompress / Sdk / C / 7zTypes.h
CommitLineData
c4ab09ef 1/* 7zTypes.h -- Basic types\r
5ec5a236 22017-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
23EXTERN_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
43typedef int SRes;\r
44\r
5ec5a236 45\r
30fdf114 46#ifdef _WIN32\r
5ec5a236 47\r
c4ab09ef
LG
48/* typedef DWORD WRes; */\r
49typedef 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 54typedef 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
66typedef unsigned char Byte;\r
67typedef short Int16;\r
68typedef unsigned short UInt16;\r
69\r
70#ifdef _LZMA_UINT32_IS_ULONG\r
71typedef long Int32;\r
72typedef unsigned long UInt32;\r
73#else\r
74typedef int Int32;\r
75typedef 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
83typedef long Int64;\r
84typedef unsigned long UInt64;\r
85\r
86#else\r
87\r
88#if defined(_MSC_VER) || defined(__BORLANDC__)\r
89typedef __int64 Int64;\r
90typedef unsigned __int64 UInt64;\r
c4ab09ef 91#define UINT64_CONST(n) n\r
30fdf114
LG
92#else\r
93typedef long long int Int64;\r
94typedef 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
101typedef UInt32 SizeT;\r
102#else\r
103typedef size_t SizeT;\r
104#endif\r
105\r
106typedef 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
152typedef struct IByteIn IByteIn;\r
153struct 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
160typedef struct IByteOut IByteOut;\r
161struct 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
168typedef struct ISeqInStream ISeqInStream;\r
169struct 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
178SRes SeqInStream_Read(const ISeqInStream *stream, void *buf, size_t size);\r
179SRes SeqInStream_Read2(const ISeqInStream *stream, void *buf, size_t size, SRes errorType);\r
180SRes SeqInStream_ReadByte(const ISeqInStream *stream, Byte *buf);\r
30fdf114 181\r
5ec5a236
LG
182\r
183typedef struct ISeqOutStream ISeqOutStream;\r
184struct 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
192typedef 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
200typedef struct ISeekInStream ISeekInStream;\r
201struct 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
210typedef struct ILookInStream ILookInStream;\r
211struct 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
231SRes LookInStream_LookRead(const ILookInStream *stream, void *buf, size_t *size);\r
232SRes LookInStream_SeekTo(const ILookInStream *stream, UInt64 offset);\r
30fdf114
LG
233\r
234/* reads via ILookInStream::Read */\r
5ec5a236
LG
235SRes LookInStream_Read2(const ILookInStream *stream, void *buf, size_t size, SRes errorType);\r
236SRes LookInStream_Read(const ILookInStream *stream, void *buf, size_t size);\r
237\r
30fdf114 238\r
30fdf114
LG
239\r
240typedef 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
253void 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
258typedef struct\r
259{\r
5ec5a236
LG
260 ISeqInStream vt;\r
261 const ILookInStream *realStream;\r
30fdf114
LG
262} CSecToLook;\r
263\r
264void SecToLook_CreateVTable(CSecToLook *p);\r
265\r
5ec5a236
LG
266\r
267\r
30fdf114
LG
268typedef struct\r
269{\r
5ec5a236
LG
270 ISeqInStream vt;\r
271 const ILookInStream *realStream;\r
30fdf114
LG
272} CSecToRead;\r
273\r
274void SecToRead_CreateVTable(CSecToRead *p);\r
275\r
5ec5a236
LG
276\r
277typedef struct ICompressProgress ICompressProgress;\r
278\r
279struct 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
289typedef struct ISzAlloc ISzAlloc;\r
290typedef const ISzAlloc * ISzAllocPtr;\r
291\r
292struct 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
372EXTERN_C_END\r
373\r
30fdf114 374#endif\r