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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? infback.c

?? 這是一個三層的進銷存系統(tǒng)
?? C
?? 第 1 頁 / 共 2 頁
字號:
                state->mode = BAD;
            }
            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;
                }
            }

            /* 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_stream FAR *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;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
美女高潮久久久| 欧美三级电影一区| 麻豆国产91在线播放| 婷婷六月综合亚洲| 亚洲综合一区二区三区| 亚洲国产欧美另类丝袜| 伊人色综合久久天天人手人婷| 中文字幕精品一区二区精品绿巨人| 国产香蕉久久精品综合网| 精品国产自在久精品国产| www欧美成人18+| 久久精品在线观看| 国产欧美综合色| 亚洲视频一二三区| 亚洲精品中文字幕乱码三区| 一区二区三区国产| 亚洲国产一区二区在线播放| 午夜视频在线观看一区二区| 天天色综合天天| 免费成人在线影院| 韩国v欧美v日本v亚洲v| 国产精品影视在线观看| 国产91精品欧美| 北岛玲一区二区三区四区| 色综合久久99| 欧美久久一二区| 久久久蜜桃精品| 亚洲日本在线a| 五月综合激情婷婷六月色窝| 奇米精品一区二区三区四区| 激情久久久久久久久久久久久久久久| 国产一区二区免费看| 成人永久aaa| 91久久精品一区二区三| 91精品国产入口在线| 久久综合九色综合欧美就去吻| 中文无字幕一区二区三区| 1区2区3区欧美| 亚洲一区二区三区美女| 美女精品自拍一二三四| 国产99久久久久| 欧美日韩亚州综合| 欧美大胆一级视频| 中文字幕在线观看不卡视频| 亚洲国产精品久久人人爱蜜臀| 蜜桃视频第一区免费观看| 国产大陆a不卡| 欧美亚洲动漫另类| 日韩欧美综合在线| 国产精品久久久久三级| 日日夜夜精品免费视频| 粉嫩av一区二区三区粉嫩| 日本高清成人免费播放| 日韩欧美亚洲国产精品字幕久久久 | 偷拍日韩校园综合在线| 韩国av一区二区三区| 色94色欧美sute亚洲线路二| 精品久久久三级丝袜| 亚洲三级免费观看| 六月丁香综合在线视频| 色哟哟在线观看一区二区三区| 日韩一区二区三区免费看| 中文字幕一区二区三区四区不卡| 99久久久免费精品国产一区二区 | 中文字幕一区二区在线播放| 视频在线观看91| 99久久精品情趣| 精品对白一区国产伦| 夜夜嗨av一区二区三区中文字幕| 国产一区二区中文字幕| 欧美午夜精品一区二区三区| 日本一区二区三区在线不卡| 日韩精品亚洲一区| 91在线免费看| 国产三级欧美三级日产三级99| 性感美女极品91精品| 色综合网站在线| 亚洲国产精品高清| 美女任你摸久久| 欧美日韩国产综合一区二区三区 | 亚洲免费成人av| 国产精品18久久久久久vr| 欧美二区在线观看| 亚洲精品自拍动漫在线| 成人免费观看av| 亚洲精品在线观看网站| 丝袜美腿高跟呻吟高潮一区| 色综合久久久久综合体桃花网| 中文字幕欧美激情| 精品亚洲成a人| 欧美一区二区黄| 亚洲成人免费看| 欧洲生活片亚洲生活在线观看| 国产精品福利影院| 国产精品99久久久久久有的能看| 日韩一区二区三区视频在线观看| 午夜视频一区在线观看| 欧美午夜一区二区三区| 亚洲综合色网站| 在线亚洲人成电影网站色www| 国产精品拍天天在线| 国产精品影视在线| 国产天堂亚洲国产碰碰| 国产精品一区在线观看你懂的| 精品久久久久99| 日本不卡一二三| 欧美一区二区三区四区在线观看| 天天综合色天天综合| 欧美日本一区二区| 日产国产欧美视频一区精品| 欧美日韩电影在线播放| 亚洲愉拍自拍另类高清精品| 欧美少妇bbb| 五月婷婷久久综合| 欧美精品日韩一本| 男男gaygay亚洲| 精品国产区一区| 国产一区二区三区国产| 久久综合九色综合97婷婷女人 | 在线看国产一区| 亚洲在线免费播放| 在线观看91av| 捆绑紧缚一区二区三区视频 | 三级久久三级久久久| 日韩精品一区二区三区视频播放| 国模一区二区三区白浆| 国产精品嫩草影院av蜜臀| 99国产精品久久久久久久久久| 亚洲欧美一区二区三区极速播放| 91高清视频免费看| 丝袜国产日韩另类美女| 精品欧美乱码久久久久久1区2区| 韩国精品一区二区| 国产精品毛片久久久久久| 色香蕉成人二区免费| 亚洲高清一区二区三区| 日韩精品最新网址| 成人午夜视频福利| 亚洲九九爱视频| 日韩一卡二卡三卡| 国产传媒欧美日韩成人| 亚洲乱码国产乱码精品精98午夜| 51午夜精品国产| 国产精品亚洲专一区二区三区| 日韩毛片一二三区| 欧美肥妇free| 成人美女在线观看| 亚洲一区二区三区国产| 欧美videos大乳护士334| 不卡av在线免费观看| 午夜精品一区二区三区电影天堂| 精品少妇一区二区三区视频免付费 | 亚洲品质自拍视频网站| 日韩色视频在线观看| 成人免费的视频| 美国十次了思思久久精品导航| 日本一区二区综合亚洲| 欧美日韩国产综合一区二区| 国产一区二区福利| 一区二区三区日韩在线观看| 日韩欧美自拍偷拍| 色综合久久66| 国产一区二区三区观看| 亚洲成av人影院在线观看网| 国产日本欧洲亚洲| 8v天堂国产在线一区二区| 成人午夜精品在线| 美国三级日本三级久久99| 亚洲毛片av在线| 亚洲精品一区二区三区四区高清| 在线这里只有精品| 国产成人免费视| 日韩va欧美va亚洲va久久| 国产精品拍天天在线| 精品国产伦一区二区三区观看方式| 色播五月激情综合网| 国产毛片精品视频| 午夜激情综合网| 国产精品久久二区二区| 久久婷婷国产综合国色天香| 欧美日本一区二区在线观看| 91偷拍与自偷拍精品| 国产大陆亚洲精品国产| 久久99精品久久久久久国产越南 | 91黄视频在线| 成人av先锋影音| 国产一区二区在线免费观看| 男人的天堂久久精品| 亚洲大片精品永久免费| 一区二区三区资源| 国产精品伦理一区二区| 久久亚洲春色中文字幕久久久| 666欧美在线视频| 欧美日韩一区二区三区高清 | 精品日产卡一卡二卡麻豆| 欧美精品777| 在线亚洲免费视频| 91麻豆国产自产在线观看| 丰满岳乱妇一区二区三区| 国内精品自线一区二区三区视频|