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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? chmhandler.cpp

?? 壓縮解壓工具7-zip源代碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
        m_PosInFolder += numBytesToWrite;
      }
      if (fileOffset == m_PosInSection)
      {
        RINOK(OpenFile());
        m_FileIsOpen = true;
        m_CurrentIndex++;
        m_IsOk = true;
      }
    }
  }
  return WriteEmptyFiles();
}

STDMETHODIMP CChmFolderOutStream::Write(const void *data, UInt32 size, UInt32 *processedSize)
{
  return Write2(data, size, processedSize, true);
}

HRESULT CChmFolderOutStream::FlushCorrupted(UInt64 maxSize)
{
  const UInt32 kBufferSize = (1 << 10);
  Byte buffer[kBufferSize];
  for (int i = 0; i < kBufferSize; i++)
    buffer[i] = 0;
  if (maxSize > m_FolderSize)
    maxSize = m_FolderSize;
  while (m_PosInFolder < maxSize)
  {
    UInt32 size = (UInt32)MyMin(maxSize - m_PosInFolder, (UInt64)kBufferSize);
    UInt32 processedSizeLocal = 0;
    RINOK(Write2(buffer, size, &processedSizeLocal, false));
    if (processedSizeLocal == 0)
      return S_OK;
  }
  return S_OK;
}


STDMETHODIMP CHandler::Extract(const UInt32* indices, UInt32 numItems,
    Int32 _aTestMode, IArchiveExtractCallback *extractCallback)
{
  COM_TRY_BEGIN
  bool allFilesMode = (numItems == UInt32(-1));

  if (allFilesMode)
    numItems = m_Database.NewFormat ? 1:
      (m_Database.LowLevel ?
      m_Database.Items.Size():
      m_Database.Indices.Size());
  if (numItems == 0)
    return S_OK;
  bool testMode = (_aTestMode != 0);

  UInt64 currentTotalSize = 0;

  NCompress::CCopyCoder *copyCoderSpec = new NCompress::CCopyCoder();
  CMyComPtr<ICompressCoder> copyCoder = copyCoderSpec;
  UInt32 i;

  CLocalProgress *lps = new CLocalProgress;
  CMyComPtr<ICompressProgressInfo> progress = lps;
  lps->Init(extractCallback, false);

  CLimitedSequentialInStream *streamSpec = new CLimitedSequentialInStream;
  CMyComPtr<ISequentialInStream> inStream(streamSpec);
  streamSpec->SetStream(m_Stream);

  if (m_Database.LowLevel)
  {
    UInt64 currentItemSize = 0;
    UInt64 totalSize = 0;
    if (m_Database.NewFormat)
      totalSize = m_Database.NewFormatString.Length();
    else
      for (i = 0; i < numItems; i++)
        totalSize += m_Database.Items[allFilesMode ? i : indices[i]].Size;
    extractCallback->SetTotal(totalSize);
    
    for (i = 0; i < numItems; i++, currentTotalSize += currentItemSize)
    {
      currentItemSize = 0;
      lps->InSize = currentTotalSize; // Change it
      lps->OutSize = currentTotalSize;

      RINOK(lps->SetCur());
      CMyComPtr<ISequentialOutStream> realOutStream;
      Int32 askMode= testMode ?
          NArchive::NExtract::NAskMode::kTest :
          NArchive::NExtract::NAskMode::kExtract;
      Int32 index = allFilesMode ? i : indices[i];
      RINOK(extractCallback->GetStream(index, &realOutStream, askMode));

      if (m_Database.NewFormat)
      {
        if (index != 0)
          return E_FAIL;
        if (!testMode && (!realOutStream))
          continue;
        if (!testMode)
        {
          UInt32 size = m_Database.NewFormatString.Length();
          RINOK(WriteStream(realOutStream, (const char *)m_Database.NewFormatString, size));
        }
        RINOK(extractCallback->SetOperationResult(NArchive::NExtract::NOperationResult::kOK));
        continue;
      }
      const CItem &item = m_Database.Items[index];
      
      currentItemSize = item.Size;
      
      if (!testMode && (!realOutStream))
        continue;
      RINOK(extractCallback->PrepareOperation(askMode));
      if (item.Section != 0)
      {
        RINOK(extractCallback->SetOperationResult(NArchive::NExtract::NOperationResult::kUnSupportedMethod));
        continue;
      }

      if (testMode)
      {
        RINOK(extractCallback->SetOperationResult(NArchive::NExtract::NOperationResult::kOK));
        continue;
      }
      
      RINOK(m_Stream->Seek(m_Database.ContentOffset + item.Offset, STREAM_SEEK_SET, NULL));
      streamSpec->Init(item.Size);
      
      RINOK(copyCoder->Code(inStream, realOutStream, NULL, NULL, progress));
      realOutStream.Release();
      RINOK(extractCallback->SetOperationResult((copyCoderSpec->TotalSize == item.Size) ?
          NArchive::NExtract::NOperationResult::kOK:
          NArchive::NExtract::NOperationResult::kDataError));
    }
    return S_OK;
  }
  
  UInt64 lastFolderIndex = ((UInt64)0 - 1);
  for (i = 0; i < numItems; i++)
  {
    UInt32 index = allFilesMode ? i : indices[i];
    int entryIndex = m_Database.Indices[index];
    const CItem &item = m_Database.Items[entryIndex];
    UInt64 sectionIndex = item.Section;
    if (item.IsDir() || item.Size == 0)
      continue;
    if (sectionIndex == 0)
    {
      currentTotalSize += item.Size;
      continue;
    }
    const CSectionInfo &section = m_Database.Sections[(int)item.Section];
    if (section.IsLzx())
    {
      const CLzxInfo &lzxInfo = section.Methods[0].LzxInfo;
      UInt64 folderIndex = m_Database.GetFolder(index);
      if (lastFolderIndex == folderIndex)
        folderIndex++;
      lastFolderIndex = m_Database.GetLastFolder(index);
      for (; folderIndex <= lastFolderIndex; folderIndex++)
        currentTotalSize += lzxInfo.GetFolderSize();
    }
  }

  RINOK(extractCallback->SetTotal(currentTotalSize));

  NCompress::NLzx::CDecoder *lzxDecoderSpec = 0;
  CMyComPtr<ICompressCoder> lzxDecoder;
  CChmFolderOutStream *chmFolderOutStream = 0;
  CMyComPtr<ISequentialOutStream> outStream;

  currentTotalSize = 0;

  CRecordVector<bool> extractStatuses;
  for (i = 0; i < numItems;)
  {
    RINOK(extractCallback->SetCompleted(&currentTotalSize));
    UInt32 index = allFilesMode ? i : indices[i];
    i++;
    int entryIndex = m_Database.Indices[index];
    const CItem &item = m_Database.Items[entryIndex];
    UInt64 sectionIndex = item.Section;
    Int32 askMode= testMode ?
        NArchive::NExtract::NAskMode::kTest :
        NArchive::NExtract::NAskMode::kExtract;
    if (item.IsDir())
    {
      CMyComPtr<ISequentialOutStream> realOutStream;
      RINOK(extractCallback->GetStream(index, &realOutStream, askMode));
      RINOK(extractCallback->PrepareOperation(askMode));
      realOutStream.Release();
      RINOK(extractCallback->SetOperationResult(NArchive::NExtract::NOperationResult::kOK));
      continue;
    }

    lps->InSize = currentTotalSize; // Change it
    lps->OutSize = currentTotalSize;

    if (item.Size == 0 || sectionIndex == 0)
    {
      CMyComPtr<ISequentialOutStream> realOutStream;
      RINOK(extractCallback->GetStream(index, &realOutStream, askMode));
      if (!testMode && (!realOutStream))
        continue;
      RINOK(extractCallback->PrepareOperation(askMode));
      Int32 opRes = NArchive::NExtract::NOperationResult::kOK;
      if (!testMode && item.Size != 0)
      {
        RINOK(m_Stream->Seek(m_Database.ContentOffset + item.Offset, STREAM_SEEK_SET, NULL));
        streamSpec->Init(item.Size);
        RINOK(copyCoder->Code(inStream, realOutStream, NULL, NULL, progress));
        if (copyCoderSpec->TotalSize != item.Size)
          opRes = NArchive::NExtract::NOperationResult::kDataError;
      }
      realOutStream.Release();
      RINOK(extractCallback->SetOperationResult(opRes));
      currentTotalSize += item.Size;
      continue;
    }
  
    const CSectionInfo &section = m_Database.Sections[(int)sectionIndex];

    if (!section.IsLzx())
    {
      CMyComPtr<ISequentialOutStream> realOutStream;
      RINOK(extractCallback->GetStream(index, &realOutStream, askMode));
      if(!testMode && (!realOutStream))
        continue;
      RINOK(extractCallback->PrepareOperation(askMode));
      RINOK(extractCallback->SetOperationResult(NArchive::NExtract::NOperationResult::kUnSupportedMethod));
      continue;
    }

    const CLzxInfo &lzxInfo = section.Methods[0].LzxInfo;

    if (chmFolderOutStream == 0)
    {
      chmFolderOutStream = new CChmFolderOutStream;
      outStream = chmFolderOutStream;
    }

    chmFolderOutStream->Init(&m_Database, extractCallback, testMode);

    if(lzxDecoderSpec == NULL)
    {
      lzxDecoderSpec = new NCompress::NLzx::CDecoder;
      lzxDecoder = lzxDecoderSpec;
    }

    UInt64 folderIndex = m_Database.GetFolder(index);

    UInt64 compressedPos = m_Database.ContentOffset + section.Offset;
    UInt32 numDictBits = lzxInfo.GetNumDictBits();
    RINOK(lzxDecoderSpec->SetParams(numDictBits));

    const CItem *lastItem = &item;
    extractStatuses.Clear();
    extractStatuses.Add(true);

    for (;; folderIndex++)
    {
      RINOK(extractCallback->SetCompleted(&currentTotalSize));

      UInt64 startPos = lzxInfo.GetFolderPos(folderIndex);
      UInt64 finishPos = lastItem->Offset + lastItem->Size;
      UInt64 limitFolderIndex = lzxInfo.GetFolder(finishPos);

      lastFolderIndex = m_Database.GetLastFolder(index);
      UInt64 folderSize = lzxInfo.GetFolderSize();
      UInt64 unPackSize = folderSize;
      if (extractStatuses.IsEmpty())
        chmFolderOutStream->m_StartIndex = index + 1;
      else
        chmFolderOutStream->m_StartIndex = index;
      if (limitFolderIndex == folderIndex)
      {
        for (; i < numItems; i++)
        {
          UInt32 nextIndex = allFilesMode ? i : indices[i];
          int entryIndex = m_Database.Indices[nextIndex];
          const CItem &nextItem = m_Database.Items[entryIndex];
          if (nextItem.Section != sectionIndex)
            break;
          UInt64 nextFolderIndex = m_Database.GetFolder(nextIndex);
          if (nextFolderIndex != folderIndex)
            break;
          for (index++; index < nextIndex; index++)
            extractStatuses.Add(false);
          extractStatuses.Add(true);
          index = nextIndex;
          lastItem = &nextItem;
          if (nextItem.Size != 0)
            finishPos = nextItem.Offset + nextItem.Size;
          lastFolderIndex = m_Database.GetLastFolder(index);
        }
      }
      unPackSize = MyMin(finishPos - startPos, unPackSize);

      chmFolderOutStream->m_FolderSize = folderSize;
      chmFolderOutStream->m_PosInFolder = 0;
      chmFolderOutStream->m_PosInSection = startPos;
      chmFolderOutStream->m_ExtractStatuses = &extractStatuses;
      chmFolderOutStream->m_NumFiles = extractStatuses.Size();
      chmFolderOutStream->m_CurrentIndex = 0;
      try
      {
        UInt64 startBlock = lzxInfo.GetBlockIndexFromFolderIndex(folderIndex);
        const CResetTable &rt = lzxInfo.ResetTable;
        UInt32 numBlocks = (UInt32)rt.GetNumBlocks(unPackSize);
        for (UInt32 b = 0; b < numBlocks; b++)
        {
          UInt64 completedSize = currentTotalSize + chmFolderOutStream->m_PosInSection - startPos;
          RINOK(extractCallback->SetCompleted(&completedSize));
          UInt64 bCur = startBlock + b;
          if (bCur >= rt.ResetOffsets.Size())
            return E_FAIL;
          UInt64 offset = rt.ResetOffsets[(int)bCur];
          UInt64 compressedSize;
          rt.GetCompressedSizeOfBlock(bCur, compressedSize);
          UInt64 rem = finishPos - chmFolderOutStream->m_PosInSection;
          if (rem > rt.BlockSize)
            rem = rt.BlockSize;
          RINOK(m_Stream->Seek(compressedPos + offset, STREAM_SEEK_SET, NULL));
          streamSpec->SetStream(m_Stream);
          streamSpec->Init(compressedSize);
          lzxDecoderSpec->SetKeepHistory(b > 0);
          HRESULT res = lzxDecoder->Code(inStream, outStream, NULL, &rem, NULL);
          if (res != S_OK)
          {
            if (res != S_FALSE)
              return res;
            throw 1;
          }
        }
      }
      catch(...)
      {
        RINOK(chmFolderOutStream->FlushCorrupted(unPackSize));
      }
      currentTotalSize += folderSize;
      if (folderIndex == lastFolderIndex)
        break;
      extractStatuses.Clear();
    }
  }
  return S_OK;
  COM_TRY_END
}

STDMETHODIMP CHandler::GetNumberOfItems(UInt32 *numItems)
{
    *numItems = m_Database.NewFormat ? 1:
      (m_Database.LowLevel ?
      m_Database.Items.Size():
      m_Database.Indices.Size());
  return S_OK;
}

}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区av在线播放| 视频一区中文字幕| 韩国视频一区二区| 欧美在线小视频| 欧美激情资源网| 另类调教123区| 欧美三级在线视频| 日韩美女视频一区| 国产99久久久国产精品免费看| 欧美精品少妇一区二区三区| 综合激情成人伊人| 盗摄精品av一区二区三区| 欧美www视频| 日韩成人一级大片| 欧美日韩性生活| 亚洲素人一区二区| 不卡的av中国片| 国产精品素人视频| 国产麻豆精品久久一二三| 日韩欧美国产午夜精品| 天堂在线一区二区| 欧美视频在线不卡| 伊人色综合久久天天人手人婷| 成人美女视频在线看| 久久精品一区二区三区四区| 久热成人在线视频| 日韩一级片网址| 日韩黄色免费网站| 欧美人伦禁忌dvd放荡欲情| 亚洲午夜一区二区| 日本久久电影网| 亚洲免费高清视频在线| 色哟哟一区二区三区| 亚洲素人一区二区| 色哟哟一区二区三区| 一区二区三区中文免费| 在线观看日韩精品| 亚洲韩国精品一区| 欧美日本一道本在线视频| 亚洲第一av色| 在线综合+亚洲+欧美中文字幕| 天堂成人免费av电影一区| 制服.丝袜.亚洲.中文.综合| 奇米色777欧美一区二区| 91精品在线免费观看| 免费在线一区观看| 久久亚洲二区三区| 国产精品一区二区久久精品爱涩| 久久久久久久电影| 懂色av中文一区二区三区| 国产精品国产三级国产有无不卡| 成人avav影音| 亚洲免费观看高清在线观看| 欧美亚洲自拍偷拍| 日本午夜精品视频在线观看| 欧美成人福利视频| 国产aⅴ精品一区二区三区色成熟| 欧美国产日本视频| 日本乱人伦aⅴ精品| 日日骚欧美日韩| 精品日韩在线观看| 成人听书哪个软件好| 一区二区三区中文免费| 6080午夜不卡| 国产一二三精品| 亚洲欧洲一区二区在线播放| 91久久一区二区| 日韩影院在线观看| 久久久久久久久蜜桃| 成人av小说网| 亚洲一区视频在线观看视频| 91精品免费观看| 国产精品综合久久| 亚洲精品菠萝久久久久久久| 欧美日韩性生活| 国产另类ts人妖一区二区| 亚洲丝袜另类动漫二区| 欧美日本乱大交xxxxx| 国产一区视频在线看| 亚洲天堂久久久久久久| 91精品国产一区二区三区香蕉 | 欧美电影免费观看高清完整版在| 国产麻豆成人精品| 亚洲综合免费观看高清完整版在线| 欧美另类z0zxhd电影| 国产电影一区在线| 亚洲小说欧美激情另类| 久久亚洲一区二区三区明星换脸| 97国产精品videossex| 亚洲国产精品嫩草影院| xf在线a精品一区二区视频网站| 91亚洲国产成人精品一区二区三 | 久久久久久久电影| 在线观看一区二区精品视频| 九九**精品视频免费播放| 国产精品色婷婷久久58| 91.成人天堂一区| 成人福利视频网站| 日本美女一区二区| 中文字幕一区日韩精品欧美| 在线综合+亚洲+欧美中文字幕| 不卡一区在线观看| 麻豆精品在线视频| 一区二区三区欧美久久| 久久免费午夜影院| 91精品国产手机| 91亚洲国产成人精品一区二区三| 玖玖九九国产精品| 亚洲国产sm捆绑调教视频| 欧美激情综合在线| 日韩欧美一区二区不卡| 欧美综合视频在线观看| 成人app在线观看| 麻豆成人综合网| 亚洲超碰97人人做人人爱| 国产精品久久久久久久久免费桃花| 欧美一级高清大全免费观看| 色狠狠综合天天综合综合| 福利视频网站一区二区三区| 久久精品国产亚洲一区二区三区| 亚洲一级在线观看| 国产精品卡一卡二| 久久久久久久国产精品影院| 欧美一二三四在线| 在线观看日产精品| caoporn国产精品| 国产一区二区三区综合| 男人操女人的视频在线观看欧美| 亚洲一卡二卡三卡四卡 | 久久午夜羞羞影院免费观看| 欧美精品第一页| 在线亚洲免费视频| av电影天堂一区二区在线 | 亚洲成av人片| 一卡二卡欧美日韩| 1区2区3区国产精品| 日本一区二区三区免费乱视频 | 日韩视频在线观看一区二区| 欧美日韩中文字幕精品| 在线看日本不卡| 色狠狠综合天天综合综合| 99re热视频精品| 91免费版pro下载短视频| 成人免费看黄yyy456| 高清不卡在线观看av| 国产精品自拍av| 国产在线精品免费| 国产一区二区美女诱惑| 国内精品视频一区二区三区八戒 | 一区二区三区视频在线观看| 在线观看亚洲精品视频| 99riav久久精品riav| 国产99久久精品| 老鸭窝一区二区久久精品| 日韩福利电影在线观看| 日韩不卡一区二区三区| 奇米影视一区二区三区小说| 蜜臀av亚洲一区中文字幕| 亚洲一区在线观看网站| 国产精品国产三级国产aⅴ中文 | 欧美日韩大陆一区二区| 亚洲宅男天堂在线观看无病毒| 成熟亚洲日本毛茸茸凸凹| 精品一区二区免费| 日韩欧美色综合网站| 麻豆精品一区二区综合av| 裸体一区二区三区| 欧美日韩国产高清一区二区 | 欧美一级片在线| 亚洲综合自拍偷拍| 成人综合在线观看| www精品美女久久久tv| 久久精品国产亚洲高清剧情介绍 | 青青国产91久久久久久| 欧美一级欧美三级在线观看| 麻豆精品一区二区三区| 26uuu精品一区二区在线观看| 日韩国产欧美在线播放| 91精品在线观看入口| 视频一区在线播放| 欧美久久久久久久久久| 天堂一区二区在线| 欧美三级三级三级爽爽爽| 亚洲欧美视频一区| 99久久er热在这里只有精品15| 国产日产欧产精品推荐色 | 一区精品在线播放| 99精品视频一区二区| 亚洲三级在线免费| 99riav久久精品riav| 一级中文字幕一区二区| 91九色最新地址| 日韩精品欧美精品| 欧美一区三区四区| 久久99精品国产麻豆婷婷洗澡| 日韩三级av在线播放| 国产999精品久久久久久| 亚洲人成网站在线| 欧美在线看片a免费观看| 日产精品久久久久久久性色|