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

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

?? infback.c

?? 這是一個三層的進銷存系統
?? 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;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区av电影| 欧美群妇大交群中文字幕| 日韩黄色在线观看| 五月婷婷综合激情| 亚洲大型综合色站| 五月天精品一区二区三区| 日韩1区2区3区| 精品伊人久久久久7777人| 激情综合色播五月| 国产精品一级在线| eeuss国产一区二区三区| 一本色道久久综合亚洲精品按摩| www.亚洲人| 欧美手机在线视频| 日韩色在线观看| 国产亚洲综合av| 亚洲色图视频网| 午夜精品国产更新| 激情综合网天天干| 99久久99精品久久久久久| 91在线视频18| 91精品国产91久久久久久一区二区| 欧美一个色资源| 国产色婷婷亚洲99精品小说| 亚洲欧美日韩电影| 日本91福利区| av在线不卡免费看| 91精品国产福利在线观看| 欧美精品一区二区三区在线| 中文字幕精品综合| 亚洲成人福利片| 国产精品亚洲午夜一区二区三区| 色综合天天综合色综合av| 欧美电影一区二区| 国产精品久久久爽爽爽麻豆色哟哟 | 欧美日韩免费不卡视频一区二区三区| 91麻豆精品91久久久久同性| 日本一区二区视频在线观看| 亚洲综合丁香婷婷六月香| 国产一区二区三区综合| 欧洲一区在线电影| 久久精品网站免费观看| 石原莉奈在线亚洲三区| 成人美女视频在线观看| 欧美电影免费观看高清完整版在线| 中文字幕精品一区二区三区精品| 天天av天天翘天天综合网色鬼国产| 国产精品小仙女| 日韩欧美高清在线| 一二三区精品视频| 99视频精品在线| 国产亚洲精品中文字幕| 琪琪久久久久日韩精品| 欧美在线观看视频一区二区三区| 久久久亚洲精品石原莉奈| 视频一区在线播放| 欧美在线free| 亚洲欧美日本韩国| 99视频精品全部免费在线| 久久久精品蜜桃| 韩国女主播一区| 精品国产免费人成电影在线观看四季 | 日韩午夜电影av| 亚洲国产精品一区二区久久恐怖片| 国产999精品久久久久久绿帽| 日韩欧美激情四射| 日韩成人精品在线观看| 欧美日韩精品欧美日韩精品一综合| 中文字幕一区二| 高清在线不卡av| 亚洲国产精品成人综合色在线婷婷| 国产一区二区福利视频| 久久夜色精品一区| 国产尤物一区二区在线| 久久综合中文字幕| 国产精品18久久久久久久久久久久| 日韩精品在线看片z| 久久精品国产一区二区| 日韩一级黄色大片| 精品无人码麻豆乱码1区2区| 久久一夜天堂av一区二区三区| 久久精品国产亚洲高清剧情介绍 | 蜜臀精品久久久久久蜜臀| 在线成人小视频| 美女在线观看视频一区二区| 日韩视频在线永久播放| 黄网站免费久久| 欧美激情一区二区三区| 99热国产精品| 亚洲国产精品久久人人爱蜜臀| 欧美日韩免费一区二区三区| 天天综合日日夜夜精品| 欧美变态口味重另类| 国产精品羞羞答答xxdd| 亚洲欧洲一区二区在线播放| 一本久道久久综合中文字幕| 性做久久久久久| 久久久久久久久一| 一本色道久久综合狠狠躁的推荐| 一区二区国产视频| 精品久久一区二区三区| av亚洲精华国产精华精华| 亚洲一二三四区不卡| 精品久久久三级丝袜| av电影天堂一区二区在线| 天堂午夜影视日韩欧美一区二区| 精品国产91亚洲一区二区三区婷婷| 国产福利不卡视频| 亚洲午夜在线电影| 国产日韩精品一区二区三区 | 麻豆久久久久久| 国产精品乱人伦| 91精品蜜臀在线一区尤物| 国产成人一区在线| 亚洲第一成人在线| 国产精品久久久久精k8 | 国产夜色精品一区二区av| 欧美日本一区二区| av电影天堂一区二区在线 | 国产精品青草久久| 日韩一区二区三区观看| 91在线视频网址| 国产精品 欧美精品| 手机精品视频在线观看| 18成人在线观看| 久久精品日产第一区二区三区高清版| 欧美在线free| 91麻豆国产精品久久| 国产美女一区二区| 蜜臀av一区二区三区| 夜夜嗨av一区二区三区网页| 欧美激情艳妇裸体舞| 久久网这里都是精品| 日韩一级二级三级| 欧美二区乱c少妇| 欧美三级一区二区| 日本高清不卡一区| 91同城在线观看| 99久久免费视频.com| 丁香另类激情小说| 国产99久久久精品| 成人h动漫精品一区二| 国产精品白丝jk白祙喷水网站| 亚洲成在线观看| 亚洲妇熟xx妇色黄| 亚洲电影视频在线| 亚洲成人av免费| 午夜国产精品一区| 免费人成在线不卡| 石原莉奈一区二区三区在线观看| 夜夜亚洲天天久久| 亚洲一二三四在线| 日韩成人伦理电影在线观看| 丝袜美腿亚洲综合| 免费三级欧美电影| 国产麻豆精品在线观看| 国产美女一区二区三区| 成人激情黄色小说| 97精品久久久久中文字幕| 色综合久久九月婷婷色综合| 91免费国产在线观看| 色哟哟国产精品免费观看| 91福利资源站| 在线播放亚洲一区| 欧美v日韩v国产v| 国产欧美va欧美不卡在线 | 欧美日韩精品专区| 日韩视频一区在线观看| 精品国产乱码91久久久久久网站| www国产成人免费观看视频 深夜成人网| 精品理论电影在线观看| 国产精品乱码久久久久久| 17c精品麻豆一区二区免费| 亚洲一区二区免费视频| 久久99精品久久久久久动态图 | 成人激情av网| 欧美日韩国产免费一区二区| www国产成人| 一区二区三区四区高清精品免费观看| 亚洲午夜私人影院| 国产在线视频精品一区| 99re这里只有精品6| 91精品久久久久久蜜臀| 国产午夜精品一区二区| 亚洲综合色成人| 精品一区二区成人精品| av不卡一区二区三区| 日韩欧美国产一区在线观看| 国产精品网曝门| 日本欧美肥老太交大片| 懂色av中文一区二区三区| 欧美日韩一区二区三区在线| 精品91自产拍在线观看一区| 亚洲视频在线观看三级| 蜜臀av一区二区三区| 在线一区二区视频| 久久九九全国免费| 日韩av中文字幕一区二区三区| 成人v精品蜜桃久久一区| 欧美v国产在线一区二区三区|