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

📄 deflate.cpp

📁 swf 格式文件(Flash)阅读器.根据 Flash 文件窗口的大小自适应调整阅读器窗口大小。直持压缩过 swf 文件。如果为 *.exe 格式 Flash 文件可用 Exe2Swf 程序进行分解为
💻 CPP
📖 第 1 页 / 共 5 页
字号:
        INSERT_STRING(s, n, hash_head);    }    if (hash_head) hash_head = 0;  /* to make compiler happy */    return Z_OK;}/* ========================================================================= */int  deflateReset (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  deflateSetHeader (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  deflatePrime (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  deflateParams(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  deflateTune(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  deflateBound(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. */ void putShortMSB (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()). */ void flush_pending(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  deflate (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;                    }                }                val = s->gzhead->name[s->gzindex++];                put_byte(s, val);            } while (val != 0);            if (s->gzhead->hcrc && s->pending > beg)                strm->adler = crc32(strm->adler, s->pending_buf + beg,                                    s->pending - beg);            if (val == 0) {                s->gzindex = 0;                s->status = COMMENT_STATE;            }

⌨️ 快捷键说明

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