Annotation of elwix/tools/oldlzma/SRC/7zip/Compress/LZ/BinTree/BinTree.h, revision 1.1.1.1

1.1       misho       1: // BinTree.h
                      2: 
                      3: #include "../LZInWindow.h"
                      4: #include "../IMatchFinder.h"
                      5:  
                      6: namespace BT_NAMESPACE {
                      7: 
                      8: typedef UInt32 CIndex;
                      9: const UInt32 kMaxValForNormalize = (UInt32(1) << 31) - 1;
                     10: 
                     11: class CMatchFinderBinTree: 
                     12:   public IMatchFinder,
                     13:   public IMatchFinderSetCallback,
                     14:   public CLZInWindow,
                     15:   public CMyUnknownImp
                     16: {
                     17:   UInt32 _cyclicBufferPos;
                     18:   UInt32 _cyclicBufferSize; // it must be historySize + 1
                     19:   UInt32 _matchMaxLen;
                     20:   CIndex *_hash;
                     21:   UInt32 _cutValue;
                     22: 
                     23:   CMyComPtr<IMatchFinderCallback> m_Callback;
                     24: 
                     25:   void Normalize();
                     26:   void FreeThisClassMemory();
                     27:   void FreeMemory();
                     28: 
                     29:   MY_UNKNOWN_IMP1(IMatchFinderSetCallback)
                     30: 
                     31:   STDMETHOD(Init)(ISequentialInStream *inStream);
                     32:   STDMETHOD_(void, ReleaseStream)();
                     33:   STDMETHOD(MovePos)();
                     34:   STDMETHOD_(Byte, GetIndexByte)(Int32 index);
                     35:   STDMETHOD_(UInt32, GetMatchLen)(Int32 index, UInt32 back, UInt32 limit);
                     36:   STDMETHOD_(UInt32, GetNumAvailableBytes)();
                     37:   STDMETHOD_(const Byte *, GetPointerToCurrentPos)();
                     38:   STDMETHOD(Create)(UInt32 historySize, UInt32 keepAddBufferBefore, 
                     39:       UInt32 matchMaxLen, UInt32 keepAddBufferAfter);
                     40:   STDMETHOD_(UInt32, GetLongestMatch)(UInt32 *distances);
                     41:   STDMETHOD_(void, DummyLongestMatch)();
                     42: 
                     43:   // IMatchFinderSetCallback
                     44:   STDMETHOD(SetCallback)(IMatchFinderCallback *callback);
                     45: 
                     46:   virtual void BeforeMoveBlock();
                     47:   virtual void AfterMoveBlock();
                     48: 
                     49: public:
                     50:   CMatchFinderBinTree();
                     51:   virtual ~CMatchFinderBinTree();
                     52:   void SetCutValue(UInt32 cutValue) { _cutValue = cutValue; }
                     53: };
                     54: 
                     55: }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>