]> git.proxmox.com Git - mirror_edk2.git/blame - BaseTools/Source/C/LzmaCompress/Sdk/C/7zTypes.h
BaseTools LzmaCompress: Update LZMA to new 19.00 version
[mirror_edk2.git] / BaseTools / Source / C / LzmaCompress / Sdk / C / 7zTypes.h
CommitLineData
c4ab09ef 1/* 7zTypes.h -- Basic types\r
4e38bb60 22018-08-04 : 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
4e38bb60
LW
106typedef int BoolInt;\r
107/* typedef BoolInt Bool; */\r
30fdf114
LG
108#define True 1\r
109#define False 0\r
110\r
111\r
c4ab09ef
LG
112#ifdef _WIN32\r
113#define MY_STD_CALL __stdcall\r
114#else\r
115#define MY_STD_CALL\r
116#endif\r
117\r
30fdf114
LG
118#ifdef _MSC_VER\r
119\r
120#if _MSC_VER >= 1300\r
121#define MY_NO_INLINE __declspec(noinline)\r
122#else\r
123#define MY_NO_INLINE\r
124#endif\r
125\r
5ec5a236
LG
126#define MY_FORCE_INLINE __forceinline\r
127\r
30fdf114 128#define MY_CDECL __cdecl\r
c4ab09ef 129#define MY_FAST_CALL __fastcall\r
30fdf114
LG
130\r
131#else\r
132\r
c4ab09ef 133#define MY_NO_INLINE\r
5ec5a236 134#define MY_FORCE_INLINE\r
30fdf114 135#define MY_CDECL\r
30fdf114
LG
136#define MY_FAST_CALL\r
137\r
5ec5a236
LG
138/* inline keyword : for C++ / C99 */\r
139\r
140/* GCC, clang: */\r
141/*\r
142#if defined (__GNUC__) && (__GNUC__ >= 4)\r
143#define MY_FORCE_INLINE __attribute__((always_inline))\r
144#define MY_NO_INLINE __attribute__((noinline))\r
145#endif\r
146*/\r
147\r
30fdf114
LG
148#endif\r
149\r
150\r
151/* The following interfaces use first parameter as pointer to structure */\r
152\r
5ec5a236
LG
153typedef struct IByteIn IByteIn;\r
154struct IByteIn\r
c4ab09ef 155{\r
5ec5a236
LG
156 Byte (*Read)(const IByteIn *p); /* reads one byte, returns 0 in case of EOF or error */\r
157};\r
158#define IByteIn_Read(p) (p)->Read(p)\r
c4ab09ef 159\r
5ec5a236
LG
160\r
161typedef struct IByteOut IByteOut;\r
162struct IByteOut\r
c4ab09ef 163{\r
5ec5a236
LG
164 void (*Write)(const IByteOut *p, Byte b);\r
165};\r
166#define IByteOut_Write(p, b) (p)->Write(p, b)\r
c4ab09ef 167\r
5ec5a236
LG
168\r
169typedef struct ISeqInStream ISeqInStream;\r
170struct ISeqInStream\r
30fdf114 171{\r
5ec5a236 172 SRes (*Read)(const ISeqInStream *p, void *buf, size_t *size);\r
30fdf114
LG
173 /* if (input(*size) != 0 && output(*size) == 0) means end_of_stream.\r
174 (output(*size) < input(*size)) is allowed */\r
5ec5a236
LG
175};\r
176#define ISeqInStream_Read(p, buf, size) (p)->Read(p, buf, size)\r
30fdf114
LG
177\r
178/* it can return SZ_ERROR_INPUT_EOF */\r
5ec5a236
LG
179SRes SeqInStream_Read(const ISeqInStream *stream, void *buf, size_t size);\r
180SRes SeqInStream_Read2(const ISeqInStream *stream, void *buf, size_t size, SRes errorType);\r
181SRes SeqInStream_ReadByte(const ISeqInStream *stream, Byte *buf);\r
30fdf114 182\r
5ec5a236
LG
183\r
184typedef struct ISeqOutStream ISeqOutStream;\r
185struct ISeqOutStream\r
30fdf114 186{\r
5ec5a236 187 size_t (*Write)(const ISeqOutStream *p, const void *buf, size_t size);\r
30fdf114
LG
188 /* Returns: result - the number of actually written bytes.\r
189 (result < size) means error */\r
5ec5a236
LG
190};\r
191#define ISeqOutStream_Write(p, buf, size) (p)->Write(p, buf, size)\r
30fdf114
LG
192\r
193typedef enum\r
194{\r
195 SZ_SEEK_SET = 0,\r
196 SZ_SEEK_CUR = 1,\r
197 SZ_SEEK_END = 2\r
198} ESzSeek;\r
199\r
5ec5a236
LG
200\r
201typedef struct ISeekInStream ISeekInStream;\r
202struct ISeekInStream\r
30fdf114 203{\r
5ec5a236
LG
204 SRes (*Read)(const ISeekInStream *p, void *buf, size_t *size); /* same as ISeqInStream::Read */\r
205 SRes (*Seek)(const ISeekInStream *p, Int64 *pos, ESzSeek origin);\r
206};\r
207#define ISeekInStream_Read(p, buf, size) (p)->Read(p, buf, size)\r
208#define ISeekInStream_Seek(p, pos, origin) (p)->Seek(p, pos, origin)\r
30fdf114 209\r
5ec5a236
LG
210\r
211typedef struct ILookInStream ILookInStream;\r
212struct ILookInStream\r
30fdf114 213{\r
5ec5a236 214 SRes (*Look)(const ILookInStream *p, const void **buf, size_t *size);\r
30fdf114
LG
215 /* if (input(*size) != 0 && output(*size) == 0) means end_of_stream.\r
216 (output(*size) > input(*size)) is not allowed\r
217 (output(*size) < input(*size)) is allowed */\r
5ec5a236 218 SRes (*Skip)(const ILookInStream *p, size_t offset);\r
30fdf114
LG
219 /* offset must be <= output(*size) of Look */\r
220\r
5ec5a236 221 SRes (*Read)(const ILookInStream *p, void *buf, size_t *size);\r
30fdf114 222 /* reads directly (without buffer). It's same as ISeqInStream::Read */\r
5ec5a236
LG
223 SRes (*Seek)(const ILookInStream *p, Int64 *pos, ESzSeek origin);\r
224};\r
30fdf114 225\r
5ec5a236
LG
226#define ILookInStream_Look(p, buf, size) (p)->Look(p, buf, size)\r
227#define ILookInStream_Skip(p, offset) (p)->Skip(p, offset)\r
228#define ILookInStream_Read(p, buf, size) (p)->Read(p, buf, size)\r
229#define ILookInStream_Seek(p, pos, origin) (p)->Seek(p, pos, origin)\r
230\r
231\r
232SRes LookInStream_LookRead(const ILookInStream *stream, void *buf, size_t *size);\r
233SRes LookInStream_SeekTo(const ILookInStream *stream, UInt64 offset);\r
30fdf114
LG
234\r
235/* reads via ILookInStream::Read */\r
5ec5a236
LG
236SRes LookInStream_Read2(const ILookInStream *stream, void *buf, size_t size, SRes errorType);\r
237SRes LookInStream_Read(const ILookInStream *stream, void *buf, size_t size);\r
238\r
30fdf114 239\r
30fdf114
LG
240\r
241typedef struct\r
242{\r
5ec5a236
LG
243 ILookInStream vt;\r
244 const ISeekInStream *realStream;\r
245 \r
30fdf114 246 size_t pos;\r
5ec5a236
LG
247 size_t size; /* it's data size */\r
248 \r
249 /* the following variables must be set outside */\r
250 Byte *buf;\r
251 size_t bufSize;\r
252} CLookToRead2;\r
253\r
254void LookToRead2_CreateVTable(CLookToRead2 *p, int lookahead);\r
255\r
256#define LookToRead2_Init(p) { (p)->pos = (p)->size = 0; }\r
30fdf114 257\r
30fdf114
LG
258\r
259typedef struct\r
260{\r
5ec5a236
LG
261 ISeqInStream vt;\r
262 const ILookInStream *realStream;\r
30fdf114
LG
263} CSecToLook;\r
264\r
265void SecToLook_CreateVTable(CSecToLook *p);\r
266\r
5ec5a236
LG
267\r
268\r
30fdf114
LG
269typedef struct\r
270{\r
5ec5a236
LG
271 ISeqInStream vt;\r
272 const ILookInStream *realStream;\r
30fdf114
LG
273} CSecToRead;\r
274\r
275void SecToRead_CreateVTable(CSecToRead *p);\r
276\r
5ec5a236
LG
277\r
278typedef struct ICompressProgress ICompressProgress;\r
279\r
280struct ICompressProgress\r
30fdf114 281{\r
5ec5a236 282 SRes (*Progress)(const ICompressProgress *p, UInt64 inSize, UInt64 outSize);\r
30fdf114
LG
283 /* Returns: result. (result != SZ_OK) means break.\r
284 Value (UInt64)(Int64)-1 for size means unknown value. */\r
5ec5a236
LG
285};\r
286#define ICompressProgress_Progress(p, inSize, outSize) (p)->Progress(p, inSize, outSize)\r
30fdf114 287\r
5ec5a236
LG
288\r
289\r
290typedef struct ISzAlloc ISzAlloc;\r
291typedef const ISzAlloc * ISzAllocPtr;\r
292\r
293struct ISzAlloc\r
30fdf114 294{\r
5ec5a236
LG
295 void *(*Alloc)(ISzAllocPtr p, size_t size);\r
296 void (*Free)(ISzAllocPtr p, void *address); /* address can be 0 */\r
297};\r
298\r
299#define ISzAlloc_Alloc(p, size) (p)->Alloc(p, size)\r
300#define ISzAlloc_Free(p, a) (p)->Free(p, a)\r
301\r
302/* deprecated */\r
303#define IAlloc_Alloc(p, size) ISzAlloc_Alloc(p, size)\r
304#define IAlloc_Free(p, a) ISzAlloc_Free(p, a)\r
305\r
306\r
307\r
308\r
309\r
310#ifndef MY_offsetof\r
311 #ifdef offsetof\r
312 #define MY_offsetof(type, m) offsetof(type, m)\r
313 /*\r
314 #define MY_offsetof(type, m) FIELD_OFFSET(type, m)\r
315 */\r
316 #else\r
317 #define MY_offsetof(type, m) ((size_t)&(((type *)0)->m))\r
318 #endif\r
319#endif\r
320\r
321\r
322\r
323#ifndef MY_container_of\r
324\r
325/*\r
326#define MY_container_of(ptr, type, m) container_of(ptr, type, m)\r
327#define MY_container_of(ptr, type, m) CONTAINING_RECORD(ptr, type, m)\r
328#define MY_container_of(ptr, type, m) ((type *)((char *)(ptr) - offsetof(type, m)))\r
329#define MY_container_of(ptr, type, m) (&((type *)0)->m == (ptr), ((type *)(((char *)(ptr)) - MY_offsetof(type, m))))\r
330*/\r
331\r
332/*\r
333 GCC shows warning: "perhaps the 'offsetof' macro was used incorrectly"\r
334 GCC 3.4.4 : classes with constructor\r
335 GCC 4.8.1 : classes with non-public variable members"\r
336*/\r
337\r
338#define MY_container_of(ptr, type, m) ((type *)((char *)(1 ? (ptr) : &((type *)0)->m) - MY_offsetof(type, m)))\r
339\r
340\r
341#endif\r
342\r
343#define CONTAINER_FROM_VTBL_SIMPLE(ptr, type, m) ((type *)(ptr))\r
344\r
345/*\r
346#define CONTAINER_FROM_VTBL(ptr, type, m) CONTAINER_FROM_VTBL_SIMPLE(ptr, type, m)\r
347*/\r
348#define CONTAINER_FROM_VTBL(ptr, type, m) MY_container_of(ptr, type, m)\r
349\r
350#define CONTAINER_FROM_VTBL_CLS(ptr, type, m) CONTAINER_FROM_VTBL_SIMPLE(ptr, type, m)\r
351/*\r
352#define CONTAINER_FROM_VTBL_CLS(ptr, type, m) CONTAINER_FROM_VTBL(ptr, type, m)\r
353*/\r
354\r
30fdf114 355\r
30fdf114 356\r
c4ab09ef
LG
357#ifdef _WIN32\r
358\r
359#define CHAR_PATH_SEPARATOR '\\'\r
360#define WCHAR_PATH_SEPARATOR L'\\'\r
361#define STRING_PATH_SEPARATOR "\\"\r
362#define WSTRING_PATH_SEPARATOR L"\\"\r
363\r
364#else\r
365\r
366#define CHAR_PATH_SEPARATOR '/'\r
367#define WCHAR_PATH_SEPARATOR L'/'\r
368#define STRING_PATH_SEPARATOR "/"\r
369#define WSTRING_PATH_SEPARATOR L"/"\r
370\r
371#endif\r
372\r
373EXTERN_C_END\r
374\r
30fdf114 375#endif\r