mirror of
https://github.com/FIX94/hbc.git
synced 2025-01-15 04:39:16 +01:00
209 lines
4.8 KiB
C
209 lines
4.8 KiB
C
|
/* 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
|