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

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

?? infback.c

?? 一個本地database引擎,支持中文T_Sql查詢,兼容DELPHI標準數據庫控件
?? C
?? 第 1 頁 / 共 2 頁
字號:
            }
            DROPBITS(2);
            break;

        case STORED:
            /* get and verify stored block length */
            BYTEBITS();                         /* go to byte boundary */
            NEEDBITS(32);
            if ((hold & 0xffff) != ((hold >> 16) ^ 0xffff)) {
                strm->msg = (char *)"invalid stored block lengths";
                state->mode = BAD;
                break;
            }
            state->length = (unsigned)hold & 0xffff;
            Tracev((stderr, "inflate:       stored length %u\n",
                    state->length));
            INITBITS();

            /* copy stored block from input to output */
            while (state->length != 0) {
                copy = state->length;
                PULL();
                ROOM();
                if (copy > have) copy = have;
                if (copy > left) copy = left;
                zmemcpy(put, next, copy);
                have -= copy;
                next += copy;
                left -= copy;
                put += copy;
                state->length -= copy;
            }
            Tracev((stderr, "inflate:       stored end\n"));
            state->mode = TYPE;
            break;

        case TABLE:
            /* get dynamic table entries descriptor */
            NEEDBITS(14);
            state->nlen = BITS(5) + 257;
            DROPBITS(5);
            state->ndist = BITS(5) + 1;
            DROPBITS(5);
            state->ncode = BITS(4) + 4;
            DROPBITS(4);
#ifndef PKZIP_BUG_WORKAROUND
            if (state->nlen > 286 || state->ndist > 30) {
                strm->msg = (char *)"too many length or distance symbols";
                state->mode = BAD;
                break;
            }
#endif
            Tracev((stderr, "inflate:       table sizes ok\n"));

            /* get code length code lengths (not a typo) */
            state->have = 0;
            while (state->have < state->ncode) {
                NEEDBITS(3);
                state->lens[order[state->have++]] = (unsigned short)BITS(3);
                DROPBITS(3);
            }
            while (state->have < 19)
                state->lens[order[state->have++]] = 0;
            state->next = state->codes;
            state->lencode = (code const FAR *)(state->next);
            state->lenbits = 7;
            ret = inflate_table(CODES, state->lens, 19, &(state->next),
                                &(state->lenbits), state->work);
            if (ret) {
                strm->msg = (char *)"invalid code lengths set";
                state->mode = BAD;
                break;
            }
            Tracev((stderr, "inflate:       code lengths ok\n"));

            /* get length and distance code code lengths */
            state->have = 0;
            while (state->have < state->nlen + state->ndist) {
                for (;;) {
                    this = state->lencode[BITS(state->lenbits)];
                    if ((unsigned)(this.bits) <= bits) break;
                    PULLBYTE();
                }
                if (this.val < 16) {
                    NEEDBITS(this.bits);
                    DROPBITS(this.bits);
                    state->lens[state->have++] = this.val;
                }
                else {
                    if (this.val == 16) {
                        NEEDBITS(this.bits + 2);
                        DROPBITS(this.bits);
                        if (state->have == 0) {
                            strm->msg = (char *)"invalid bit length repeat";
                            state->mode = BAD;
                            break;
                        }
                        len = (unsigned)(state->lens[state->have - 1]);
                        copy = 3 + BITS(2);
                        DROPBITS(2);
                    }
                    else if (this.val == 17) {
                        NEEDBITS(this.bits + 3);
                        DROPBITS(this.bits);
                        len = 0;
                        copy = 3 + BITS(3);
                        DROPBITS(3);
                    }
                    else {
                        NEEDBITS(this.bits + 7);
                        DROPBITS(this.bits);
                        len = 0;
                        copy = 11 + BITS(7);
                        DROPBITS(7);
                    }
                    if (state->have + copy > state->nlen + state->ndist) {
                        strm->msg = (char *)"invalid bit length repeat";
                        state->mode = BAD;
                        break;
                    }
                    while (copy--)
                        state->lens[state->have++] = (unsigned short)len;
                }
            }

            /* handle error breaks in while */
            if (state->mode == BAD) break;

            /* build code tables */
            state->next = state->codes;
            state->lencode = (code const FAR *)(state->next);
            state->lenbits = 9;
            ret = inflate_table(LENS, state->lens, state->nlen, &(state->next),
                                &(state->lenbits), state->work);
            if (ret) {
                strm->msg = (char *)"invalid literal/lengths set";
                state->mode = BAD;
                break;
            }
            state->distcode = (code const FAR *)(state->next);
            state->distbits = 6;
            ret = inflate_table(DISTS, state->lens + state->nlen, state->ndist,
                            &(state->next), &(state->distbits), state->work);
            if (ret) {
                strm->msg = (char *)"invalid distances set";
                state->mode = BAD;
                break;
            }
            Tracev((stderr, "inflate:       codes ok\n"));
            state->mode = LEN;

        case LEN:
            /* use inflate_fast() if we have enough input and output */
            if (have >= 6 && left >= 258) {
                RESTORE();
                if (state->whave < state->wsize)
                    state->whave = state->wsize - left;
                inflate_fast(strm, state->wsize);
                LOAD();
                break;
            }

            /* get a literal, length, or end-of-block code */
            for (;;) {
                this = state->lencode[BITS(state->lenbits)];
                if ((unsigned)(this.bits) <= bits) break;
                PULLBYTE();
            }
            if (this.op && (this.op & 0xf0) == 0) {
                last = this;
                for (;;) {
                    this = state->lencode[last.val +
                            (BITS(last.bits + last.op) >> last.bits)];
                    if ((unsigned)(last.bits + this.bits) <= bits) break;
                    PULLBYTE();
                }
                DROPBITS(last.bits);
            }
            DROPBITS(this.bits);
            state->length = (unsigned)this.val;

            /* process literal */
            if (this.op == 0) {
                Tracevv((stderr, this.val >= 0x20 && this.val < 0x7f ?
                        "inflate:         literal '%c'\n" :
                        "inflate:         literal 0x%02x\n", this.val));
                ROOM();
                *put++ = (unsigned char)(state->length);
                left--;
                state->mode = LEN;
                break;
            }

            /* process end of block */
            if (this.op & 32) {
                Tracevv((stderr, "inflate:         end of block\n"));
                state->mode = TYPE;
                break;
            }

            /* invalid code */
            if (this.op & 64) {
                strm->msg = (char *)"invalid literal/length code";
                state->mode = BAD;
                break;
            }

            /* length code -- get extra bits, if any */
            state->extra = (unsigned)(this.op) & 15;
            if (state->extra != 0) {
                NEEDBITS(state->extra);
                state->length += BITS(state->extra);
                DROPBITS(state->extra);
            }
            Tracevv((stderr, "inflate:         length %u\n", state->length));

            /* get distance code */
            for (;;) {
                this = state->distcode[BITS(state->distbits)];
                if ((unsigned)(this.bits) <= bits) break;
                PULLBYTE();
            }
            if ((this.op & 0xf0) == 0) {
                last = this;
                for (;;) {
                    this = state->distcode[last.val +
                            (BITS(last.bits + last.op) >> last.bits)];
                    if ((unsigned)(last.bits + this.bits) <= bits) break;
                    PULLBYTE();
                }
                DROPBITS(last.bits);
            }
            DROPBITS(this.bits);
            if (this.op & 64) {
                strm->msg = (char *)"invalid distance code";
                state->mode = BAD;
                break;
            }
            state->offset = (unsigned)this.val;

            /* get distance extra bits, if any */
            state->extra = (unsigned)(this.op) & 15;
            if (state->extra != 0) {
                NEEDBITS(state->extra);
                state->offset += BITS(state->extra);
                DROPBITS(state->extra);
            }
            if (state->offset > state->wsize - (state->whave < state->wsize ?
                                                left : 0)) {
                strm->msg = (char *)"invalid distance too far back";
                state->mode = BAD;
                break;
            }
            Tracevv((stderr, "inflate:         distance %u\n", state->offset));

            /* copy match from window to output */
            do {
                ROOM();
                copy = state->wsize - state->offset;
                if (copy < left) {
                    from = put + copy;
                    copy = left - copy;
                }
                else {
                    from = put - state->offset;
                    copy = left;
                }
                if (copy > state->length) copy = state->length;
                state->length -= copy;
                left -= copy;
                do {
                    *put++ = *from++;
                } while (--copy);
            } while (state->length != 0);
            break;

        case DONE:
            /* inflate stream terminated properly -- write leftover output */
            ret = Z_STREAM_END;
            if (left < state->wsize) {
                if (out(out_desc, state->window, state->wsize - left))
                    ret = Z_BUF_ERROR;
            }
            goto inf_leave;

        case BAD:
            ret = Z_DATA_ERROR;
            goto inf_leave;

        default:                /* can't happen, but makes compilers happy */
            ret = Z_STREAM_ERROR;
            goto inf_leave;
        }

    /* Return unused input */
  inf_leave:
    strm->next_in = next;
    strm->avail_in = have;
    return ret;
}

int ZEXPORT inflateBackEnd(strm)
z_streamp strm;
{
    if (strm == Z_NULL || strm->state == Z_NULL || strm->zfree == (free_func)0)
        return Z_STREAM_ERROR;
    ZFREE(strm, strm->state);
    strm->state = Z_NULL;
    Tracev((stderr, "inflate: end\n"));
    return Z_OK;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美剧情片在线观看| 国产一区999| 中文字幕精品一区二区三区精品| 欧美日韩国产在线播放网站| 91久久精品日日躁夜夜躁欧美| 国产高清亚洲一区| caoporen国产精品视频| 国产成人精品一区二区三区四区 | 亚洲欧美日韩在线播放| 国产亚洲综合性久久久影院| 26uuu久久天堂性欧美| 欧美精品日韩精品| 欧美久久免费观看| 欧美日韩视频在线一区二区| 色乱码一区二区三区88| 97久久超碰国产精品| 91看片淫黄大片一级在线观看| 国产精品一二三| 国产精品99久久久久久似苏梦涵| 美国av一区二区| 九色综合狠狠综合久久| 精品在线一区二区三区| 美女尤物国产一区| 麻豆91小视频| 国产精品99久久久久久宅男| 国产成人精品影视| 99久久综合精品| 在线看国产一区二区| 欧美日韩一级视频| 91精选在线观看| 日韩网站在线看片你懂的| 久久久久久久电影| 国产精品日韩精品欧美在线| 国产精品久久久久一区二区三区| 最新国产成人在线观看| 亚洲欧美在线视频| 亚洲欧洲www| 日韩国产在线观看一区| 久久激情五月激情| 国产剧情一区在线| 免费精品视频最新在线| 国产a久久麻豆| 精品1区2区3区| 欧美大肚乱孕交hd孕妇| 中文字幕一区二区三区在线播放| 亚洲男人的天堂av| 婷婷国产v国产偷v亚洲高清| 国产剧情一区二区三区| 在线免费观看日本一区| 精品国精品国产| 中文字幕一区二区三区蜜月| 夜夜嗨av一区二区三区| 亚洲成年人影院| 国产一区不卡在线| 欧美午夜在线一二页| 久久精品亚洲精品国产欧美kt∨ | 成人av在线网| 欧美男人的天堂一二区| 国产精品每日更新| 免费在线看成人av| 色视频一区二区| 日韩免费视频一区二区| 亚洲人成伊人成综合网小说| 青青草97国产精品免费观看| 一本到不卡精品视频在线观看| 欧美日韩一区二区三区免费看| 国产欧美日韩三区| 婷婷国产v国产偷v亚洲高清| av成人动漫在线观看| 精品久久久久久久久久久久久久久久久 | 国产精品原创巨作av| 欧美影院一区二区三区| 国产精品久久久久久户外露出 | 日韩高清在线观看| 成人激情图片网| 久久综合久色欧美综合狠狠| 午夜激情久久久| 欧美综合在线视频| 日韩美女视频19| 成人18精品视频| 国产三级一区二区三区| 精品亚洲aⅴ乱码一区二区三区| 欧美日韩国产电影| 亚洲精品高清视频在线观看| 粉嫩aⅴ一区二区三区四区| 日韩欧美国产三级| 免费成人在线播放| 欧美日韩国产综合视频在线观看| 欧美国产亚洲另类动漫| 国产一区二区福利视频| 久久日韩粉嫩一区二区三区| 韩国一区二区在线观看| 精品国产乱码久久久久久蜜臀| 天天综合天天做天天综合| 欧美伊人久久久久久久久影院| 亚洲免费观看高清完整版在线| 成人丝袜18视频在线观看| 国产三级精品三级在线专区| 国模少妇一区二区三区| 久久精品日产第一区二区三区高清版 | 在线免费不卡视频| 亚洲国产乱码最新视频| 欧美日韩亚洲综合一区| 日韩成人免费在线| 欧美变态tickling挠脚心| 午夜免费久久看| 欧美三级日韩在线| 亚洲一区二区视频在线观看| 97se亚洲国产综合在线| 亚洲小说春色综合另类电影| 成人18精品视频| 亚洲伊人伊色伊影伊综合网| 99久久久久久| 亚洲欧美经典视频| 一本久道久久综合中文字幕| 亚洲女同ⅹxx女同tv| 欧美亚洲一区二区在线| 亚洲成人中文在线| 欧美成人乱码一区二区三区| 久久黄色级2电影| 精品粉嫩aⅴ一区二区三区四区| 日本在线不卡视频一二三区| 国产欧美一二三区| 成人ar影院免费观看视频| 亚洲欧美aⅴ...| 91精品午夜视频| 国产美女视频91| 亚洲激情图片一区| 久久免费偷拍视频| 99视频精品免费视频| 天堂精品中文字幕在线| 欧美激情一区二区三区不卡 | 成人免费看视频| 日韩中文字幕区一区有砖一区| 国产亚洲成av人在线观看导航 | 亚洲一线二线三线视频| 精品成人一区二区三区四区| 色伊人久久综合中文字幕| 午夜欧美视频在线观看| 中文字幕精品—区二区四季| 欧美日韩国产综合一区二区| 成人免费va视频| 美腿丝袜亚洲色图| 亚洲精品久久久蜜桃| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 亚洲图片欧美一区| 欧美国产亚洲另类动漫| 精品乱码亚洲一区二区不卡| 欧美伊人精品成人久久综合97| 国产精品一卡二卡| 免费人成黄页网站在线一区二区| 亚洲少妇30p| 久久精品无码一区二区三区| 91精品国产欧美日韩| 日本国产一区二区| 成人av在线电影| 国产成人av电影在线播放| 亚洲女与黑人做爰| 亚洲欧美电影院| 精品成人在线观看| 欧美日韩国产一二三| 国产精品亚洲专一区二区三区 | 91麻豆国产精品久久| 精品亚洲成av人在线观看| 日本欧美一区二区| 偷窥少妇高潮呻吟av久久免费| 亚洲精品视频在线观看免费| 中文字幕精品一区| 亚洲国产岛国毛片在线| 国产日产精品一区| 国产欧美一区二区三区网站| 久久中文字幕电影| 久久久久免费观看| 久久精品视频免费观看| 日韩午夜三级在线| 欧美一区二区精品久久911| 日韩精品成人一区二区三区| 亚洲色欲色欲www在线观看| 国产精品毛片a∨一区二区三区| 日韩天堂在线观看| 精品免费视频.| 精品国产电影一区二区| 在线视频欧美区| 色综合网站在线| 91亚洲精品久久久蜜桃| 91天堂素人约啪| 99热这里都是精品| 91福利在线导航| 欧美视频在线不卡| 日韩精品综合一本久道在线视频| 欧美精品一区视频| 自拍偷拍欧美精品| 午夜精品久久久久久不卡8050| 青青草国产精品亚洲专区无| 国产美女精品在线| 91丨九色丨蝌蚪富婆spa| 欧美三级韩国三级日本三斤| 日韩一区二区免费高清| 国产亚洲综合性久久久影院| 亚洲欧美国产高清|