亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? lzmadecoder.h

?? lzma 壓縮 4.06version
?? H
字號(hào):
// LZMA/Decoder.h

#ifndef __LZMA_DECODER_H
#define __LZMA_DECODER_H

#include "../../../Common/MyCom.h"
#include "../../../Common/Alloc.h"
#include "../../ICoder.h"
#include "../LZ/LZOutWindow.h"
#include "../RangeCoder/RangeCoderBitTree.h"

#include "LZMA.h"

namespace NCompress {
namespace NLZMA {

typedef NRangeCoder::CBitDecoder<kNumMoveBits> CMyBitDecoder;

class CLiteralDecoder2
{
  CMyBitDecoder _decoders[0x300];
public:
  void Init()
  {
    for (int i = 0; i < 0x300; i++)
      _decoders[i].Init();
  }
  Byte DecodeNormal(NRangeCoder::CDecoder *rangeDecoder)
  {
    UInt32 symbol = 1;
    RC_INIT_VAR
    do
    {
      // symbol = (symbol << 1) | _decoders[0][symbol].Decode(rangeDecoder);
      RC_GETBIT(kNumMoveBits, _decoders[symbol].Prob, symbol)
    }
    while (symbol < 0x100);
    RC_FLUSH_VAR
    return (Byte)symbol;
  }
  Byte DecodeWithMatchByte(NRangeCoder::CDecoder *rangeDecoder, Byte matchByte)
  {
    UInt32 symbol = 1;
    RC_INIT_VAR
    do
    {
      UInt32 matchBit = (matchByte >> 7) & 1;
      matchByte <<= 1;
      // UInt32 bit = _decoders[1 + matchBit][symbol].Decode(rangeDecoder);
      // symbol = (symbol << 1) | bit;
      UInt32 bit;
      RC_GETBIT2(kNumMoveBits, _decoders[((1 + matchBit) << 8) + symbol].Prob, symbol, 
          bit = 0, bit = 1)
      if (matchBit != bit)
      {
        while (symbol < 0x100)
        {
          // symbol = (symbol << 1) | _decoders[0][symbol].Decode(rangeDecoder);
          RC_GETBIT(kNumMoveBits, _decoders[symbol].Prob, symbol)
        }
        break;
      }
    }
    while (symbol < 0x100);
    RC_FLUSH_VAR
    return (Byte)symbol;
  }
};

class CLiteralDecoder
{
  CLiteralDecoder2 *_coders;
  int _numPrevBits;
  int _numPosBits;
  UInt32 _posMask;
public:
  CLiteralDecoder(): _coders(0) {}
  ~CLiteralDecoder()  { Free(); }
  void Free()
  { 
    MyFree(_coders);
    _coders = 0;
  }
  bool Create(int numPosBits, int numPrevBits)
  {
    if (_coders == 0 || (numPosBits + numPrevBits) != 
        (_numPrevBits + _numPosBits) )
    {
      Free();
      UInt32 numStates = 1 << (numPosBits + numPrevBits);
      _coders = (CLiteralDecoder2 *)MyAlloc(numStates * sizeof(CLiteralDecoder2));
    }
    _numPosBits = numPosBits;
    _posMask = (1 << numPosBits) - 1;
    _numPrevBits = numPrevBits;
    return (_coders != 0);
  }
  void Init()
  {
    UInt32 numStates = 1 << (_numPrevBits + _numPosBits);
    for (UInt32 i = 0; i < numStates; i++)
      _coders[i].Init();
  }
  UInt32 GetState(UInt32 pos, Byte prevByte) const
    { return ((pos & _posMask) << _numPrevBits) + (prevByte >> (8 - _numPrevBits)); }
  Byte DecodeNormal(NRangeCoder::CDecoder *rangeDecoder, UInt32 pos, Byte prevByte)
    { return _coders[GetState(pos, prevByte)].DecodeNormal(rangeDecoder); }
  Byte DecodeWithMatchByte(NRangeCoder::CDecoder *rangeDecoder, UInt32 pos, Byte prevByte, Byte matchByte)
    { return _coders[GetState(pos, prevByte)].DecodeWithMatchByte(rangeDecoder, matchByte); }
};

namespace NLength {

class CDecoder
{
  CMyBitDecoder _choice;
  NRangeCoder::CBitTreeDecoder<kNumMoveBits, kNumLowBits>  _lowCoder[kNumPosStatesMax];
  CMyBitDecoder _choice2;
  NRangeCoder::CBitTreeDecoder<kNumMoveBits, kNumMidBits>  _midCoder[kNumPosStatesMax];
  NRangeCoder::CBitTreeDecoder<kNumMoveBits, kNumHighBits> _highCoder; 
public:
  void Init(UInt32 numPosStates)
  {
    _choice.Init();
    for (UInt32 posState = 0; posState < numPosStates; posState++)
    {
      _lowCoder[posState].Init();
      _midCoder[posState].Init();
    }
    _choice2.Init();
    _highCoder.Init();
  }
  UInt32 Decode(NRangeCoder::CDecoder *rangeDecoder, UInt32 posState)
  {
    if(_choice.Decode(rangeDecoder) == 0)
      return _lowCoder[posState].Decode(rangeDecoder);
    if(_choice2.Decode(rangeDecoder) == 0)
      return kNumLowSymbols + _midCoder[posState].Decode(rangeDecoder);
    return kNumLowSymbols + kNumMidSymbols + _highCoder.Decode(rangeDecoder);
  }
};

}

class CDecoder: 
  public ICompressCoder,
  public ICompressSetDecoderProperties,
  public ICompressSetInStream,
  public ICompressSetOutStreamSize,
  public ISequentialInStream,
  public CMyUnknownImp
{
  CLZOutWindow _outWindowStream;
  NRangeCoder::CDecoder _rangeDecoder;

  CMyBitDecoder _isMatch[kNumStates][NLength::kNumPosStatesMax];
  CMyBitDecoder _isRep[kNumStates];
  CMyBitDecoder _isRepG0[kNumStates];
  CMyBitDecoder _isRepG1[kNumStates];
  CMyBitDecoder _isRepG2[kNumStates];
  CMyBitDecoder _isRep0Long[kNumStates][NLength::kNumPosStatesMax];

  NRangeCoder::CBitTreeDecoder<kNumMoveBits, kNumPosSlotBits> _posSlotDecoder[kNumLenToPosStates];

  CMyBitDecoder _posDecoders[kNumFullDistances - kEndPosModelIndex];
  NRangeCoder::CBitTreeDecoder<kNumMoveBits, kNumAlignBits> _posAlignDecoder;
  
  NLength::CDecoder _lenDecoder;
  NLength::CDecoder _repMatchLenDecoder;

  CLiteralDecoder _literalDecoder;

  UInt32 _dictionarySizeCheck;
  
  UInt32 _posStateMask;

  ///////////////////
  // State
  UInt64 _outSize;
  UInt64 _nowPos64;
  UInt32 _reps[4];
  CState _state;
  bool _previousIsMatch;
  Int32 _remainLen; // -1 means end of stream.


  HRESULT CodeSpec(Byte *buffer, UInt32 size);
public:
  MY_UNKNOWN_IMP4(
      ICompressSetDecoderProperties, 
      ICompressSetInStream, 
      ICompressSetOutStreamSize, 
      ISequentialInStream)

  void Init();
  void ReleaseStreams()
  {
    _outWindowStream.ReleaseStream();
    _rangeDecoder.ReleaseStream();
  }

  class CDecoderFlusher
  {
    CDecoder *_decoder;
  public:
    bool NeedFlush;
    CDecoderFlusher(CDecoder *decoder): 
          _decoder(decoder), NeedFlush(true) {}
    ~CDecoderFlusher() 
    { 
      if (NeedFlush)
        _decoder->Flush();
      _decoder->ReleaseStreams(); 
    }
  };

  HRESULT Flush() {  return _outWindowStream.Flush(); }  

  STDMETHOD(CodeReal)(ISequentialInStream *inStream,
      ISequentialOutStream *outStream, const UInt64 *inSize, const UInt64 *outSize,
      ICompressProgressInfo *progress);
  
  STDMETHOD(Code)(ISequentialInStream *inStream,
      ISequentialOutStream *outStream, const UInt64 *inSize, const UInt64 *outSize,
      ICompressProgressInfo *progress);

  // ICompressSetDecoderProperties
  STDMETHOD(SetDecoderProperties)(ISequentialInStream *inStream);

  STDMETHOD(GetInStreamProcessedSize)(UInt64 *value);

  STDMETHOD(SetInStream)(ISequentialInStream *inStream);
  STDMETHOD(SetOutStreamSize)(const UInt64 *outSize);
  STDMETHOD(Read)(void *data, UInt32 size, UInt32 *processedSize);
  STDMETHOD(ReadPart)(void *data, UInt32 size, UInt32 *processedSize);

  virtual ~CDecoder() {}
};

}}

#endif

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本免费新一区视频| 久久免费美女视频| 日韩欧美成人激情| 欧美—级在线免费片| 亚洲日本青草视频在线怡红院| 亚洲精品老司机| 日本视频一区二区三区| 国产精品自拍三区| 一本色道a无线码一区v| 欧美一区二区三区免费视频| 国产亚洲综合在线| 亚洲国产欧美在线人成| 国产精品一区二区三区乱码| 一本到一区二区三区| 欧美一级在线视频| 国产精品福利在线播放| 偷拍日韩校园综合在线| 国产suv精品一区二区6| 欧美亚洲国产一区在线观看网站 | 中文字幕一区二区三区在线播放| 一区二区三区蜜桃| 国产精品综合二区| 欧美日韩一区国产| 国产蜜臀av在线一区二区三区| 亚洲制服丝袜av| 国产91在线观看| 51午夜精品国产| 国产精品第13页| 精品中文字幕一区二区| 欧美亚洲国产bt| 中文字幕在线不卡| 捆绑调教美女网站视频一区| 色av成人天堂桃色av| 久久久久国产一区二区三区四区| 亚洲国产综合91精品麻豆| 高清不卡一二三区| 日韩一级二级三级| 亚洲综合一区在线| 99精品欧美一区二区蜜桃免费| 日韩欧美三级在线| 亚洲一区成人在线| 91在线一区二区三区| 久久久777精品电影网影网 | 精品国产乱码91久久久久久网站| 亚洲无人区一区| 一本大道久久a久久综合| 国产丝袜美腿一区二区三区| 蜜臀a∨国产成人精品| 欧美日韩大陆在线| 一级日本不卡的影视| 成人a级免费电影| 久久久影视传媒| 久久精品国产久精国产| 欧美色视频在线| 亚洲欧美成人一区二区三区| 成人性生交大片免费看中文| 久久影视一区二区| 美国毛片一区二区| 欧美精品日韩一本| 亚洲综合在线观看视频| hitomi一区二区三区精品| 久久久www成人免费无遮挡大片| 日韩国产精品久久久| 欧美日韩国产综合久久| 亚洲国产欧美日韩另类综合| 在线视频一区二区三区| 亚洲激情在线激情| 色欧美88888久久久久久影院| 综合婷婷亚洲小说| 99精品偷自拍| 亚洲天堂精品在线观看| 97se亚洲国产综合自在线观| 中文字幕一区二区在线播放| 成人h动漫精品一区二| 中文字幕一区在线观看视频| 99久久久久久99| 亚洲私人黄色宅男| 91精品91久久久中77777| 亚洲精品欧美综合四区| 91黄色激情网站| 亚洲一区二区三区四区五区黄| 精品污污网站免费看| 视频在线观看一区二区三区| 欧美一区二区三区婷婷月色| 久久疯狂做爰流白浆xx| 久久婷婷一区二区三区| 丁香天五香天堂综合| 国产精品人人做人人爽人人添| 成人国产一区二区三区精品| 国产精品美日韩| 色域天天综合网| 亚洲成人一区二区| 欧美一级二级三级乱码| 国产资源在线一区| 国产精品三级电影| 日本久久精品电影| 丝袜美腿一区二区三区| www国产成人| 99久久国产综合精品麻豆| 一区二区三区美女视频| 日韩一卡二卡三卡四卡| 国产一区二区三区四| 国产精品伦理一区二区| 欧美亚洲自拍偷拍| 久久精品72免费观看| 亚洲国产精品av| 欧美色综合影院| 国产在线精品免费| 国产精品久久久久久户外露出 | 日韩综合在线视频| 久久久久久影视| 色综合天天综合给合国产| 天天色 色综合| 久久精品夜色噜噜亚洲aⅴ| 91一区在线观看| 男人的天堂久久精品| 国产精品视频免费看| 欧美日本一区二区| 国产激情精品久久久第一区二区 | 欧美日韩国产a| 国产不卡高清在线观看视频| 一区二区三区**美女毛片| 精品人在线二区三区| 99精品视频在线播放观看| 琪琪一区二区三区| 中文字幕视频一区| 欧美一区二区三区日韩视频| 不卡电影一区二区三区| 另类小说一区二区三区| 亚洲色图丝袜美腿| 精品国产乱码久久久久久老虎| 色综合久久综合网97色综合 | 久久久国产综合精品女国产盗摄| 色综合 综合色| 国产黑丝在线一区二区三区| 亚洲高清三级视频| 国产精品国产三级国产专播品爱网| 在线成人免费视频| www.欧美色图| 国产尤物一区二区在线| 五月婷婷综合网| 日韩美女精品在线| 久久精品日产第一区二区三区高清版 | 欧洲精品中文字幕| 国产精一区二区三区| 日欧美一区二区| 亚洲综合精品久久| 国产精品人成在线观看免费| 成人av在线资源| 精品一区二区综合| 亚洲第一会所有码转帖| 国产精品国产精品国产专区不蜜 | 五月婷婷综合在线| 亚洲欧美日韩一区| 国产欧美一区二区三区在线看蜜臀| 欧美男男青年gay1069videost | 亚洲精品久久久蜜桃| 中文字幕av一区二区三区高| 日韩三级视频在线观看| 欧美日韩一区二区三区四区| 91免费看`日韩一区二区| 国产精品1区二区.| 激情综合五月婷婷| 奇米777欧美一区二区| 天天综合网天天综合色| 亚洲国产综合色| 亚洲精品日产精品乱码不卡| 亚洲欧美自拍偷拍| 国产精品免费视频一区| 久久精品人人做人人综合| 精品久久久久久最新网址| 91麻豆精品国产91久久久| 欧美午夜理伦三级在线观看| 在线观看免费一区| 欧美丝袜自拍制服另类| 在线观看日韩电影| 欧美亚洲综合网| 欧美日韩三级视频| 欧美日韩久久久一区| 欧美日韩免费视频| 欧美三级一区二区| 欧美日韩高清在线播放| 538在线一区二区精品国产| 7777精品伊人久久久大香线蕉经典版下载 | 日韩精品在线看片z| 欧美一个色资源| 日韩欧美中文字幕精品| 精品美女在线播放| 久久亚洲一级片| 日本一区二区免费在线| 国产精品久久久久久久浪潮网站| 中文字幕在线观看不卡| 亚洲欧美日本在线| 亚洲综合视频在线| 日韩av一级电影| 精久久久久久久久久久| 国产99一区视频免费| 94-欧美-setu| 欧美日韩在线播放三区四区| 欧美精品乱人伦久久久久久|