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

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

?? inflate.h

?? AT91RM9200的引到程序
?? H
?? 第 1 頁 / 共 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;
}



STATIC 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;
}



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

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


  /* decompress until the last block */
  h = 0;
  do {
    hufts = 0;
    gzip_mark(&ptr);
    if ((r = inflate_block(&e)) != 0) {
      gzip_release(&ptr);	    
      return r;
    }
    gzip_release(&ptr);
    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;
}

/**********************************************************************
 *
 * The following are support routines for inflate.c
 *
 **********************************************************************/

static ulg crc_32_tab[256];
static ulg crc = (ulg)0xffffffffL; /* shift register contents */
#define CRC_VALUE (crc ^ 0xffffffffL)

/*
 * Code to compute the CRC-32 table. Borrowed from 
 * gzip-1.0.3/makecrc.c.
 */

static void
makecrc(void)
{
/* Not copyrighted 1990 Mark Adler	*/

  unsigned long c;      /* crc shift register */
  unsigned long e;      /* polynomial exclusive-or pattern */
  int i;                /* counter for all possible eight bit values */
  int k;                /* byte being shifted into crc apparatus */

  /* terms of polynomial defining this crc (except x^32): */
  static int p[] = {0,1,2,4,5,7,8,10,11,12,16,22,23,26};

  /* Make exclusive-or pattern from polynomial */
  e = 0;
  for (i = 0; i < sizeof(p)/sizeof(int); i++)
    e |= 1L << (31 - p[i]);

  crc_32_tab[0] = 0;

  for (i = 1; i < 256; i++)
  {
    c = 0;
    for (k = i | 256; k != 1; k >>= 1)
    {
      c = c & 1 ? (c >> 1) ^ e : c >> 1;
      if (k & 1)
        c ^= e;
    }
    crc_32_tab[i] = c;
  }
}

/* gzip flag byte */
#define ASCII_FLAG   0x01 /* bit 0 set: file probably ascii text */
#define CONTINUATION 0x02 /* bit 1 set: continuation of multi-part gzip file */
#define EXTRA_FIELD  0x04 /* bit 2 set: extra field present */
#define ORIG_NAME    0x08 /* bit 3 set: original file name present */
#define COMMENT      0x10 /* bit 4 set: file comment present */
#define ENCRYPTED    0x20 /* bit 5 set: file is encrypted */
#define RESERVED     0xC0 /* bit 6,7:   reserved */

/*
 * Do the uncompression!
 */
static int gunzip(void)
{
    uch flags;
    unsigned char magic[2]; /* magic header */
    char method;
    ulg orig_crc = 0;       /* original crc */
    ulg orig_len = 0;       /* original uncompressed length */
    int res;

    magic[0] = (unsigned char)get_byte();
    magic[1] = (unsigned char)get_byte();
    method = (unsigned char)get_byte();

    if (magic[0] != 037 ||
	((magic[1] != 0213) && (magic[1] != 0236))) {
	    error("bad gzip magic numbers");
	    return -1;
    }

    /* We only support method #8, DEFLATED */
    if (method != 8)  {
	    error("internal error, invalid method");
	    return -1;
    }

    flags  = (uch)get_byte();
    if ((flags & ENCRYPTED) != 0) {
	    error("Input is encrypted\n");
	    return -1;
    }
    if ((flags & CONTINUATION) != 0) {
	    error("Multi part input\n");
	    return -1;
    }
    if ((flags & RESERVED) != 0) {
	    error("Input has invalid flags\n");
	    return -1;
    }
    (ulg)get_byte();	/* Get timestamp */
    ((ulg)get_byte()) << 8;
    ((ulg)get_byte()) << 16;
    ((ulg)get_byte()) << 24;

    (void)get_byte();  /* Ignore extra flags for the moment */
    (void)get_byte();  /* Ignore OS type for the moment */

    if ((flags & EXTRA_FIELD) != 0) {
	    unsigned len = (unsigned)get_byte();
	    len |= ((unsigned)get_byte())<<8;
	    while (len--) (void)get_byte();
    }

    /* Get original file name if it was truncated */
    if ((flags & ORIG_NAME) != 0) {
	    /* Discard the old name */
	    while (get_byte() != 0) /* null */ ;
    } 

    /* Discard file comment if any */
    if ((flags & COMMENT) != 0) {
	    while (get_byte() != 0) /* null */ ;
    }

    /* Decompress */
    if ((res = inflate())) {
	    switch (res) {
	    case 0:
		    break;
	    case 1:
		    error("invalid compressed format (err=1)");
		    break;
	    case 2:
		    error("invalid compressed format (err=2)");
		    break;
	    case 3:
		    error("out of memory");
		    break;
	    default:
		    error("invalid compressed format (other)");
	    }
	    return -1;
    }

    
    /* Get the crc and original length */
    /* crc32  (see algorithm.doc)
     * uncompressed input size modulo 2^32
     */
    orig_crc = (ulg) get_byte();
    orig_crc |= (ulg) get_byte() << 8;
    orig_crc |= (ulg) get_byte() << 16;
    orig_crc |= (ulg) get_byte() << 24;
    
    orig_len = (ulg) get_byte();
    orig_len |= (ulg) get_byte() << 8;
    orig_len |= (ulg) get_byte() << 16;
    orig_len |= (ulg) get_byte() << 24;

    /* Validate decompression */
    if (orig_crc != CRC_VALUE) {
	    error("crc error");
	    return -1;
    }
    if (orig_len != bytes_out) {
	    error("length error");
	    return -1;
    }
    return 0;
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产亚洲一区二区三区在线观看| 国产精品毛片大码女人| 风间由美一区二区三区在线观看 | 欧美激情一区二区三区在线| 欧洲精品在线观看| 风间由美中文字幕在线看视频国产欧美| 亚洲精品乱码久久久久久黑人| wwwwxxxxx欧美| 欧美男女性生活在线直播观看| 不卡一区在线观看| 精品亚洲porn| 日韩高清在线一区| 一区二区三区中文字幕电影 | 精品捆绑美女sm三区| 欧美在线观看你懂的| 成人ar影院免费观看视频| 久99久精品视频免费观看| 亚洲国产欧美日韩另类综合| 中文字幕一区二区三区四区不卡| 久久综合资源网| 欧美精品在线一区二区三区| 日本乱人伦一区| av电影一区二区| 福利电影一区二区| 国产成人av一区| 国产老妇另类xxxxx| 激情综合网av| 韩国v欧美v日本v亚洲v| 美女爽到高潮91| 日一区二区三区| 五月天激情小说综合| 一区二区三区小说| 亚洲日本中文字幕区| 国产精品无遮挡| 久久精品免费在线观看| 久久久久久久久久看片| 日韩精品综合一本久道在线视频| 日韩一二在线观看| 日韩精品一区在线| 26uuu亚洲综合色欧美| 久久午夜色播影院免费高清| 精品美女在线观看| 久久久精品免费观看| 久久久国产精华| 欧美激情综合五月色丁香| 国产精品乱码妇女bbbb| 国产精品福利一区二区| 亚洲欧美色图小说| 亚洲午夜在线观看视频在线| 肉色丝袜一区二区| 精品综合免费视频观看| 国产精品中文字幕欧美| 波多野结衣中文字幕一区| 色综合视频一区二区三区高清| 91麻豆.com| 欧美亚洲国产一卡| 欧美一二三四在线| 中文在线资源观看网站视频免费不卡| 欧美激情一区在线| 亚洲一区二区三区小说| 美腿丝袜亚洲一区| 国产一区二区免费看| 91在线免费视频观看| 欧美日韩精品一区二区| 欧美成人欧美edvon| 国产精品麻豆一区二区| 亚洲一区二区成人在线观看| 麻豆国产一区二区| jlzzjlzz亚洲日本少妇| 欧美日韩在线观看一区二区| 日韩精品一区国产麻豆| 亚洲欧洲国产日本综合| 蜜臀久久99精品久久久久宅男| 国产麻豆精品一区二区| 日本韩国一区二区| 日韩欧美国产电影| 亚洲色大成网站www久久九九| 日韩和欧美的一区| 国产成人激情av| 欧美天堂亚洲电影院在线播放| 精品国产免费视频| 亚洲欧美另类久久久精品 | 亚洲人精品午夜| 日韩高清一区在线| av激情亚洲男人天堂| 日韩一区二区在线看片| 日韩美女精品在线| 久久se精品一区二区| 一本大道久久a久久综合| 欧美美女激情18p| **性色生活片久久毛片| 老司机精品视频一区二区三区| 97se亚洲国产综合自在线不卡| 日韩一区二区免费高清| 亚洲精品自拍动漫在线| 国产麻豆精品95视频| 欧美日韩卡一卡二| 中文字幕亚洲不卡| 国产一区视频导航| 欧美一区二区三区人| 一区二区三区精品| 高清国产午夜精品久久久久久| 日韩一区二区在线观看| 亚洲一二三四久久| 成人美女在线视频| 久久亚洲一区二区三区四区| 亚洲成av人片一区二区三区| 99久久国产综合精品女不卡| 久久尤物电影视频在线观看| 日韩高清一区在线| 欧美三级视频在线观看| 亚洲欧美日韩系列| 成人国产在线观看| 久久综合久久综合九色| 日韩高清一级片| 欧美日本国产一区| 亚洲五月六月丁香激情| 日本高清视频一区二区| 亚洲欧洲av在线| 成人动漫精品一区二区| 日本一区二区三级电影在线观看| 久久99久久久欧美国产| 日韩视频一区二区三区在线播放 | 麻豆极品一区二区三区| 欧美精品黑人性xxxx| 亚洲韩国一区二区三区| 欧洲亚洲国产日韩| 亚洲一区在线观看免费 | 麻豆国产精品官网| 91精品在线一区二区| 视频一区视频二区中文| 欧美日韩一区不卡| 亚洲成人免费在线| 欧美偷拍一区二区| 天堂精品中文字幕在线| 欧美日韩一区在线观看| 亚洲国产精品久久人人爱| 欧美日韩国产一二三| 天堂精品中文字幕在线| 欧美一区二区三区电影| 老司机免费视频一区二区三区| 精品久久久三级丝袜| 国产一区中文字幕| 中文字幕精品综合| 91片在线免费观看| 亚洲成人免费电影| 日韩一级免费一区| 国产精品2024| 日韩高清欧美激情| 日韩欧美一区电影| 国产在线播放一区三区四| 欧美激情一区三区| 91蝌蚪porny| 天天综合日日夜夜精品| 精品国产麻豆免费人成网站| 精品写真视频在线观看| 国产精品美女久久久久久久网站| 色素色在线综合| 日本伊人精品一区二区三区观看方式| 欧美大片一区二区三区| 国产高清精品网站| 悠悠色在线精品| 精品区一区二区| 91理论电影在线观看| 日韩av电影一区| 国产亚洲精品bt天堂精选| 91影视在线播放| 日本女人一区二区三区| 国产欧美精品区一区二区三区| 在线观看一区二区视频| 毛片av一区二区| 综合婷婷亚洲小说| 日韩一区二区在线观看视频| 本田岬高潮一区二区三区| 亚州成人在线电影| 国产目拍亚洲精品99久久精品| 欧美自拍丝袜亚洲| 精品一区二区三区香蕉蜜桃| 亚洲日本一区二区| 精品三级在线看| 91成人网在线| 国产麻豆91精品| 午夜精品久久久久| 国产精品色一区二区三区| 91精品国产综合久久久久久久久久 | 91在线porny国产在线看| 日韩高清国产一区在线| 自拍av一区二区三区| 欧美一激情一区二区三区| 99精品国产99久久久久久白柏| 麻豆国产精品777777在线| 亚洲美女视频一区| 国产午夜亚洲精品理论片色戒| 欧美日韩精品一区二区三区四区 | 亚洲另类色综合网站| 26uuuu精品一区二区| 欧美日韩免费观看一区三区| 成人免费毛片高清视频| 久久99精品久久只有精品| 亚洲综合在线第一页|