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

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

?? inflate.c

?? ZIP壓縮算法源代碼,可以直接加入C++Project中編譯調用
?? C
?? 第 1 頁 / 共 4 頁
字號:
/* inflate.c -- zlib decompression
 * Copyright (C) 1995-2005 Mark Adler
 * For conditions of distribution and use, see copyright notice in zlib.h
 */

/*
 * Change history:
 *
 * 1.2.beta0    24 Nov 2002
 * - First version -- complete rewrite of inflate to simplify code, avoid
 *   creation of window when not needed, minimize use of window when it is
 *   needed, make inffast.c even faster, implement gzip decoding, and to
 *   improve code readability and style over the previous zlib inflate code
 *
 * 1.2.beta1    25 Nov 2002
 * - Use pointers for available input and output checking in inffast.c
 * - Remove input and output counters in inffast.c
 * - Change inffast.c entry and loop from avail_in >= 7 to >= 6
 * - Remove unnecessary second byte pull from length extra in inffast.c
 * - Unroll direct copy to three copies per loop in inffast.c
 *
 * 1.2.beta2    4 Dec 2002
 * - Change external routine names to reduce potential conflicts
 * - Correct filename to inffixed.h for fixed tables in inflate.c
 * - Make hbuf[] unsigned char to match parameter type in inflate.c
 * - Change strm->next_out[-state->offset] to *(strm->next_out - state->offset)
 *   to avoid negation problem on Alphas (64 bit) in inflate.c
 *
 * 1.2.beta3    22 Dec 2002
 * - Add comments on state->bits assertion in inffast.c
 * - Add comments on op field in inftrees.h
 * - Fix bug in reuse of allocated window after inflateReset()
 * - Remove bit fields--back to byte structure for speed
 * - Remove distance extra == 0 check in inflate_fast()--only helps for lengths
 * - Change post-increments to pre-increments in inflate_fast(), PPC biased?
 * - Add compile time option, POSTINC, to use post-increments instead (Intel?)
 * - Make MATCH copy in inflate() much faster for when inflate_fast() not used
 * - Use local copies of stream next and avail values, as well as local bit
 *   buffer and bit count in inflate()--for speed when inflate_fast() not used
 *
 * 1.2.beta4    1 Jan 2003
 * - Split ptr - 257 statements in inflate_table() to avoid compiler warnings
 * - Move a comment on output buffer sizes from inffast.c to inflate.c
 * - Add comments in inffast.c to introduce the inflate_fast() routine
 * - Rearrange window copies in inflate_fast() for speed and simplification
 * - Unroll last copy for window match in inflate_fast()
 * - Use local copies of window variables in inflate_fast() for speed
 * - Pull out common write == 0 case for speed in inflate_fast()
 * - Make op and len in inflate_fast() unsigned for consistency
 * - Add FAR to lcode and dcode declarations in inflate_fast()
 * - Simplified bad distance check in inflate_fast()
 * - Added inflateBackInit(), inflateBack(), and inflateBackEnd() in new
 *   source file infback.c to provide a call-back interface to inflate for
 *   programs like gzip and unzip -- uses window as output buffer to avoid
 *   window copying
 *
 * 1.2.beta5    1 Jan 2003
 * - Improved inflateBack() interface to allow the caller to provide initial
 *   input in strm.
 * - Fixed stored blocks bug in inflateBack()
 *
 * 1.2.beta6    4 Jan 2003
 * - Added comments in inffast.c on effectiveness of POSTINC
 * - Typecasting all around to reduce compiler warnings
 * - Changed loops from while (1) or do {} while (1) to for (;;), again to
 *   make compilers happy
 * - Changed type of window in inflateBackInit() to unsigned char *
 *
 * 1.2.beta7    27 Jan 2003
 * - Changed many types to unsigned or unsigned short to avoid warnings
 * - Added inflateCopy() function
 *
 * 1.2.0        9 Mar 2003
 * - Changed inflateBack() interface to provide separate opaque descriptors
 *   for the in() and out() functions
 * - Changed inflateBack() argument and in_func typedef to swap the length
 *   and buffer address return values for the input function
 * - Check next_in and next_out for Z_NULL on entry to inflate()
 *
 * The history for versions after 1.2.0 are in ChangeLog in zlib distribution.
 */

#include "zutil.h"
#include "inftrees.h"
#include "inflate.h"
#include "inffast.h"

#ifdef MAKEFIXED
#  ifndef BUILDFIXED
#    define BUILDFIXED
#  endif
#endif

/* function prototypes */
local void fixedtables OF((struct inflate_state FAR *state));
local int updatewindow OF((z_streamp strm, unsigned out));
#ifdef BUILDFIXED
   void makefixed OF((void));
#endif
local unsigned syncsearch OF((unsigned FAR *have, unsigned char FAR *buf,
                              unsigned len));

int ZEXPORT inflateReset(strm)
z_streamp strm;
{
    struct inflate_state FAR *state;

    if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR;
    state = (struct inflate_state FAR *)strm->state;
    strm->total_in = strm->total_out = state->total = 0;
    strm->msg = Z_NULL;
    strm->adler = 1;        /* to support ill-conceived Java test suite */
    state->mode = HEAD;
    state->last = 0;
    state->havedict = 0;
    state->dmax = 32768U;
    state->head = Z_NULL;
    state->wsize = 0;
    state->whave = 0;
    state->write = 0;
    state->hold = 0;
    state->bits = 0;
    state->lencode = state->distcode = state->next = state->codes;
    Tracev((stderr, "inflate: reset\n"));
    return Z_OK;
}

int ZEXPORT inflatePrime(strm, bits, value)
z_streamp strm;
int bits;
int value;
{
    struct inflate_state FAR *state;

    if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR;
    state = (struct inflate_state FAR *)strm->state;
    if (bits > 16 || state->bits + bits > 32) return Z_STREAM_ERROR;
    value &= (1L << bits) - 1;
    state->hold += value << state->bits;
    state->bits += bits;
    return Z_OK;
}

int ZEXPORT inflateInit2_(strm, windowBits, version, stream_size)
z_streamp strm;
int windowBits;
const char *version;
int stream_size;
{
    struct inflate_state FAR *state;

    if (version == Z_NULL || version[0] != ZLIB_VERSION[0] ||
        stream_size != (int)(sizeof(z_stream)))
        return Z_VERSION_ERROR;
    if (strm == Z_NULL) return Z_STREAM_ERROR;
    strm->msg = Z_NULL;                 /* in case we return an error */
    if (strm->zalloc == (alloc_func)0) {
        strm->zalloc = zcalloc;
        strm->opaque = (voidpf)0;
    }
    if (strm->zfree == (free_func)0) strm->zfree = zcfree;
    state = (struct inflate_state FAR *)
            ZALLOC(strm, 1, sizeof(struct inflate_state));
    if (state == Z_NULL) return Z_MEM_ERROR;
    Tracev((stderr, "inflate: allocated\n"));
    strm->state = (struct internal_state FAR *)state;
    if (windowBits < 0) {
        state->wrap = 0;
        windowBits = -windowBits;
    }
    else {
        state->wrap = (windowBits >> 4) + 1;
#ifdef GUNZIP
        if (windowBits < 48) windowBits &= 15;
#endif
    }
    if (windowBits < 8 || windowBits > 15) {
        ZFREE(strm, state);
        strm->state = Z_NULL;
        return Z_STREAM_ERROR;
    }
    state->wbits = (unsigned)windowBits;
    state->window = Z_NULL;
    return inflateReset(strm);
}

int ZEXPORT inflateInit_(strm, version, stream_size)
z_streamp strm;
const char *version;
int stream_size;
{
    return inflateInit2_(strm, DEF_WBITS, version, stream_size);
}

/*
   Return state with length and distance decoding tables and index sizes set to
   fixed code decoding.  Normally this returns fixed tables from inffixed.h.
   If BUILDFIXED is defined, then instead this routine builds the tables the
   first time it's called, and returns those tables the first time and
   thereafter.  This reduces the size of the code by about 2K bytes, in
   exchange for a little execution time.  However, BUILDFIXED should not be
   used for threaded applications, since the rewriting of the tables and virgin
   may not be thread-safe.
 */
local void fixedtables(state)
struct inflate_state FAR *state;
{
#ifdef BUILDFIXED
    static int virgin = 1;
    static code *lenfix, *distfix;
    static code fixed[544];

    /* build fixed huffman tables if first call (may not be thread safe) */
    if (virgin) {
        unsigned sym, bits;
        static code *next;

        /* literal/length table */
        sym = 0;
        while (sym < 144) state->lens[sym++] = 8;
        while (sym < 256) state->lens[sym++] = 9;
        while (sym < 280) state->lens[sym++] = 7;
        while (sym < 288) state->lens[sym++] = 8;
        next = fixed;
        lenfix = next;
        bits = 9;
        inflate_table(LENS, state->lens, 288, &(next), &(bits), state->work);

        /* distance table */
        sym = 0;
        while (sym < 32) state->lens[sym++] = 5;
        distfix = next;
        bits = 5;
        inflate_table(DISTS, state->lens, 32, &(next), &(bits), state->work);

        /* do this just once */
        virgin = 0;
    }
#else /* !BUILDFIXED */
#   include "inffixed.h"
#endif /* BUILDFIXED */
    state->lencode = lenfix;
    state->lenbits = 9;
    state->distcode = distfix;
    state->distbits = 5;
}

#ifdef MAKEFIXED
#include <stdio.h>

/*
   Write out the inffixed.h that is #include'd above.  Defining MAKEFIXED also
   defines BUILDFIXED, so the tables are built on the fly.  makefixed() writes
   those tables to stdout, which would be piped to inffixed.h.  A small program
   can simply call makefixed to do this:

    void makefixed(void);

    int main(void)
    {
        makefixed();
        return 0;
    }

   Then that can be linked with zlib built with MAKEFIXED defined and run:

    a.out > inffixed.h
 */
void makefixed()
{
    unsigned low, size;
    struct inflate_state state;

    fixedtables(&state);
    puts("    /* inffixed.h -- table for decoding fixed codes");
    puts("     * Generated automatically by makefixed().");
    puts("     */");
    puts("");
    puts("    /* WARNING: this file should *not* be used by applications.");
    puts("       It is part of the implementation of this library and is");
    puts("       subject to change. Applications should only use zlib.h.");
    puts("     */");
    puts("");
    size = 1U << 9;
    printf("    static const code lenfix[%u] = {", size);
    low = 0;
    for (;;) {
        if ((low % 7) == 0) printf("\n        ");
        printf("{%u,%u,%d}", state.lencode[low].op, state.lencode[low].bits,
               state.lencode[low].val);
        if (++low == size) break;
        putchar(',');
    }
    puts("\n    };");
    size = 1U << 5;
    printf("\n    static const code distfix[%u] = {", size);
    low = 0;
    for (;;) {
        if ((low % 6) == 0) printf("\n        ");
        printf("{%u,%u,%d}", state.distcode[low].op, state.distcode[low].bits,
               state.distcode[low].val);
        if (++low == size) break;
        putchar(',');
    }
    puts("\n    };");
}
#endif /* MAKEFIXED */

/*
   Update the window with the last wsize (normally 32K) bytes written before
   returning.  If window does not exist yet, create it.  This is only called
   when a window is already in use, or when output has been written during this
   inflate call, but the end of the deflate stream has not been reached yet.
   It is also called to create a window for dictionary data when a dictionary
   is loaded.

   Providing output buffers larger than 32K to inflate() should provide a speed
   advantage, since only the last 32K of output is copied to the sliding window
   upon return from inflate(), and since all distances after the first 32K of
   output will fall in the output data, making match copies simpler and faster.
   The advantage may be dependent on the size of the processor's data caches.
 */
local int updatewindow(strm, out)
z_streamp strm;
unsigned out;
{
    struct inflate_state FAR *state;
    unsigned copy, dist;

    state = (struct inflate_state FAR *)strm->state;

    /* if it hasn't been done already, allocate space for the window */
    if (state->window == Z_NULL) {
        state->window = (unsigned char FAR *)
                        ZALLOC(strm, 1U << state->wbits,
                               sizeof(unsigned char));
        if (state->window == Z_NULL) return 1;
    }

    /* if window not in use yet, initialize */
    if (state->wsize == 0) {
        state->wsize = 1U << state->wbits;
        state->write = 0;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩欧美国产电影| 久久99精品一区二区三区| 欧美国产一区视频在线观看| 精品国产乱码久久久久久浪潮| 欧美成人精品福利| 欧美xxxx在线观看| 国产精品久久久久久久久图文区| 国产色一区二区| 亚洲一区二区三区四区中文字幕 | 欧美在线色视频| 欧美一区二区网站| 国产亚洲制服色| 亚洲美女免费视频| 免费欧美在线视频| 色婷婷久久久久swag精品 | 日韩情涩欧美日韩视频| 欧美四级电影网| 久久久av毛片精品| 久久精品视频免费| 欧美美女激情18p| 99视频一区二区三区| 久久黄色级2电影| 视频一区中文字幕国产| 亚洲欧洲精品成人久久奇米网| 日韩美女在线视频 | 99久久伊人网影院| 国产精品一区二区x88av| 日韩电影在线免费| 亚洲一区二区三区三| 一区视频在线播放| 国产精品无遮挡| 国产欧美日韩精品在线| 欧美sm极限捆绑bd| 久久久久久99久久久精品网站| 日韩一区二区在线播放| 日韩一区二区三区电影| 日韩视频在线你懂得| 2021国产精品久久精品| 国产喷白浆一区二区三区| 久久精品欧美一区二区三区麻豆| 久久久久久麻豆| 久久婷婷久久一区二区三区| 久久久国产综合精品女国产盗摄| 国产精品丝袜黑色高跟| 亚洲一区av在线| 奇米影视一区二区三区小说| 日韩在线卡一卡二| 国产成人精品aa毛片| 在线观看三级视频欧美| 日韩欧美一二区| 中文字幕一区二区三区在线观看| 一区二区三区在线影院| 中文字幕在线一区| 一区二区三区在线观看视频 | 蜜臀久久99精品久久久久宅男| 精品亚洲免费视频| 欧美三级乱人伦电影| 欧美激情一区在线| 精品一区二区三区免费播放| 色噜噜狠狠色综合中国 | 中文字幕亚洲欧美在线不卡| 一区二区三区精品| 成人av在线网站| 精品少妇一区二区三区| 秋霞影院一区二区| 欧美性色黄大片手机版| 亚洲丝袜精品丝袜在线| 成人做爰69片免费看网站| 亚洲精品一区二区三区精华液| 亚洲 欧美综合在线网络| 91搞黄在线观看| 亚洲婷婷综合色高清在线| 91色九色蝌蚪| 亚洲精品中文字幕在线观看| 在线看一区二区| 亚洲va天堂va国产va久| 欧美日本视频在线| 午夜视黄欧洲亚洲| 91精品国产91久久综合桃花| 麻豆国产精品一区二区三区| 久久伊人中文字幕| 激情五月婷婷综合| 久久人人97超碰com| 成人app软件下载大全免费| 亚洲色图制服诱惑| 欧美中文字幕一区| 久久精品久久精品| 国产区在线观看成人精品| 94-欧美-setu| 麻豆久久久久久| 国产亚洲精品bt天堂精选| 一本色道久久综合亚洲精品按摩| 午夜影院在线观看欧美| 久久嫩草精品久久久久| 日本高清不卡aⅴ免费网站| 蜜桃91丨九色丨蝌蚪91桃色| 国产精品久久久久久久久免费樱桃| 色综合天天综合狠狠| 美女性感视频久久| 亚洲影视在线播放| 亚洲国产成人在线| 久久久久久久久久久电影| 欧美日韩在线免费视频| 99免费精品视频| 国产很黄免费观看久久| 久久99国产精品久久| 亚洲成人av中文| 亚洲激情欧美激情| 亚洲精品国产精品乱码不99| 国产欧美日韩在线观看| 精品奇米国产一区二区三区| 91精品麻豆日日躁夜夜躁| 欧美视频你懂的| 正在播放亚洲一区| 欧美美女一区二区在线观看| 欧美高清视频不卡网| 欧美亚洲动漫精品| 欧美图片一区二区三区| 欧美日韩一区二区三区不卡| 欧美二区在线观看| 日韩欧美资源站| 精品国产一二三| 久久久久久久电影| 亚洲精品精品亚洲| 国产精品成人免费在线| 亚洲天堂网中文字| 日韩va欧美va亚洲va久久| 秋霞国产午夜精品免费视频| 国产一区二区在线电影| 国产成人免费视| 在线观看日韩av先锋影音电影院| 一本大道久久精品懂色aⅴ| 欧美日韩dvd在线观看| 精品国产亚洲一区二区三区在线观看 | 日韩免费性生活视频播放| 国产欧美精品区一区二区三区 | 综合分类小说区另类春色亚洲小说欧美 | 婷婷激情综合网| 成人午夜电影网站| 欧美电影免费观看高清完整版| 日本一区二区成人| 久久精品国产成人一区二区三区 | 视频一区欧美精品| av网站一区二区三区| 日韩欧美国产1| 亚洲日本va在线观看| 岛国精品在线播放| 久久色中文字幕| 免费日本视频一区| 欧美日韩在线综合| 一区二区三区不卡视频在线观看| 久久黄色级2电影| 日韩午夜电影在线观看| 丝袜亚洲精品中文字幕一区| 欧美性猛交xxxxxxxx| 日韩一区有码在线| 91在线看国产| 亚洲人成影院在线观看| 91丨porny丨蝌蚪视频| 亚洲精品自拍动漫在线| 欧美自拍丝袜亚洲| 亚洲免费电影在线| 欧美熟乱第一页| 免费观看在线综合| 欧美猛男超大videosgay| 偷窥少妇高潮呻吟av久久免费| 欧美精品免费视频| 久久国产麻豆精品| 国产精品麻豆99久久久久久| 99精品视频一区二区三区| 一区二区日韩电影| 91精品国产综合久久小美女| 国产福利一区二区三区视频 | 欧美日韩在线亚洲一区蜜芽| 男女激情视频一区| 国产精品午夜电影| 欧美日韩久久久一区| 国产精品资源在线看| 一区二区三区成人在线视频| 日韩欧美在线观看一区二区三区| 成人a区在线观看| 蜜臀av性久久久久蜜臀aⅴ流畅| 中文字幕乱码亚洲精品一区| 制服丝袜av成人在线看| 一本色道a无线码一区v| 美女视频免费一区| 亚洲不卡在线观看| 中文字幕制服丝袜一区二区三区 | 中文字幕日本乱码精品影院| 91精品婷婷国产综合久久性色 | 成人一道本在线| 精品一区二区三区免费视频| 视频精品一区二区| 亚洲精品乱码久久久久久黑人| 精品国产123| 国产午夜亚洲精品羞羞网站| 欧美成人精品福利| 精品国产免费一区二区三区香蕉| 欧美日韩成人一区二区| 欧美日韩在线电影|