⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 deflate.c

📁 linux下建立JAVA虚拟机的源码KAFFE
💻 C
📖 第 1 页 / 共 5 页
字号:
    for (n = 0; n <= length - MIN_MATCH; n++) {        INSERT_STRING(s, n, hash_head);    }    if (hash_head) hash_head = 0;  /* to make compiler happy */    return Z_OK;}/* ========================================================================= */int ZEXPORT deflateReset (strm)    z_streamp strm;{    deflate_state *s;    if (strm == Z_NULL || strm->state == Z_NULL ||        strm->zalloc == (alloc_func)0 || strm->zfree == (free_func)0) {        return Z_STREAM_ERROR;    }    strm->total_in = strm->total_out = 0;    strm->msg = Z_NULL; /* use zfree if we ever allocate msg dynamically */    strm->data_type = Z_UNKNOWN;    s = (deflate_state *)strm->state;    s->pending = 0;    s->pending_out = s->pending_buf;    if (s->wrap < 0) {        s->wrap = -s->wrap; /* was made negative by deflate(..., Z_FINISH); */    }    s->status = s->wrap ? INIT_STATE : BUSY_STATE;    strm->adler =#ifdef GZIP        s->wrap == 2 ? crc32(0L, Z_NULL, 0) :#endif        adler32(0L, Z_NULL, 0);    s->last_flush = Z_NO_FLUSH;    _tr_init(s);    lm_init(s);    return Z_OK;}/* ========================================================================= */int ZEXPORT deflateSetHeader (strm, head)    z_streamp strm;    gz_headerp head;{    if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR;    if (strm->state->wrap != 2) return Z_STREAM_ERROR;    strm->state->gzhead = head;    return Z_OK;}/* ========================================================================= */int ZEXPORT deflatePrime (strm, bits, value)    z_streamp strm;    int bits;    int value;{    if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR;    strm->state->bi_valid = bits;    strm->state->bi_buf = (ush)(value & ((1 << bits) - 1));    return Z_OK;}/* ========================================================================= */int ZEXPORT deflateParams(strm, level, strategy)    z_streamp strm;    int level;    int strategy;{    deflate_state *s;    compress_func func;    int err = Z_OK;    if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR;    s = strm->state;#ifdef FASTEST    if (level != 0) level = 1;#else    if (level == Z_DEFAULT_COMPRESSION) level = 6;#endif    if (level < 0 || level > 9 || strategy < 0 || strategy > Z_FIXED) {        return Z_STREAM_ERROR;    }    func = configuration_table[s->level].func;    if (func != configuration_table[level].func && strm->total_in != 0) {        /* Flush the last buffer: */        err = deflate(strm, Z_PARTIAL_FLUSH);    }    if (s->level != level) {        s->level = level;        s->max_lazy_match   = configuration_table[level].max_lazy;        s->good_match       = configuration_table[level].good_length;        s->nice_match       = configuration_table[level].nice_length;        s->max_chain_length = configuration_table[level].max_chain;    }    s->strategy = strategy;    return err;}/* ========================================================================= */int ZEXPORT deflateTune(strm, good_length, max_lazy, nice_length, max_chain)    z_streamp strm;    int good_length;    int max_lazy;    int nice_length;    int max_chain;{    deflate_state *s;    if (strm == Z_NULL || strm->state == Z_NULL) return Z_STREAM_ERROR;    s = strm->state;    s->good_match = good_length;    s->max_lazy_match = max_lazy;    s->nice_match = nice_length;    s->max_chain_length = max_chain;    return Z_OK;}/* ========================================================================= * For the default windowBits of 15 and memLevel of 8, this function returns * a close to exact, as well as small, upper bound on the compressed size. * They are coded as constants here for a reason--if the #define's are * changed, then this function needs to be changed as well.  The return * value for 15 and 8 only works for those exact settings. * * For any setting other than those defaults for windowBits and memLevel, * the value returned is a conservative worst case for the maximum expansion * resulting from using fixed blocks instead of stored blocks, which deflate * can emit on compressed data for some combinations of the parameters. * * This function could be more sophisticated to provide closer upper bounds * for every combination of windowBits and memLevel, as well as wrap. * But even the conservative upper bound of about 14% expansion does not * seem onerous for output buffer allocation. */uLong ZEXPORT deflateBound(strm, sourceLen)    z_streamp strm;    uLong sourceLen;{    deflate_state *s;    uLong destLen;    /* conservative upper bound */    destLen = sourceLen +              ((sourceLen + 7) >> 3) + ((sourceLen + 63) >> 6) + 11;    /* if can't get parameters, return conservative bound */    if (strm == Z_NULL || strm->state == Z_NULL)        return destLen;    /* if not default parameters, return conservative bound */    s = strm->state;    if (s->w_bits != 15 || s->hash_bits != 8 + 7)        return destLen;    /* default settings: return tight bound for that case */    return compressBound(sourceLen);}/* ========================================================================= * Put a short in the pending buffer. The 16-bit value is put in MSB order. * IN assertion: the stream state is correct and there is enough room in * pending_buf. */local void putShortMSB (s, b)    deflate_state *s;    uInt b;{    put_byte(s, (Byte)(b >> 8));    put_byte(s, (Byte)(b & 0xff));}/* ========================================================================= * Flush as much pending output as possible. All deflate() output goes * through this function so some applications may wish to modify it * to avoid allocating a large strm->next_out buffer and copying into it. * (See also read_buf()). */local void flush_pending(strm)    z_streamp strm;{    unsigned len = strm->state->pending;    if (len > strm->avail_out) len = strm->avail_out;    if (len == 0) return;    zmemcpy(strm->next_out, strm->state->pending_out, len);    strm->next_out  += len;    strm->state->pending_out  += len;    strm->total_out += len;    strm->avail_out  -= len;    strm->state->pending -= len;    if (strm->state->pending == 0) {        strm->state->pending_out = strm->state->pending_buf;    }}/* ========================================================================= */int ZEXPORT deflate (strm, flush)    z_streamp strm;    int flush;{    int old_flush; /* value of flush param for previous deflate call */    deflate_state *s;    if (strm == Z_NULL || strm->state == Z_NULL ||        flush > Z_FINISH || flush < 0) {        return Z_STREAM_ERROR;    }    s = strm->state;    if (strm->next_out == Z_NULL ||        (strm->next_in == Z_NULL && strm->avail_in != 0) ||        (s->status == FINISH_STATE && flush != Z_FINISH)) {        ERR_RETURN(strm, Z_STREAM_ERROR);    }    if (strm->avail_out == 0) ERR_RETURN(strm, Z_BUF_ERROR);    s->strm = strm; /* just in case */    old_flush = s->last_flush;    s->last_flush = flush;    /* Write the header */    if (s->status == INIT_STATE) {#ifdef GZIP        if (s->wrap == 2) {            strm->adler = crc32(0L, Z_NULL, 0);            put_byte(s, 31);            put_byte(s, 139);            put_byte(s, 8);            if (s->gzhead == NULL) {                put_byte(s, 0);                put_byte(s, 0);                put_byte(s, 0);                put_byte(s, 0);                put_byte(s, 0);                put_byte(s, s->level == 9 ? 2 :                            (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2 ?                             4 : 0));                put_byte(s, OS_CODE);                s->status = BUSY_STATE;            }            else {                put_byte(s, (s->gzhead->text ? 1 : 0) +                            (s->gzhead->hcrc ? 2 : 0) +                            (s->gzhead->extra == Z_NULL ? 0 : 4) +                            (s->gzhead->name == Z_NULL ? 0 : 8) +                            (s->gzhead->comment == Z_NULL ? 0 : 16)                        );                put_byte(s, (Byte)(s->gzhead->time & 0xff));                put_byte(s, (Byte)((s->gzhead->time >> 8) & 0xff));                put_byte(s, (Byte)((s->gzhead->time >> 16) & 0xff));                put_byte(s, (Byte)((s->gzhead->time >> 24) & 0xff));                put_byte(s, s->level == 9 ? 2 :                            (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2 ?                             4 : 0));                put_byte(s, s->gzhead->os & 0xff);                if (s->gzhead->extra != NULL) {                    put_byte(s, s->gzhead->extra_len & 0xff);                    put_byte(s, (s->gzhead->extra_len >> 8) & 0xff);                }                if (s->gzhead->hcrc)                    strm->adler = crc32(strm->adler, s->pending_buf,                                        s->pending);                s->gzindex = 0;                s->status = EXTRA_STATE;            }        }        else#endif        {            uInt header = (Z_DEFLATED + ((s->w_bits-8)<<4)) << 8;            uInt level_flags;            if (s->strategy >= Z_HUFFMAN_ONLY || s->level < 2)                level_flags = 0;            else if (s->level < 6)                level_flags = 1;            else if (s->level == 6)                level_flags = 2;            else                level_flags = 3;            header |= (level_flags << 6);            if (s->strstart != 0) header |= PRESET_DICT;            header += 31 - (header % 31);            s->status = BUSY_STATE;            putShortMSB(s, header);            /* Save the adler32 of the preset dictionary: */            if (s->strstart != 0) {                putShortMSB(s, (uInt)(strm->adler >> 16));                putShortMSB(s, (uInt)(strm->adler & 0xffff));            }            strm->adler = adler32(0L, Z_NULL, 0);        }    }#ifdef GZIP    if (s->status == EXTRA_STATE) {        if (s->gzhead->extra != NULL) {            uInt beg = s->pending;  /* start of bytes to update crc */            while (s->gzindex < (s->gzhead->extra_len & 0xffff)) {                if (s->pending == s->pending_buf_size) {                    if (s->gzhead->hcrc && s->pending > beg)                        strm->adler = crc32(strm->adler, s->pending_buf + beg,                                            s->pending - beg);                    flush_pending(strm);                    beg = s->pending;                    if (s->pending == s->pending_buf_size)                        break;                }                put_byte(s, s->gzhead->extra[s->gzindex]);                s->gzindex++;            }            if (s->gzhead->hcrc && s->pending > beg)                strm->adler = crc32(strm->adler, s->pending_buf + beg,                                    s->pending - beg);            if (s->gzindex == s->gzhead->extra_len) {                s->gzindex = 0;                s->status = NAME_STATE;            }        }        else            s->status = NAME_STATE;    }    if (s->status == NAME_STATE) {        if (s->gzhead->name != NULL) {            uInt beg = s->pending;  /* start of bytes to update crc */            int val;            do {                if (s->pending == s->pending_buf_size) {                    if (s->gzhead->hcrc && s->pending > beg)                        strm->adler = crc32(strm->adler, s->pending_buf + beg,                                            s->pending - beg);                    flush_pending(strm);                    beg = s->pending;                    if (s->pending == s->pending_buf_size) {                        val = 1;                        break;                    }                }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -