| /* Types.h -- Basic types |
| 2008-11-23 : Igor Pavlov : Public domain */ |
| |
| #ifndef __7Z_TYPES_H |
| #define __7Z_TYPES_H |
| |
| #include <stddef.h> |
| |
| #ifdef _WIN32 |
| #include <windows.h> |
| #endif |
| |
| #define SZ_OK 0 |
| |
| #define SZ_ERROR_DATA 1 |
| #define SZ_ERROR_MEM 2 |
| #define SZ_ERROR_CRC 3 |
| #define SZ_ERROR_UNSUPPORTED 4 |
| #define SZ_ERROR_PARAM 5 |
| #define SZ_ERROR_INPUT_EOF 6 |
| #define SZ_ERROR_OUTPUT_EOF 7 |
| #define SZ_ERROR_READ 8 |
| #define SZ_ERROR_WRITE 9 |
| #define SZ_ERROR_PROGRESS 10 |
| #define SZ_ERROR_FAIL 11 |
| #define SZ_ERROR_THREAD 12 |
| |
| #define SZ_ERROR_ARCHIVE 16 |
| #define SZ_ERROR_NO_ARCHIVE 17 |
| |
| typedef int SRes; |
| |
| #ifdef _WIN32 |
| typedef DWORD WRes; |
| #else |
| typedef int WRes; |
| #endif |
| |
| #ifndef RINOK |
| #define RINOK(x) { int __result__ = (x); if (__result__ != 0) return __result__; } |
| #endif |
| |
| typedef unsigned char Byte; |
| typedef short Int16; |
| typedef unsigned short UInt16; |
| |
| #ifdef _LZMA_UINT32_IS_ULONG |
| typedef long Int32; |
| typedef unsigned long UInt32; |
| #else |
| typedef int Int32; |
| typedef unsigned int UInt32; |
| #endif |
| |
| #ifdef _SZ_NO_INT_64 |
| |
| /* define _SZ_NO_INT_64, if your compiler doesn't support 64-bit integers. |
| NOTES: Some code will work incorrectly in that case! */ |
| |
| typedef long Int64; |
| typedef unsigned long UInt64; |
| |
| #else |
| |
| #if defined(_MSC_VER) || defined(__BORLANDC__) |
| typedef __int64 Int64; |
| typedef unsigned __int64 UInt64; |
| #else |
| typedef long long int Int64; |
| typedef unsigned long long int UInt64; |
| #endif |
| |
| #endif |
| |
| #ifdef _LZMA_NO_SYSTEM_SIZE_T |
| typedef UInt32 SizeT; |
| #else |
| typedef size_t SizeT; |
| #endif |
| |
| typedef int Bool; |
| #define True 1 |
| #define False 0 |
| |
| |
| #ifdef _MSC_VER |
| |
| #if _MSC_VER >= 1300 |
| #define MY_NO_INLINE __declspec(noinline) |
| #else |
| #define MY_NO_INLINE |
| #endif |
| |
| #define MY_CDECL __cdecl |
| #define MY_STD_CALL __stdcall |
| #define MY_FAST_CALL MY_NO_INLINE __fastcall |
| |
| #else |
| |
| #define MY_CDECL |
| #define MY_STD_CALL |
| #define MY_FAST_CALL |
| |
| #endif |
| |
| |
| /* The following interfaces use first parameter as pointer to structure */ |
| |
| typedef struct |
| { |
| SRes (*Read)(void *p, void *buf, size_t *size); |
| /* if (input(*size) != 0 && output(*size) == 0) means end_of_stream. |
| (output(*size) < input(*size)) is allowed */ |
| } ISeqInStream; |
| |
| /* it can return SZ_ERROR_INPUT_EOF */ |
| SRes SeqInStream_Read(ISeqInStream *stream, void *buf, size_t size); |
| SRes SeqInStream_Read2(ISeqInStream *stream, void *buf, size_t size, SRes errorType); |
| SRes SeqInStream_ReadByte(ISeqInStream *stream, Byte *buf); |
| |
| typedef struct |
| { |
| size_t (*Write)(void *p, const void *buf, size_t size); |
| /* Returns: result - the number of actually written bytes. |
| (result < size) means error */ |
| } ISeqOutStream; |
| |
| typedef enum |
| { |
| SZ_SEEK_SET = 0, |
| SZ_SEEK_CUR = 1, |
| SZ_SEEK_END = 2 |
| } ESzSeek; |
| |
| typedef struct |
| { |
| SRes (*Read)(void *p, void *buf, size_t *size); /* same as ISeqInStream::Read */ |
| SRes (*Seek)(void *p, Int64 *pos, ESzSeek origin); |
| } ISeekInStream; |
| |
| typedef struct |
| { |
| SRes (*Look)(void *p, void **buf, size_t *size); |
| /* if (input(*size) != 0 && output(*size) == 0) means end_of_stream. |
| (output(*size) > input(*size)) is not allowed |
| (output(*size) < input(*size)) is allowed */ |
| SRes (*Skip)(void *p, size_t offset); |
| /* offset must be <= output(*size) of Look */ |
| |
| SRes (*Read)(void *p, void *buf, size_t *size); |
| /* reads directly (without buffer). It's same as ISeqInStream::Read */ |
| SRes (*Seek)(void *p, Int64 *pos, ESzSeek origin); |
| } ILookInStream; |
| |
| SRes LookInStream_LookRead(ILookInStream *stream, void *buf, size_t *size); |
| SRes LookInStream_SeekTo(ILookInStream *stream, UInt64 offset); |
| |
| /* reads via ILookInStream::Read */ |
| SRes LookInStream_Read2(ILookInStream *stream, void *buf, size_t size, SRes errorType); |
| SRes LookInStream_Read(ILookInStream *stream, void *buf, size_t size); |
| |
| #define LookToRead_BUF_SIZE (1 << 14) |
| |
| typedef struct |
| { |
| ILookInStream s; |
| ISeekInStream *realStream; |
| size_t pos; |
| size_t size; |
| Byte buf[LookToRead_BUF_SIZE]; |
| } CLookToRead; |
| |
| void LookToRead_CreateVTable(CLookToRead *p, int lookahead); |
| void LookToRead_Init(CLookToRead *p); |
| |
| typedef struct |
| { |
| ISeqInStream s; |
| ILookInStream *realStream; |
| } CSecToLook; |
| |
| void SecToLook_CreateVTable(CSecToLook *p); |
| |
| typedef struct |
| { |
| ISeqInStream s; |
| ILookInStream *realStream; |
| } CSecToRead; |
| |
| void SecToRead_CreateVTable(CSecToRead *p); |
| |
| typedef struct |
| { |
| SRes (*Progress)(void *p, UInt64 inSize, UInt64 outSize); |
| /* Returns: result. (result != SZ_OK) means break. |
| Value (UInt64)(Int64)-1 for size means unknown value. */ |
| } ICompressProgress; |
| |
| typedef struct |
| { |
| void *(*Alloc)(void *p, size_t size); |
| void (*Free)(void *p, void *address); /* address can be 0 */ |
| } ISzAlloc; |
| |
| #define IAlloc_Alloc(p, size) (p)->Alloc((p), size) |
| #define IAlloc_Free(p, a) (p)->Free((p), a) |
| |
| #endif |