mirror of
https://github.com/ZDoom/Raze.git
synced 2024-12-02 09:02:18 +00:00
718112a8fe
Currently none of these is being used, but eventually they will, once more code gets ported over. So it's better to have them right away and avoid editing the project file too much, only to revert that later.
202 lines
5 KiB
C
202 lines
5 KiB
C
/* 7z.h -- 7z interface
|
|
2017-04-03 : Igor Pavlov : Public domain */
|
|
|
|
#ifndef __7Z_H
|
|
#define __7Z_H
|
|
|
|
#include "7zTypes.h"
|
|
|
|
EXTERN_C_BEGIN
|
|
|
|
#define k7zStartHeaderSize 0x20
|
|
#define k7zSignatureSize 6
|
|
|
|
extern const Byte k7zSignature[k7zSignatureSize];
|
|
|
|
typedef struct
|
|
{
|
|
const Byte *Data;
|
|
size_t Size;
|
|
} CSzData;
|
|
|
|
/* CSzCoderInfo & CSzFolder support only default methods */
|
|
|
|
typedef struct
|
|
{
|
|
size_t PropsOffset;
|
|
UInt32 MethodID;
|
|
Byte NumStreams;
|
|
Byte PropsSize;
|
|
} CSzCoderInfo;
|
|
|
|
typedef struct
|
|
{
|
|
UInt32 InIndex;
|
|
UInt32 OutIndex;
|
|
} CSzBond;
|
|
|
|
#define SZ_NUM_CODERS_IN_FOLDER_MAX 4
|
|
#define SZ_NUM_BONDS_IN_FOLDER_MAX 3
|
|
#define SZ_NUM_PACK_STREAMS_IN_FOLDER_MAX 4
|
|
|
|
typedef struct
|
|
{
|
|
UInt32 NumCoders;
|
|
UInt32 NumBonds;
|
|
UInt32 NumPackStreams;
|
|
UInt32 UnpackStream;
|
|
UInt32 PackStreams[SZ_NUM_PACK_STREAMS_IN_FOLDER_MAX];
|
|
CSzBond Bonds[SZ_NUM_BONDS_IN_FOLDER_MAX];
|
|
CSzCoderInfo Coders[SZ_NUM_CODERS_IN_FOLDER_MAX];
|
|
} CSzFolder;
|
|
|
|
|
|
SRes SzGetNextFolderItem(CSzFolder *f, CSzData *sd);
|
|
|
|
typedef struct
|
|
{
|
|
UInt32 Low;
|
|
UInt32 High;
|
|
} CNtfsFileTime;
|
|
|
|
typedef struct
|
|
{
|
|
Byte *Defs; /* MSB 0 bit numbering */
|
|
UInt32 *Vals;
|
|
} CSzBitUi32s;
|
|
|
|
typedef struct
|
|
{
|
|
Byte *Defs; /* MSB 0 bit numbering */
|
|
// UInt64 *Vals;
|
|
CNtfsFileTime *Vals;
|
|
} CSzBitUi64s;
|
|
|
|
#define SzBitArray_Check(p, i) (((p)[(i) >> 3] & (0x80 >> ((i) & 7))) != 0)
|
|
|
|
#define SzBitWithVals_Check(p, i) ((p)->Defs && ((p)->Defs[(i) >> 3] & (0x80 >> ((i) & 7))) != 0)
|
|
|
|
typedef struct
|
|
{
|
|
UInt32 NumPackStreams;
|
|
UInt32 NumFolders;
|
|
|
|
UInt64 *PackPositions; // NumPackStreams + 1
|
|
CSzBitUi32s FolderCRCs; // NumFolders
|
|
|
|
size_t *FoCodersOffsets; // NumFolders + 1
|
|
UInt32 *FoStartPackStreamIndex; // NumFolders + 1
|
|
UInt32 *FoToCoderUnpackSizes; // NumFolders + 1
|
|
Byte *FoToMainUnpackSizeIndex; // NumFolders
|
|
UInt64 *CoderUnpackSizes; // for all coders in all folders
|
|
|
|
Byte *CodersData;
|
|
} CSzAr;
|
|
|
|
UInt64 SzAr_GetFolderUnpackSize(const CSzAr *p, UInt32 folderIndex);
|
|
|
|
SRes SzAr_DecodeFolder(const CSzAr *p, UInt32 folderIndex,
|
|
ILookInStream *stream, UInt64 startPos,
|
|
Byte *outBuffer, size_t outSize,
|
|
ISzAllocPtr allocMain);
|
|
|
|
typedef struct
|
|
{
|
|
CSzAr db;
|
|
|
|
UInt64 startPosAfterHeader;
|
|
UInt64 dataPos;
|
|
|
|
UInt32 NumFiles;
|
|
|
|
UInt64 *UnpackPositions; // NumFiles + 1
|
|
// Byte *IsEmptyFiles;
|
|
Byte *IsDirs;
|
|
CSzBitUi32s CRCs;
|
|
|
|
CSzBitUi32s Attribs;
|
|
// CSzBitUi32s Parents;
|
|
CSzBitUi64s MTime;
|
|
CSzBitUi64s CTime;
|
|
|
|
UInt32 *FolderToFile; // NumFolders + 1
|
|
UInt32 *FileToFolder; // NumFiles
|
|
|
|
size_t *FileNameOffsets; /* in 2-byte steps */
|
|
Byte *FileNames; /* UTF-16-LE */
|
|
} CSzArEx;
|
|
|
|
#define SzArEx_IsDir(p, i) (SzBitArray_Check((p)->IsDirs, i))
|
|
|
|
#define SzArEx_GetFileSize(p, i) ((p)->UnpackPositions[(i) + 1] - (p)->UnpackPositions[i])
|
|
|
|
void SzArEx_Init(CSzArEx *p);
|
|
void SzArEx_Free(CSzArEx *p, ISzAllocPtr alloc);
|
|
UInt64 SzArEx_GetFolderStreamPos(const CSzArEx *p, UInt32 folderIndex, UInt32 indexInFolder);
|
|
int SzArEx_GetFolderFullPackSize(const CSzArEx *p, UInt32 folderIndex, UInt64 *resSize);
|
|
|
|
/*
|
|
if dest == NULL, the return value specifies the required size of the buffer,
|
|
in 16-bit characters, including the null-terminating character.
|
|
if dest != NULL, the return value specifies the number of 16-bit characters that
|
|
are written to the dest, including the null-terminating character. */
|
|
|
|
size_t SzArEx_GetFileNameUtf16(const CSzArEx *p, size_t fileIndex, UInt16 *dest);
|
|
|
|
/*
|
|
size_t SzArEx_GetFullNameLen(const CSzArEx *p, size_t fileIndex);
|
|
UInt16 *SzArEx_GetFullNameUtf16_Back(const CSzArEx *p, size_t fileIndex, UInt16 *dest);
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
SzArEx_Extract extracts file from archive
|
|
|
|
*outBuffer must be 0 before first call for each new archive.
|
|
|
|
Extracting cache:
|
|
If you need to decompress more than one file, you can send
|
|
these values from previous call:
|
|
*blockIndex,
|
|
*outBuffer,
|
|
*outBufferSize
|
|
You can consider "*outBuffer" as cache of solid block. If your archive is solid,
|
|
it will increase decompression speed.
|
|
|
|
If you use external function, you can declare these 3 cache variables
|
|
(blockIndex, outBuffer, outBufferSize) as static in that external function.
|
|
|
|
Free *outBuffer and set *outBuffer to 0, if you want to flush cache.
|
|
*/
|
|
|
|
SRes SzArEx_Extract(
|
|
const CSzArEx *db,
|
|
ILookInStream *inStream,
|
|
UInt32 fileIndex, /* index of file */
|
|
UInt32 *blockIndex, /* index of solid block */
|
|
Byte **outBuffer, /* pointer to pointer to output buffer (allocated with allocMain) */
|
|
size_t *outBufferSize, /* buffer size for output buffer */
|
|
size_t *offset, /* offset of stream for required file in *outBuffer */
|
|
size_t *outSizeProcessed, /* size of file in *outBuffer */
|
|
ISzAllocPtr allocMain,
|
|
ISzAllocPtr allocTemp);
|
|
|
|
|
|
/*
|
|
SzArEx_Open Errors:
|
|
SZ_ERROR_NO_ARCHIVE
|
|
SZ_ERROR_ARCHIVE
|
|
SZ_ERROR_UNSUPPORTED
|
|
SZ_ERROR_MEM
|
|
SZ_ERROR_CRC
|
|
SZ_ERROR_INPUT_EOF
|
|
SZ_ERROR_FAIL
|
|
*/
|
|
|
|
SRes SzArEx_Open(CSzArEx *p, ILookInStream *inStream,
|
|
ISzAllocPtr allocMain, ISzAllocPtr allocTemp);
|
|
|
|
EXTERN_C_END
|
|
|
|
#endif
|