goat3d
diff libs/openctm/liblzma/LzFind.h @ 14:188c697b3b49
- added a document describing the goat3d file format chunk hierarchy
- started an alternative XML-based file format
- added the openctm library
author | John Tsiombikas <nuclear@member.fsf.org> |
---|---|
date | Thu, 26 Sep 2013 04:47:05 +0300 |
parents | |
children |
line diff
1.1 --- /dev/null Thu Jan 01 00:00:00 1970 +0000 1.2 +++ b/libs/openctm/liblzma/LzFind.h Thu Sep 26 04:47:05 2013 +0300 1.3 @@ -0,0 +1,107 @@ 1.4 +/* LzFind.h -- Match finder for LZ algorithms 1.5 +2008-10-04 : Igor Pavlov : Public domain */ 1.6 + 1.7 +#ifndef __LZFIND_H 1.8 +#define __LZFIND_H 1.9 + 1.10 +#include "Types.h" 1.11 + 1.12 +typedef UInt32 CLzRef; 1.13 + 1.14 +typedef struct _CMatchFinder 1.15 +{ 1.16 + Byte *buffer; 1.17 + UInt32 pos; 1.18 + UInt32 posLimit; 1.19 + UInt32 streamPos; 1.20 + UInt32 lenLimit; 1.21 + 1.22 + UInt32 cyclicBufferPos; 1.23 + UInt32 cyclicBufferSize; /* it must be = (historySize + 1) */ 1.24 + 1.25 + UInt32 matchMaxLen; 1.26 + CLzRef *hash; 1.27 + CLzRef *son; 1.28 + UInt32 hashMask; 1.29 + UInt32 cutValue; 1.30 + 1.31 + Byte *bufferBase; 1.32 + ISeqInStream *stream; 1.33 + int streamEndWasReached; 1.34 + 1.35 + UInt32 blockSize; 1.36 + UInt32 keepSizeBefore; 1.37 + UInt32 keepSizeAfter; 1.38 + 1.39 + UInt32 numHashBytes; 1.40 + int directInput; 1.41 + int btMode; 1.42 + /* int skipModeBits; */ 1.43 + int bigHash; 1.44 + UInt32 historySize; 1.45 + UInt32 fixedHashSize; 1.46 + UInt32 hashSizeSum; 1.47 + UInt32 numSons; 1.48 + SRes result; 1.49 + UInt32 crc[256]; 1.50 +} CMatchFinder; 1.51 + 1.52 +#define Inline_MatchFinder_GetPointerToCurrentPos(p) ((p)->buffer) 1.53 +#define Inline_MatchFinder_GetIndexByte(p, index) ((p)->buffer[(Int32)(index)]) 1.54 + 1.55 +#define Inline_MatchFinder_GetNumAvailableBytes(p) ((p)->streamPos - (p)->pos) 1.56 + 1.57 +int MatchFinder_NeedMove(CMatchFinder *p); 1.58 +Byte *MatchFinder_GetPointerToCurrentPos(CMatchFinder *p); 1.59 +void MatchFinder_MoveBlock(CMatchFinder *p); 1.60 +void MatchFinder_ReadIfRequired(CMatchFinder *p); 1.61 + 1.62 +void MatchFinder_Construct(CMatchFinder *p); 1.63 + 1.64 +/* Conditions: 1.65 + historySize <= 3 GB 1.66 + keepAddBufferBefore + matchMaxLen + keepAddBufferAfter < 511MB 1.67 +*/ 1.68 +int MatchFinder_Create(CMatchFinder *p, UInt32 historySize, 1.69 + UInt32 keepAddBufferBefore, UInt32 matchMaxLen, UInt32 keepAddBufferAfter, 1.70 + ISzAlloc *alloc); 1.71 +void MatchFinder_Free(CMatchFinder *p, ISzAlloc *alloc); 1.72 +void MatchFinder_Normalize3(UInt32 subValue, CLzRef *items, UInt32 numItems); 1.73 +void MatchFinder_ReduceOffsets(CMatchFinder *p, UInt32 subValue); 1.74 + 1.75 +UInt32 * GetMatchesSpec1(UInt32 lenLimit, UInt32 curMatch, UInt32 pos, const Byte *buffer, CLzRef *son, 1.76 + UInt32 _cyclicBufferPos, UInt32 _cyclicBufferSize, UInt32 _cutValue, 1.77 + UInt32 *distances, UInt32 maxLen); 1.78 + 1.79 +/* 1.80 +Conditions: 1.81 + Mf_GetNumAvailableBytes_Func must be called before each Mf_GetMatchLen_Func. 1.82 + Mf_GetPointerToCurrentPos_Func's result must be used only before any other function 1.83 +*/ 1.84 + 1.85 +typedef void (*Mf_Init_Func)(void *object); 1.86 +typedef Byte (*Mf_GetIndexByte_Func)(void *object, Int32 index); 1.87 +typedef UInt32 (*Mf_GetNumAvailableBytes_Func)(void *object); 1.88 +typedef const Byte * (*Mf_GetPointerToCurrentPos_Func)(void *object); 1.89 +typedef UInt32 (*Mf_GetMatches_Func)(void *object, UInt32 *distances); 1.90 +typedef void (*Mf_Skip_Func)(void *object, UInt32); 1.91 + 1.92 +typedef struct _IMatchFinder 1.93 +{ 1.94 + Mf_Init_Func Init; 1.95 + Mf_GetIndexByte_Func GetIndexByte; 1.96 + Mf_GetNumAvailableBytes_Func GetNumAvailableBytes; 1.97 + Mf_GetPointerToCurrentPos_Func GetPointerToCurrentPos; 1.98 + Mf_GetMatches_Func GetMatches; 1.99 + Mf_Skip_Func Skip; 1.100 +} IMatchFinder; 1.101 + 1.102 +void MatchFinder_CreateVTable(CMatchFinder *p, IMatchFinder *vTable); 1.103 + 1.104 +void MatchFinder_Init(CMatchFinder *p); 1.105 +UInt32 Bt3Zip_MatchFinder_GetMatches(CMatchFinder *p, UInt32 *distances); 1.106 +UInt32 Hc3Zip_MatchFinder_GetMatches(CMatchFinder *p, UInt32 *distances); 1.107 +void Bt3Zip_MatchFinder_Skip(CMatchFinder *p, UInt32 num); 1.108 +void Hc3Zip_MatchFinder_Skip(CMatchFinder *p, UInt32 num); 1.109 + 1.110 +#endif