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

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

?? inflate.c

?? ZIP壓縮算法源代碼,可以直接加入C++Project中編譯調用
?? C
?? 第 1 頁 / 共 4 頁
字號:
                        len = state->head->extra_len - state->length;
                        zmemcpy(state->head->extra + len, next,
                                len + copy > state->head->extra_max ?
                                state->head->extra_max - len : copy);
                    }
                    if (state->flags & 0x0200)
                        state->check = crc32(state->check, next, copy);
                    have -= copy;
                    next += copy;
                    state->length -= copy;
                }
                if (state->length) goto inf_leave;
            }
            state->length = 0;
            state->mode = NAME;
        case NAME:
            if (state->flags & 0x0800) {
                if (have == 0) goto inf_leave;
                copy = 0;
                do {
                    len = (unsigned)(next[copy++]);
                    if (state->head != Z_NULL &&
                            state->head->name != Z_NULL &&
                            state->length < state->head->name_max)
                        state->head->name[state->length++] = len;
                } while (len && copy < have);
                if (state->flags & 0x0200)
                    state->check = crc32(state->check, next, copy);
                have -= copy;
                next += copy;
                if (len) goto inf_leave;
            }
            else if (state->head != Z_NULL)
                state->head->name = Z_NULL;
            state->length = 0;
            state->mode = COMMENT;
        case COMMENT:
            if (state->flags & 0x1000) {
                if (have == 0) goto inf_leave;
                copy = 0;
                do {
                    len = (unsigned)(next[copy++]);
                    if (state->head != Z_NULL &&
                            state->head->comment != Z_NULL &&
                            state->length < state->head->comm_max)
                        state->head->comment[state->length++] = len;
                } while (len && copy < have);
                if (state->flags & 0x0200)
                    state->check = crc32(state->check, next, copy);
                have -= copy;
                next += copy;
                if (len) goto inf_leave;
            }
            else if (state->head != Z_NULL)
                state->head->comment = Z_NULL;
            state->mode = HCRC;
        case HCRC:
            if (state->flags & 0x0200) {
                NEEDBITS(16);
                if (hold != (state->check & 0xffff)) {
                    strm->msg = (char *)"header crc mismatch";
                    state->mode = BAD;
                    break;
                }
                INITBITS();
            }
            if (state->head != Z_NULL) {
                state->head->hcrc = (int)((state->flags >> 9) & 1);
                state->head->done = 1;
            }
            strm->adler = state->check = crc32(0L, Z_NULL, 0);
            state->mode = TYPE;
            break;
#endif
        case DICTID:
            NEEDBITS(32);
            strm->adler = state->check = REVERSE(hold);
            INITBITS();
            state->mode = DICT;
        case DICT:
            if (state->havedict == 0) {
                RESTORE();
                return Z_NEED_DICT;
            }
            strm->adler = state->check = adler32(0L, Z_NULL, 0);
            state->mode = TYPE;
        case TYPE:
            if (flush == Z_BLOCK) goto inf_leave;
        case TYPEDO:
            if (state->last) {
                BYTEBITS();
                state->mode = CHECK;
                break;
            }
            NEEDBITS(3);
            state->last = BITS(1);
            DROPBITS(1);
            switch (BITS(2)) {
            case 0:                             /* stored block */
                Tracev((stderr, "inflate:     stored block%s\n",
                        state->last ? " (last)" : ""));
                state->mode = STORED;
                break;
            case 1:                             /* fixed block */
                fixedtables(state);
                Tracev((stderr, "inflate:     fixed codes block%s\n",
                        state->last ? " (last)" : ""));
                state->mode = LEN;              /* decode codes */
                break;
            case 2:                             /* dynamic block */
                Tracev((stderr, "inflate:     dynamic codes block%s\n",
                        state->last ? " (last)" : ""));
                state->mode = TABLE;
                break;
            case 3:
                strm->msg = (char *)"invalid block type";
                state->mode = BAD;
            }
            DROPBITS(2);
            break;
        case STORED:
            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();
            state->mode = COPY;
        case COPY:
            copy = state->length;
            if (copy) {
                if (copy > have) copy = have;
                if (copy > left) copy = left;
                if (copy == 0) goto inf_leave;
                zmemcpy(put, next, copy);
                have -= copy;
                next += copy;
                left -= copy;
                put += copy;
                state->length -= copy;
                break;
            }
            Tracev((stderr, "inflate:       stored end\n"));
            state->mode = TYPE;
            break;
        case TABLE:
            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"));
            state->have = 0;
            state->mode = LENLENS;
        case LENLENS:
            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"));
            state->have = 0;
            state->mode = CODELENS;
        case CODELENS:
            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 = 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:
            if (have >= 6 && left >= 258) {
                RESTORE();
                inflate_fast(strm, out);
                LOAD();
                break;
            }
            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;
            if ((int)(this.op) == 0) {
                Tracevv((stderr, this.val >= 0x20 && this.val < 0x7f ?
                        "inflate:         literal '%c'\n" :
                        "inflate:         literal 0x%02x\n", this.val));
                state->mode = LIT;
                break;
            }
            if (this.op & 32) {
                Tracevv((stderr, "inflate:         end of block\n"));
                state->mode = TYPE;
                break;
            }
            if (this.op & 64) {
                strm->msg = (char *)"invalid literal/length code";
                state->mode = BAD;
                break;
            }
            state->extra = (unsigned)(this.op) & 15;
            state->mode = LENEXT;
        case LENEXT:
            if (state->extra) {
                NEEDBITS(state->extra);
                state->length += BITS(state->extra);
                DROPBITS(state->extra);
            }
            Tracevv((stderr, "inflate:         length %u\n", state->length));
            state->mode = DIST;
        case DIST:
            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;
            state->extra = (unsigned)(this.op) & 15;
            state->mode = DISTEXT;
        case DISTEXT:
            if (state->extra) {
                NEEDBITS(state->extra);
                state->offset += BITS(state->extra);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产精品自拍| 综合自拍亚洲综合图不卡区| 在线播放中文字幕一区| 国产亚洲欧美在线| 欧美日韩不卡在线| 免播放器亚洲一区| 色琪琪一区二区三区亚洲区| 国产精品久久久久久久久久免费看| 91网站在线播放| 久久久久久久综合| 国产一区亚洲一区| 日产精品久久久久久久性色| 亚洲国产精品人人做人人爽| 欧美激情综合网| 一区二区三区免费观看| 国产麻豆日韩欧美久久| 91麻豆精品国产综合久久久久久 | 91蜜桃传媒精品久久久一区二区| 2023国产精品视频| 欧美日韩一级黄| 成人综合婷婷国产精品久久| 在线日韩av片| 亚洲欧洲综合另类在线| 欧美一区二区三区四区在线观看 | 日韩精品国产精品| 在线91免费看| 日韩国产欧美在线播放| 国产精品黄色在线观看| 亚洲精品免费播放| 亚洲三级在线观看| 亚洲123区在线观看| 91蝌蚪porny| 4438x亚洲最大成人网| 一个色在线综合| 天堂资源在线中文精品| 欧美日韩国产精选| 亚洲欧洲精品一区二区精品久久久 | 亚洲另类一区二区| 久久午夜免费电影| 亚洲激情成人在线| 亚洲特黄一级片| 欧美国产精品v| 午夜精品福利在线| 9久草视频在线视频精品| 久久综合九色综合97婷婷| 亚洲18女电影在线观看| 日韩美女视频在线| 亚洲精品日产精品乱码不卡| av午夜一区麻豆| 亚洲男同性恋视频| 欧美一区二区日韩| 韩国av一区二区| 国产乱码精品1区2区3区| 免费成人你懂的| 在线观看av一区二区| 高清在线不卡av| 轻轻草成人在线| 另类小说图片综合网| 高清在线不卡av| 欧美mv日韩mv国产网站| 国产精品538一区二区在线| 天天综合色天天| 国产欧美日韩在线看| 国产成人在线视频播放| 一区二区在线观看不卡| 欧美精品一区二区久久婷婷 | 99精品久久久久久| 在线免费av一区| 成人在线一区二区三区| 亚洲成人免费观看| 日本一区二区成人在线| 国产精品美女久久久久高潮| 久久综合色播五月| 91久久国产最好的精华液| 国产成人三级在线观看| 99久久精品免费| 久久国产精品无码网站| 亚洲精选在线视频| 亚洲综合激情网| 国产一区视频导航| 欧美美女激情18p| 成人久久久精品乱码一区二区三区| 一区二区三区在线视频观看| 91久久久免费一区二区| 国产乱人伦偷精品视频不卡| 99久久99久久久精品齐齐| 精品一区二区三区日韩| 在线精品视频一区二区| 国产精品色哟哟| **欧美大码日韩| 91一区二区在线观看| 91精品欧美久久久久久动漫| 欧美亚洲综合在线| 久久免费电影网| 亚洲与欧洲av电影| 国产经典欧美精品| 国产传媒欧美日韩成人| 欧美一三区三区四区免费在线看| 日韩国产高清影视| 欧美精品一二三四| 99视频精品免费视频| 国产综合成人久久大片91| 精品视频一区 二区 三区| 91搞黄在线观看| 国产清纯在线一区二区www| 欧美电影免费观看高清完整版在 | 国产伦精品一区二区三区视频青涩 | 欧美在线视频不卡| 国产成人鲁色资源国产91色综| 日韩高清一级片| 欧美一卡二卡三卡四卡| 日韩一级大片在线| 国产福利一区在线| 日韩黄色免费电影| 精品久久久久久久久久久久久久久久久 | 9i看片成人免费高清| 91精品国产美女浴室洗澡无遮挡| 伦理电影国产精品| 欧美精品一二三| 亚洲精品国久久99热| 亚洲不卡一区二区三区| 7777精品伊人久久久大香线蕉| 亚洲已满18点击进入久久| 一本到三区不卡视频| 蜜臀久久99精品久久久久宅男| jiyouzz国产精品久久| 国产 日韩 欧美大片| 国产成人在线影院| 亚洲精品亚洲人成人网在线播放| 色94色欧美sute亚洲线路一ni | 国产精品国产三级国产| 亚洲美女屁股眼交| 秋霞成人午夜伦在线观看| 青青草原综合久久大伊人精品 | 不卡av免费在线观看| 国产一区二区网址| 国产在线观看一区二区| 久久激情综合网| 亚洲欧美激情视频在线观看一区二区三区| 激情小说欧美图片| 亚洲免费观看高清完整版在线观看熊 | 婷婷六月综合亚洲| 免费观看一级欧美片| 欧美一区二区三区婷婷月色 | 久久精品国产99国产| 国产馆精品极品| 2022国产精品视频| 国产精品66部| 欧美老肥妇做.爰bbww| 99精品欧美一区二区蜜桃免费| 天天操天天综合网| 国产日韩欧美制服另类| 偷拍日韩校园综合在线| 色婷婷国产精品综合在线观看| 日日夜夜免费精品视频| 亚洲欧美激情小说另类| 成人污污视频在线观看| 日本一区二区三区电影| 成人一区二区视频| 亚洲狠狠丁香婷婷综合久久久| 奇米精品一区二区三区四区| 日韩精品在线看片z| 亚洲欧洲色图综合| 欧美日韩精品一区二区天天拍小说| 国产日韩欧美激情| 五月婷婷久久丁香| 精品国产乱码91久久久久久网站| 国产 日韩 欧美大片| 亚洲精品自拍动漫在线| 欧美一区二区在线播放| 国产一区二区三区在线看麻豆| 91色综合久久久久婷婷| 国产成人午夜视频| 亚洲天堂精品视频| 欧美一级二级三级蜜桃| 日韩高清一级片| 高清不卡在线观看av| 亚洲欧美日本韩国| 6080亚洲精品一区二区| 中文字幕日韩一区二区| 亚洲精品国产品国语在线app| 久久99精品久久久久婷婷| 一本大道综合伊人精品热热 | 国产一区二区按摩在线观看| 亚洲欧洲在线观看av| 欧美一区二区私人影院日本| 99热精品国产| 美日韩一区二区三区| 欧美日韩国产首页在线观看| 国产一区二区三区久久久| 一级女性全黄久久生活片免费| 国产大陆精品国产| 久久综合av免费| 精品写真视频在线观看| 亚洲欧美偷拍三级| 久久一留热品黄| 色诱亚洲精品久久久久久| 欧美激情综合五月色丁香小说| 日韩一区二区免费高清| 色综合中文字幕国产 |