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

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

?? inflate.c

?? LINUX1.0源代碼,代碼條理清晰
?? C
?? 第 1 頁 / 共 2 頁
字號:
        {
          memcpy(slide + w, slide + d, e);
          w += e;
          d += e;
        }
        else                      /* do it slow to avoid memcpy() overlap */
#endif /* !NOMEMCPY */
          do {
            slide[w++] = slide[d++];
          } while (--e);
        if (w == WSIZE)
        {
          flush_output(w);
          w = 0;
        }
      } while (n);
    }
  }


  /* restore the globals from the locals */
  wp = w;                       /* restore global window pointer */
  bb = b;                       /* restore global bit buffer */
  bk = k;

  /* done */
  return 0;
}



int inflate_stored()
/* "decompress" an inflated type 0 (stored) block. */
{
  unsigned n;           /* number of bytes in block */
  unsigned w;           /* current window position */
  register ulg b;       /* bit buffer */
  register unsigned k;  /* number of bits in bit buffer */

DEBG("<stor");

  /* make local copies of globals */
  b = bb;                       /* initialize bit buffer */
  k = bk;
  w = wp;                       /* initialize window position */


  /* go to byte boundary */
  n = k & 7;
  DUMPBITS(n);


  /* get the length and its complement */
  NEEDBITS(16)
  n = ((unsigned)b & 0xffff);
  DUMPBITS(16)
  NEEDBITS(16)
  if (n != (unsigned)((~b) & 0xffff))
    return 1;                   /* error in compressed data */
  DUMPBITS(16)


  /* read and output the compressed data */
  while (n--)
  {
    NEEDBITS(8)
    slide[w++] = (uch)b;
    if (w == WSIZE)
    {
      flush_output(w);
      w = 0;
    }
    DUMPBITS(8)
  }


  /* restore the globals from the locals */
  wp = w;                       /* restore global window pointer */
  bb = b;                       /* restore global bit buffer */
  bk = k;

  DEBG(">");
  return 0;
}



int inflate_fixed()
/* decompress an inflated type 1 (fixed Huffman codes) block.  We should
   either replace this with a custom decoder, or at least precompute the
   Huffman tables. */
{
  int i;                /* temporary variable */
  struct huft *tl;      /* literal/length code table */
  struct huft *td;      /* distance code table */
  int bl;               /* lookup bits for tl */
  int bd;               /* lookup bits for td */
  unsigned l[288];      /* length list for huft_build */

DEBG("<fix");

  /* set up literal table */
  for (i = 0; i < 144; i++)
    l[i] = 8;
  for (; i < 256; i++)
    l[i] = 9;
  for (; i < 280; i++)
    l[i] = 7;
  for (; i < 288; i++)          /* make a complete, but wrong code set */
    l[i] = 8;
  bl = 7;
  if ((i = huft_build(l, 288, 257, cplens, cplext, &tl, &bl)) != 0)
    return i;


  /* set up distance table */
  for (i = 0; i < 30; i++)      /* make an incomplete code set */
    l[i] = 5;
  bd = 5;
  if ((i = huft_build(l, 30, 0, cpdist, cpdext, &td, &bd)) > 1)
  {
    huft_free(tl);

    DEBG(">");
    return i;
  }


  /* decompress until an end-of-block code */
  if (inflate_codes(tl, td, bl, bd))
    return 1;


  /* free the decoding tables, return */
  huft_free(tl);
  huft_free(td);
  return 0;
}



int inflate_dynamic()
/* decompress an inflated type 2 (dynamic Huffman codes) block. */
{
  int i;                /* temporary variables */
  unsigned j;
  unsigned l;           /* last length */
  unsigned m;           /* mask for bit lengths table */
  unsigned n;           /* number of lengths to get */
  struct huft *tl;      /* literal/length code table */
  struct huft *td;      /* distance code table */
  int bl;               /* lookup bits for tl */
  int bd;               /* lookup bits for td */
  unsigned nb;          /* number of bit length codes */
  unsigned nl;          /* number of literal/length codes */
  unsigned nd;          /* number of distance codes */
#ifdef PKZIP_BUG_WORKAROUND
  unsigned ll[288+32];  /* literal/length and distance code lengths */
#else
  unsigned ll[286+30];  /* literal/length and distance code lengths */
#endif
  register ulg b;       /* bit buffer */
  register unsigned k;  /* number of bits in bit buffer */

DEBG("<dyn");

  /* make local bit buffer */
  b = bb;
  k = bk;


  /* read in table lengths */
  NEEDBITS(5)
  nl = 257 + ((unsigned)b & 0x1f);      /* number of literal/length codes */
  DUMPBITS(5)
  NEEDBITS(5)
  nd = 1 + ((unsigned)b & 0x1f);        /* number of distance codes */
  DUMPBITS(5)
  NEEDBITS(4)
  nb = 4 + ((unsigned)b & 0xf);         /* number of bit length codes */
  DUMPBITS(4)
#ifdef PKZIP_BUG_WORKAROUND
  if (nl > 288 || nd > 32)
#else
  if (nl > 286 || nd > 30)
#endif
    return 1;                   /* bad lengths */

DEBG("dyn1 ");

  /* read in bit-length-code lengths */
  for (j = 0; j < nb; j++)
  {
    NEEDBITS(3)
    ll[border[j]] = (unsigned)b & 7;
    DUMPBITS(3)
  }
  for (; j < 19; j++)
    ll[border[j]] = 0;

DEBG("dyn2 ");

  /* build decoding table for trees--single level, 7 bit lookup */
  bl = 7;
  if ((i = huft_build(ll, 19, 19, NULL, NULL, &tl, &bl)) != 0)
  {
    if (i == 1)
      huft_free(tl);
    return i;                   /* incomplete code set */
  }

DEBG("dyn3 ");

  /* read in literal and distance code lengths */
  n = nl + nd;
  m = mask_bits[bl];
  i = l = 0;
  while ((unsigned)i < n)
  {
    NEEDBITS((unsigned)bl)
    j = (td = tl + ((unsigned)b & m))->b;
    DUMPBITS(j)
    j = td->v.n;
    if (j < 16)                 /* length of code in bits (0..15) */
      ll[i++] = l = j;          /* save last length in l */
    else if (j == 16)           /* repeat last length 3 to 6 times */
    {
      NEEDBITS(2)
      j = 3 + ((unsigned)b & 3);
      DUMPBITS(2)
      if ((unsigned)i + j > n)
        return 1;
      while (j--)
        ll[i++] = l;
    }
    else if (j == 17)           /* 3 to 10 zero length codes */
    {
      NEEDBITS(3)
      j = 3 + ((unsigned)b & 7);
      DUMPBITS(3)
      if ((unsigned)i + j > n)
        return 1;
      while (j--)
        ll[i++] = 0;
      l = 0;
    }
    else                        /* j == 18: 11 to 138 zero length codes */
    {
      NEEDBITS(7)
      j = 11 + ((unsigned)b & 0x7f);
      DUMPBITS(7)
      if ((unsigned)i + j > n)
        return 1;
      while (j--)
        ll[i++] = 0;
      l = 0;
    }
  }

DEBG("dyn4 ");

  /* free decoding table for trees */
  huft_free(tl);

DEBG("dyn5 ");

  /* restore the global bit buffer */
  bb = b;
  bk = k;

DEBG("dyn5a ");

  /* build the decoding tables for literal/length and distance codes */
  bl = lbits;
  if ((i = huft_build(ll, nl, 257, cplens, cplext, &tl, &bl)) != 0)
  {
DEBG("dyn5b ");
    if (i == 1) {
      error(" incomplete literal tree\n");
      huft_free(tl);
    }
    return i;                   /* incomplete code set */
  }
DEBG("dyn5c ");
  bd = dbits;
  if ((i = huft_build(ll + nl, nd, 0, cpdist, cpdext, &td, &bd)) != 0)
  {
DEBG("dyn5d ");
    if (i == 1) {
      error(" incomplete distance tree\n");
#ifdef PKZIP_BUG_WORKAROUND
      i = 0;
    }
#else
      huft_free(td);
    }
    huft_free(tl);
    return i;                   /* incomplete code set */
#endif
  }

DEBG("dyn6 ");

  /* decompress until an end-of-block code */
  if (inflate_codes(tl, td, bl, bd))
    return 1;

DEBG("dyn7 ");

  /* free the decoding tables, return */
  huft_free(tl);
  huft_free(td);

  DEBG(">");
  return 0;
}



int inflate_block(e)
int *e;                 /* last block flag */
/* decompress an inflated block */
{
  unsigned t;           /* block type */
  register ulg b;       /* bit buffer */
  register unsigned k;  /* number of bits in bit buffer */

  DEBG("<blk");

  /* make local bit buffer */
  b = bb;
  k = bk;


  /* read in last block bit */
  NEEDBITS(1)
  *e = (int)b & 1;
  DUMPBITS(1)


  /* read in block type */
  NEEDBITS(2)
  t = (unsigned)b & 3;
  DUMPBITS(2)


  /* restore the global bit buffer */
  bb = b;
  bk = k;

  /* inflate that block type */
  if (t == 2)
    return inflate_dynamic();
  if (t == 0)
    return inflate_stored();
  if (t == 1)
    return inflate_fixed();

  DEBG(">");

  /* bad block type */
  return 2;
}



int inflate()
/* decompress an inflated entry */
{
  int e;                /* last block flag */
  int r;                /* result code */
  unsigned h;           /* maximum struct huft's malloc'ed */


  /* initialize window, bit buffer */
  wp = 0;
  bk = 0;
  bb = 0;


  /* decompress until the last block */
  h = 0;
  do {
    hufts = 0;
    if ((r = inflate_block(&e)) != 0)
      return r;
    if (hufts > h)
      h = hufts;
  } while (!e);

  /* Undo too much lookahead. The next read will be byte aligned so we
   * can discard unused bits in the last meaningful byte.
   */
  while (bk >= 8) {
    bk -= 8;
    inptr--;
  }

  /* flush out slide */
  flush_output(wp);


  /* return success */
#ifdef DEBUG
  fprintf(stderr, "<%u> ", h);
#endif /* DEBUG */
  return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩美女久久久| 亚洲国产精品影院| 欧美日韩免费观看一区三区| 狠狠色综合色综合网络| 一区二区欧美精品| 国产精品日日摸夜夜摸av| 日韩欧美国产麻豆| 欧美日韩一区二区三区四区五区| 国产成人aaaa| 国产在线不卡视频| 免费在线观看一区二区三区| 亚洲激情综合网| 国产精品全国免费观看高清 | 激情综合亚洲精品| 亚洲图片欧美色图| 中文字幕综合网| 国产精品美女久久久久久久网站| 欧美成人猛片aaaaaaa| 欧美日韩精品一区二区三区四区 | 日本不卡一二三| 亚洲一区免费在线观看| 亚洲欧美另类久久久精品2019| 久久久五月婷婷| 26uuu精品一区二区| 5566中文字幕一区二区电影| 色综合久久88色综合天天6| av在线一区二区三区| 狠狠色丁香婷综合久久| 日本不卡高清视频| 日本不卡在线视频| 日本不卡不码高清免费观看| 三级在线观看一区二区| 视频一区二区三区中文字幕| 午夜不卡在线视频| 日韩av电影天堂| 日韩国产精品久久久久久亚洲| 亚洲国产一区二区在线播放| 洋洋av久久久久久久一区| ...av二区三区久久精品| 亚洲人成影院在线观看| 亚洲精品国久久99热| 亚洲综合999| 午夜久久久久久久久久一区二区| 亚洲高清在线精品| 日韩电影免费一区| 久久9热精品视频| 国产一二精品视频| 成人视屏免费看| 色狠狠一区二区三区香蕉| 色狠狠一区二区| 欧美人牲a欧美精品| 日韩精品一区二区三区四区| 精品福利视频一区二区三区| 国产视频一区二区在线观看| 久久国产视频网| 国产一区二区在线看| 成人的网站免费观看| 99久久精品国产一区| 欧美写真视频网站| 欧美大胆一级视频| 国产偷国产偷精品高清尤物| 中文字幕制服丝袜一区二区三区| 亚洲精品成a人| 爽好多水快深点欧美视频| 麻豆国产精品一区二区三区 | 欧美一区二区视频在线观看2020| 日韩亚洲欧美成人一区| 久久人人超碰精品| 亚洲精品国产精华液| 欧美aⅴ一区二区三区视频| 国产精品一级二级三级| 日本道免费精品一区二区三区| 欧美裸体一区二区三区| 久久久亚洲午夜电影| 亚洲伊人色欲综合网| 国产综合色精品一区二区三区| 99国产精品久久久久久久久久| 3d动漫精品啪啪| 国产精品免费丝袜| 日韩av一级电影| 不卡视频一二三四| 日韩一区二区精品在线观看| 中文字幕av一区二区三区免费看| 亚洲福利一区二区| 国产一区二区在线电影| 在线观看视频91| 国产亚洲人成网站| 天天爽夜夜爽夜夜爽精品视频| 国产盗摄视频一区二区三区| 欧美视频第二页| 国产精品每日更新在线播放网址| 日韩精品一二三区| 一本一本久久a久久精品综合麻豆| 欧美一区中文字幕| 亚洲免费在线观看| 国产激情视频一区二区在线观看| 欧美日韩激情在线| 国产成人免费视频网站高清观看视频| 欧美私人免费视频| 国产精品色眯眯| 久久疯狂做爰流白浆xx| 91福利在线观看| 国产精品久久久久久福利一牛影视| 麻豆精品新av中文字幕| 欧美性生活一区| 中文字幕不卡三区| 久草精品在线观看| 在线播放中文一区| 亚洲综合在线免费观看| 成人精品视频一区二区三区| 欧美成人一区二区三区在线观看 | 日韩一区二区免费电影| 一区二区三区不卡在线观看 | 91论坛在线播放| 国产色产综合产在线视频| 捆绑调教美女网站视频一区| 欧美老女人第四色| 一区二区日韩电影| 在线亚洲免费视频| 亚洲同性同志一二三专区| 成人av免费在线观看| 欧美激情中文字幕| 国产精品羞羞答答xxdd| 精品国产一二三区| 国内成人精品2018免费看| 日韩精品一区二区三区视频播放| 日韩国产在线观看一区| 欧美性色欧美a在线播放| 亚洲制服丝袜在线| 欧美日韩一区 二区 三区 久久精品| 亚洲黄网站在线观看| 在线精品视频小说1| 亚洲最大成人综合| 欧美日韩成人激情| 免费在线欧美视频| 2023国产一二三区日本精品2022| 久久精品国产色蜜蜜麻豆| 日韩欧美国产综合在线一区二区三区| 日韩av中文字幕一区二区三区| 日韩一区二区影院| 久久99精品久久久久| 久久精品夜夜夜夜久久| 成人av免费在线| 亚洲伦理在线免费看| 欧美亚洲综合网| 奇米一区二区三区| 精品久久人人做人人爱| 国产麻豆9l精品三级站| 国产精品美女一区二区| 色婷婷国产精品| 日韩影院精彩在线| 精品国免费一区二区三区| 国产成人丝袜美腿| 亚洲视频一区二区在线观看| 一本一本大道香蕉久在线精品| 亚洲成人先锋电影| 精品国产一区二区三区久久久蜜月 | 成人黄色片在线观看| 亚洲人成小说网站色在线| 欧美人狂配大交3d怪物一区 | 国产盗摄精品一区二区三区在线| 国产精品乱码妇女bbbb| 日本女人一区二区三区| 日韩精品中文字幕一区| 欧洲精品在线观看| 成人免费在线播放视频| 无吗不卡中文字幕| aaa国产一区| 午夜精品在线看| 久久影院电视剧免费观看| 成人免费观看av| 亚洲一二三区不卡| 日韩你懂的在线观看| 99视频有精品| 午夜精品在线看| 中文字幕精品—区二区四季| 欧美影院午夜播放| 国产一区二区不卡在线| 亚洲免费观看高清完整版在线观看| 3751色影院一区二区三区| 国产69精品久久久久毛片| 亚洲第一福利视频在线| 中文天堂在线一区| 日韩一区二区精品| 波多野结衣欧美| 免费精品99久久国产综合精品| 日本一区二区三区高清不卡| 欧美日韩在线直播| 福利电影一区二区三区| 亚洲va欧美va人人爽| 国产精品久久久久一区| 日韩欧美一级二级三级| 91激情在线视频| 国产成人a级片| 欧美aaaaaa午夜精品| 亚洲综合免费观看高清完整版| 国产丝袜美腿一区二区三区| 欧美一二三区在线| 欧美少妇一区二区| 91色九色蝌蚪|