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

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

?? udfin.cpp

?? 壓縮解壓工具7-zip源代碼
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
  if (extendedAttrLen > size - pos)
    return S_FALSE;
  /*
  if (extendedAttrLen != 16)
  {
    if (extendedAttrLen < 24)
      return S_FALSE;
    CTag attrTag;
    RINOK(attrTag.Parse(p + pos, size));
    if (attrTag.Id != DESC_TYPE_ExtendedAttrHeader)
      return S_FALSE;
    // UInt32 implAttrLocation = Get32(p + pos + 16);
    // UInt32 applicationlAttrLocation = Get32(p + pos + 20);
  }
  */
  pos += extendedAttrLen;

  int desctType = item.IcbTag.GetDescriptorType();
  if (allocDescriptorsLen > size - pos)
    return S_FALSE;
  if (desctType == ICB_DESC_TYPE_INLINE)
  {
    item.IsInline = true;
    item.InlineData.SetCapacity(allocDescriptorsLen);
    memcpy(item.InlineData, p + pos, allocDescriptorsLen);
  }
  else
  {
    item.IsInline = false;
    if (desctType != ICB_DESC_TYPE_SHORT && desctType != ICB_DESC_TYPE_LONG)
      return S_FALSE;
    for (UInt32 i = 0; i < allocDescriptorsLen;)
    {
      CMyExtent e;
      if (desctType == ICB_DESC_TYPE_SHORT)
      {
        if (i + 8 > allocDescriptorsLen)
          return S_FALSE;
        CShortAllocDesc sad;
        sad.Parse(p + pos + i);
        e.Pos = sad.Pos;
        e.Len = sad.Len;
        e.PartitionRef = lad.Location.PartitionRef;
        i += 8;
      }
      else
      {
        if (i + 16 > allocDescriptorsLen)
          return S_FALSE;
        CLongAllocDesc ladNew;
        ladNew.Parse(p + pos + i);
        e.Pos = ladNew.Location.Pos;
        e.PartitionRef = ladNew.Location.PartitionRef;
        e.Len = ladNew.Len;
        i += 16;
      }
      item.Extents.Add(e);
    }
  }

  if (item.IcbTag.IsDir())
  {
    if (!item.CheckChunkSizes() || !CheckItemExtents(volIndex, item))
      return S_FALSE;
    CByteBuffer buf;
    RINOK(ReadFromFile(volIndex, item, buf));
    item.Size = 0;
    item.Extents.ClearAndFree();
    item.InlineData.Free();

    const Byte *p = buf;
    size = buf.GetCapacity();
    size_t processedTotal = 0;
    for (; processedTotal < size;)
    {
      size_t processedCur;
      CFileId fileId;
      RINOK(fileId.Parse(p + processedTotal, size - processedTotal, processedCur));
      if (!fileId.IsItLinkParent())
      {
        CFile file;
        // file.FileVersion = fileId.FileVersion;
        // file.FileCharacteristics = fileId.FileCharacteristics;
        // file.ImplUse = fileId.ImplUse;
        file.Id = fileId.Id;
        
        _fileNameLengthTotal += file.Id.Data.GetCapacity();
        if (_fileNameLengthTotal > kFileNameLengthTotalMax)
          return S_FALSE;
        
        item.SubFiles.Add(Files.Size());
        if (Files.Size() > kNumFilesMax)
          return S_FALSE;
        Files.Add(file);
        RINOK(ReadFileItem(volIndex, fsIndex, fileId.Icb, numRecurseAllowed));
      }
      processedTotal += processedCur;
    }
  }
  else
  {
    if ((UInt32)item.Extents.Size() > kNumExtentsMax - _numExtents)
      return S_FALSE;
    _numExtents += item.Extents.Size();

    if (item.InlineData.GetCapacity() > kInlineExtentsSizeMax - _inlineExtentsSize)
      return S_FALSE;
    _inlineExtentsSize += item.InlineData.GetCapacity();
  }

  return S_OK;
}

HRESULT CInArchive::FillRefs(CFileSet &fs, int fileIndex, int parent, int numRecurseAllowed)
{
  if (_numRefs % 10000 == 0)
  {
    RINOK(_progress->SetCompleted());
  }
  if (numRecurseAllowed-- == 0)
    return S_FALSE;
  if (_numRefs >= kNumRefsMax)
    return S_FALSE;
  _numRefs++;
  CRef ref;
  ref.FileIndex = fileIndex;
  ref.Parent = parent;
  parent = fs.Refs.Size();
  fs.Refs.Add(ref);
  const CItem &item = Items[Files[fileIndex].ItemIndex];
  for (int i = 0; i < item.SubFiles.Size(); i++)
  {
    RINOK(FillRefs(fs, item.SubFiles[i], parent, numRecurseAllowed));
  }
  return S_OK;
}

HRESULT CInArchive::Open2()
{
  Clear();

  UInt64 fileSize;
  RINOK(_stream->Seek(0, STREAM_SEEK_END, &fileSize));

  const int kSecLogSizeMax = 11;
  const int kSecLogSizeMin = 8;
  Byte buf[1 << kSecLogSizeMax];
  for (SecLogSize = kSecLogSizeMax; SecLogSize >= kSecLogSizeMin; SecLogSize -= 3)
  {
    Int32 bufSize = 1 << SecLogSize;
    if (bufSize > fileSize)
      return S_FALSE;
    RINOK(_stream->Seek(-bufSize, STREAM_SEEK_END, NULL));
    RINOK(ReadStream_FALSE(_stream, buf, bufSize));
    CTag tag;
    if (tag.Parse(buf, bufSize) == S_OK)
      if (tag.Id == DESC_TYPE_AnchorVolPtr)
        break;
  }
  if (SecLogSize < kSecLogSizeMin)
    return S_FALSE;

  CExtent extentVDS;
  extentVDS.Parse(buf + 16);

  for (UInt32 location = extentVDS.Pos; ; location++)
  {
    size_t bufSize = 1 << SecLogSize;
    size_t pos = 0;
    RINOK(_stream->Seek((UInt64)location << SecLogSize, STREAM_SEEK_SET, NULL));
    RINOK(ReadStream_FALSE(_stream, buf, bufSize));
    CTag tag;
    RINOK(tag.Parse(buf + pos, bufSize - pos));
    if (tag.Id == DESC_TYPE_Terminating)
      break;
    if (tag.Id == DESC_TYPE_Partition)
    {
      if (Partitions.Size() >= kNumPartitionsMax)
        return S_FALSE;
      CPartition partition;
      // UInt32 volDescSeqNumer = Get32(buf + 16);
      // partition.Flags = Get16(buf + 20);
      partition.Number = Get16(buf + 22);
      // partition.ContentsId.Parse(buf + 24);
      
      // memcpy(partition.ContentsUse, buf + 56, sizeof(partition.ContentsUse));
      // ContentsUse is Partition Header Description.

      // partition.AccessType = Get32(buf + 184);
      partition.Pos = Get32(buf + 188);
      partition.Len = Get32(buf + 192);
      // partition.ImplId.Parse(buf + 196);
      // memcpy(partition.ImplUse, buf + 228, sizeof(partition.ImplUse));

      Partitions.Add(partition);
    }
    else if (tag.Id == DESC_TYPE_LogicalVol)
    {
      if (LogVols.Size() >= kNumLogVolumesMax)
        return S_FALSE;
      CLogVol vol;
      vol.Id.Parse(buf + 84);
      vol.BlockSize = Get32(buf + 212);
      // vol.DomainId.Parse(buf + 216);

      if (vol.BlockSize < 512 || vol.BlockSize > ((UInt32)1 << 30))
        return S_FALSE;
      
      // memcpy(vol.ContentsUse, buf + 248, sizeof(vol.ContentsUse));
      vol.FileSetLocation.Parse(buf + 248);

      // UInt32 mapTableLength = Get32(buf + 264);
      UInt32 numPartitionMaps = Get32(buf + 268);
      if (numPartitionMaps > kNumPartitionsMax)
        return S_FALSE;
      // vol.ImplId.Parse(buf + 272);
      // memcpy(vol.ImplUse, buf + 128, sizeof(vol.ImplUse));
      size_t pos = 440;
      for (UInt32 i = 0; i < numPartitionMaps; i++)
      {
        if (pos + 2 > bufSize)
          return S_FALSE;
        CPartitionMap pm;
        pm.Type = buf[pos];
        // pm.Length = buf[pos + 1];
        Byte len = buf[pos + 1];

        if (pos + len > bufSize)
          return S_FALSE;
        
        // memcpy(pm.Data, buf + pos + 2, pm.Length - 2);
        if (pm.Type == 1)
        {
          if (pos + 6 > bufSize)
            return S_FALSE;
          // pm.VolSeqNumber = Get16(buf + pos + 2);
          pm.PartitionNumber = Get16(buf + pos + 4);
        }
        else
          return S_FALSE;
        pos += len;
        vol.PartitionMaps.Add(pm);
      }
      LogVols.Add(vol);
    }
  }

  UInt64 totalSize = 0;

  int volIndex;
  for (volIndex = 0; volIndex < LogVols.Size(); volIndex++)
  {
    CLogVol &vol = LogVols[volIndex];
    for (int pmIndex = 0; pmIndex < vol.PartitionMaps.Size(); pmIndex++)
    {
      CPartitionMap &pm = vol.PartitionMaps[pmIndex];
      int i;
      for (i = 0; i < Partitions.Size(); i++)
      {
        CPartition &part = Partitions[i];
        if (part.Number == pm.PartitionNumber)
        {
          if (part.VolIndex >= 0)
            return S_FALSE;
          pm.PartitionIndex = i;
          part.VolIndex = volIndex;

          totalSize += (UInt64)part.Len << SecLogSize;
          break;
        }
      }
      if (i == Partitions.Size())
        return S_FALSE;
    }
  }

  RINOK(_progress->SetTotal(totalSize));

  for (volIndex = 0; volIndex < LogVols.Size(); volIndex++)
  {
    CLogVol &vol = LogVols[volIndex];

    CLongAllocDesc nextExtent = vol.FileSetLocation;
    // while (nextExtent.ExtentLen != 0)
    // for (int i = 0; i < 1; i++)
    {
      if (nextExtent.GetLen() < 512)
        return S_FALSE;
      CByteBuffer buf;
      buf.SetCapacity(nextExtent.GetLen());
      RINOK(Read(volIndex, nextExtent, buf));
      const Byte *p = buf;
      size_t size = nextExtent.GetLen();

      CTag tag;
      RINOK(tag.Parse(p, size));
      if (tag.Id != DESC_TYPE_FileSet)
        return S_FALSE;
      
      CFileSet fs;
      fs.RecodringTime.Parse(p + 16);
      // fs.InterchangeLevel = Get16(p + 18);
      // fs.MaxInterchangeLevel = Get16(p + 20);
      // fs.FileSetNumber = Get32(p + 40);
      // fs.FileSetDescNumber = Get32(p + 44);
      
      // fs.Id.Parse(p + 304);
      // fs.CopyrightId.Parse(p + 336);
      // fs.AbstractId.Parse(p + 368);
      
      fs.RootDirICB.Parse(p + 400);
      // fs.DomainId.Parse(p + 416);
      
      // fs.SystemStreamDirICB.Parse(p + 464);
      
      vol.FileSets.Add(fs);

      // nextExtent.Parse(p + 448);
    }

    for (int fsIndex = 0; fsIndex < vol.FileSets.Size(); fsIndex++)
    {
      CFileSet &fs = vol.FileSets[fsIndex];
      int fileIndex = Files.Size();
      Files.Add(CFile());
      RINOK(ReadFileItem(volIndex, fsIndex, fs.RootDirICB, kNumRecureseLevelsMax));
      RINOK(FillRefs(fs, fileIndex, -1, kNumRecureseLevelsMax));
    }
  }

  return S_OK;
}

HRESULT CInArchive::Open(IInStream *inStream, CProgressVirt *progress)
{
  _progress = progress;
  _stream = inStream;
  HRESULT res;
  try { res = Open2(); }
  catch(...) { Clear(); res = S_FALSE; }
  _stream.Release();
  return res;
}

void CInArchive::Clear()
{
  Partitions.Clear();
  LogVols.Clear();
  Items.Clear();
  Files.Clear();
  _fileNameLengthTotal = 0;
  _numRefs = 0;
  _numExtents = 0;
  _inlineExtentsSize = 0;
  _processedProgressBytes = 0;
}

UString CInArchive::GetComment() const
{
  UString res;
  for (int i = 0; i < LogVols.Size(); i++)
  {
    if (i > 0)
      res += L" ";
    res += LogVols[i].GetName();
  }
  return res;
}

static UString GetSpecName(const UString &name)
{
  UString name2 = name;
  name2.Trim();
  if (name2.IsEmpty())
  {
    /*
    wchar_t s[32];
    ConvertUInt64ToString(id, s);
    return L"[" + (UString)s + L"]";
    */
    return L"[]";
  }
  return name;
}

static void UpdateWithName(UString &res, const UString &addString)
{
  if (res.IsEmpty())
    res = addString;
  else
    res = addString + WCHAR_PATH_SEPARATOR + res;
}

UString CInArchive::GetItemPath(int volIndex, int fsIndex, int refIndex,
    bool showVolName, bool showFsName) const
{
  // showVolName = true;
  const CLogVol &vol = LogVols[volIndex];
  const CFileSet &fs = vol.FileSets[fsIndex];

  UString name;

  for (;;)
  {
    const CRef &ref = fs.Refs[refIndex];
    refIndex = ref.Parent;
    if (refIndex < 0)
      break;
    UpdateWithName(name, GetSpecName(Files[ref.FileIndex].GetName()));
  }

  if (showFsName)
  {
    wchar_t s[32];
    ConvertUInt64ToString(fsIndex, s);
    UString newName = L"File Set ";
    newName += s;
    UpdateWithName(name, newName);
  }

  if (showVolName)
  {
    wchar_t s[32];
    ConvertUInt64ToString(volIndex, s);
    UString newName = s;
    UString newName2 = vol.GetName();
    if (newName2.IsEmpty())
      newName2 = L"Volume";
    newName += L'-';
    newName += newName2;
    UpdateWithName(name, newName);
  }
  return name;
}

}}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产麻豆精品theporn| 国产成人亚洲综合a∨婷婷| 26uuu色噜噜精品一区| 99久久综合色| 日韩成人精品在线观看| 国产精品久久久久影院色老大 | 欧美日韩三级在线| 懂色av一区二区三区蜜臀| 午夜视频在线观看一区| 中文字幕中文乱码欧美一区二区| 欧美二区乱c少妇| 色婷婷久久一区二区三区麻豆| 精品中文av资源站在线观看| 亚洲一区二区三区视频在线播放| 日韩国产欧美三级| 中文字幕一区不卡| wwwwxxxxx欧美| 69精品人人人人| 在线视频一区二区三区| 成人h精品动漫一区二区三区| 麻豆精品在线播放| 无吗不卡中文字幕| 亚洲乱码国产乱码精品精可以看 | 国产欧美精品日韩区二区麻豆天美| 欧美日韩亚洲综合在线| 91蝌蚪porny| 成人毛片在线观看| 国产精品1024| 国产精品一区二区久久精品爱涩 | 91免费观看国产| 国产成人精品一区二区三区四区| 久久精品国产一区二区| 无码av中文一区二区三区桃花岛| 亚洲一区二区五区| 一卡二卡欧美日韩| 一区二区三区**美女毛片| 中文字幕五月欧美| 亚洲欧美色图小说| 亚洲视频网在线直播| 亚洲欧美视频在线观看视频| **网站欧美大片在线观看| |精品福利一区二区三区| 日韩一区在线免费观看| 亚洲视频在线一区| 亚洲欧美色图小说| 亚洲国产精品精华液网站| 亚洲成人av在线电影| 调教+趴+乳夹+国产+精品| 日韩高清在线不卡| 麻豆成人免费电影| 韩日av一区二区| 岛国精品一区二区| 色综合久久88色综合天天免费| 91美女视频网站| 欧美日韩在线播放三区四区| 欧美日韩视频在线观看一区二区三区 | 夜夜嗨av一区二区三区| 亚洲一区精品在线| 天堂在线亚洲视频| 黄网站免费久久| 丰满少妇在线播放bd日韩电影| 成人黄色a**站在线观看| 91在线看国产| 欧美日韩另类国产亚洲欧美一级| 3751色影院一区二区三区| 日韩免费电影网站| 欧美韩国日本综合| 一区二区三区中文字幕精品精品| 天堂精品中文字幕在线| 国产精品18久久久久久久久| 91视频在线观看| 欧美日韩成人高清| 久久婷婷色综合| 中文字幕一区在线观看视频| 日韩专区中文字幕一区二区| 国产一区二区在线看| 色呦呦国产精品| 欧美日韩激情一区二区三区| 精品第一国产综合精品aⅴ| 中文字幕一区免费在线观看| 亚洲成人先锋电影| 国产成人免费在线视频| 色综合天天综合网国产成人综合天| 欧美日韩一卡二卡| 国产农村妇女毛片精品久久麻豆| 亚洲精品写真福利| 九一九一国产精品| 日本韩国一区二区| 欧美精品一区二区三区四区| 一级日本不卡的影视| 精品一区二区三区在线观看国产| 91在线播放网址| 精品久久久久久久一区二区蜜臀| 成人欧美一区二区三区在线播放| 三级影片在线观看欧美日韩一区二区 | 理论电影国产精品| 91麻豆自制传媒国产之光| 精品国产麻豆免费人成网站| 亚洲欧美一区二区三区孕妇| 久久国产生活片100| 91国偷自产一区二区开放时间 | 欧美精品一区二| 一二三四社区欧美黄| 国产成人免费视频网站 | 日韩毛片精品高清免费| 蜜桃av一区二区在线观看| 在线免费观看一区| 国产精品乱码一区二区三区软件 | 91精品视频网| 亚洲综合在线五月| 不卡高清视频专区| 国产午夜精品一区二区三区四区| 天天综合天天做天天综合| av中文字幕不卡| 国产亚洲精品福利| 激情深爱一区二区| 日韩一区二区中文字幕| 亚洲午夜电影网| 色综合久久综合| 中文字幕日韩av资源站| 国产69精品久久久久毛片| 久久久久久久网| 久久99久久精品欧美| 欧美精品一二三| 亚洲国产一二三| 欧美三级日韩三级| 亚洲午夜激情av| 欧美日韩综合一区| 亚洲午夜三级在线| 欧美日韩小视频| 丝袜a∨在线一区二区三区不卡| 欧美性三三影院| 亚洲自拍偷拍图区| 欧美午夜精品久久久| 一区二区三区在线观看网站| 一本一本久久a久久精品综合麻豆| 国产精品色呦呦| av中文字幕在线不卡| 亚洲天堂免费在线观看视频| gogo大胆日本视频一区| 亚洲三级在线免费观看| 91啪亚洲精品| 亚洲一区二区3| 欧洲视频一区二区| 日韩精品亚洲一区| 欧美一三区三区四区免费在线看 | 一区二区三区中文字幕电影| 色婷婷av一区二区| 亚洲一级二级三级| 欧美日韩五月天| 久久精品国产亚洲一区二区三区| 精品国产乱码久久久久久图片| 国模无码大尺度一区二区三区| 久久久国产精华| 99在线视频精品| 一区av在线播放| 欧美一区二区三区人| 国产电影一区在线| 亚洲精品你懂的| 欧美精品在线观看播放| 国内精品久久久久影院色| 国产欧美视频一区二区三区| 99精品欧美一区二区三区小说| 亚洲理论在线观看| 日韩欧美美女一区二区三区| 国产成人啪免费观看软件| 亚洲乱码日产精品bd| 欧美一级黄色录像| 成人污视频在线观看| 亚洲第一激情av| 久久这里都是精品| 91视频在线看| 久草在线在线精品观看| 国产精品福利一区二区| 欧美日韩成人在线| 国产大片一区二区| 亚洲国产另类av| 久久精品日韩一区二区三区| 日本道精品一区二区三区 | 91网站最新网址| 日韩电影在线免费观看| 国产精品久久免费看| 欧美夫妻性生活| av午夜精品一区二区三区| 五月天国产精品| 中日韩av电影| 91精品久久久久久久91蜜桃| 成人免费看片app下载| 亚洲综合在线免费观看| 国产欧美一区二区精品性色超碰| 欧美日韩久久久一区| 成人激情动漫在线观看| 裸体歌舞表演一区二区| 伊人婷婷欧美激情| 久久久www免费人成精品| 欧美日韩亚洲综合| 一本大道久久a久久精二百| 精品一区二区av| 亚洲成人av免费| 综合久久综合久久|