os/ossrv/compressionlibs/ziplib/test/oldezlib/Zlib/deflate.h
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
/* deflate.h -- internal compression state
sl@0
     2
 * Copyright (C) 1995-1998 Jean-loup Gailly
sl@0
     3
 * For conditions of distribution and use, see copyright notice in zlib.h 
sl@0
     4
 */
sl@0
     5
sl@0
     6
/* WARNING: this file should *not* be used by applications. It is
sl@0
     7
   part of the implementation of the compression library and is
sl@0
     8
   subject to change. Applications should only use zlib.h.
sl@0
     9
 */
sl@0
    10
sl@0
    11
/* @(#) $Id$ */
sl@0
    12
sl@0
    13
#ifndef _DEFLATE_H
sl@0
    14
#define _DEFLATE_H
sl@0
    15
sl@0
    16
#include "zutil.h"
sl@0
    17
sl@0
    18
/* ===========================================================================
sl@0
    19
 * Internal compression state.
sl@0
    20
 */
sl@0
    21
sl@0
    22
#define LENGTH_CODES 29
sl@0
    23
/* number of length codes, not counting the special END_BLOCK code */
sl@0
    24
sl@0
    25
#define LITERALS  256
sl@0
    26
/* number of literal bytes 0..255 */
sl@0
    27
sl@0
    28
#define L_CODES (LITERALS+1+LENGTH_CODES)
sl@0
    29
/* number of Literal or Length codes, including the END_BLOCK code */
sl@0
    30
sl@0
    31
#define D_CODES   30
sl@0
    32
/* number of distance codes */
sl@0
    33
sl@0
    34
#define BL_CODES  19
sl@0
    35
/* number of codes used to transfer the bit lengths */
sl@0
    36
sl@0
    37
#define HEAP_SIZE (2*L_CODES+1)
sl@0
    38
/* maximum heap size */
sl@0
    39
sl@0
    40
#define MAX_BITS 15
sl@0
    41
/* All codes must not exceed MAX_BITS bits */
sl@0
    42
sl@0
    43
#define INIT_STATE    42
sl@0
    44
#define BUSY_STATE   113
sl@0
    45
#define FINISH_STATE 666
sl@0
    46
/* Stream status */
sl@0
    47
sl@0
    48
sl@0
    49
/* Data structure describing a single value and its code string. */
sl@0
    50
typedef struct ct_data_s {
sl@0
    51
    union {
sl@0
    52
        ush  freq;       /* frequency count */
sl@0
    53
        ush  code;       /* bit string */
sl@0
    54
    } fc;
sl@0
    55
    union {
sl@0
    56
        ush  dad;        /* father node in Huffman tree */
sl@0
    57
        ush  len;        /* length of bit string */
sl@0
    58
    } dl;
sl@0
    59
} FAR ct_data;
sl@0
    60
sl@0
    61
#define Freq fc.freq
sl@0
    62
#define Code fc.code
sl@0
    63
#define Dad  dl.dad
sl@0
    64
#define Len  dl.len
sl@0
    65
sl@0
    66
typedef struct static_tree_desc_s  static_tree_desc;
sl@0
    67
sl@0
    68
typedef struct tree_desc_s {
sl@0
    69
    ct_data *dyn_tree;           /* the dynamic tree */
sl@0
    70
    int     max_code;            /* largest code with non zero frequency */
sl@0
    71
    static_tree_desc *stat_desc; /* the corresponding static tree */
sl@0
    72
} FAR tree_desc;
sl@0
    73
sl@0
    74
typedef ush Pos;
sl@0
    75
typedef Pos FAR Posf;
sl@0
    76
typedef unsigned IPos;
sl@0
    77
sl@0
    78
/* A Pos is an index in the character window. We use short instead of int to
sl@0
    79
 * save space in the various tables. IPos is used only for parameter passing.
sl@0
    80
 */
sl@0
    81
sl@0
    82
typedef struct internal_state {
sl@0
    83
    z_streamp strm;      /* pointer back to this zlib stream */
sl@0
    84
    int   status;        /* as the name implies */
sl@0
    85
    Bytef *pending_buf;  /* output still pending */
sl@0
    86
    ulg   pending_buf_size; /* size of pending_buf */
sl@0
    87
    Bytef *pending_out;  /* next pending byte to output to the stream */
sl@0
    88
    int   pending;       /* nb of bytes in the pending buffer */
sl@0
    89
    int   noheader;      /* suppress zlib header and adler32 */
sl@0
    90
    Byte  data_type;     /* UNKNOWN, BINARY or ASCII */
sl@0
    91
    Byte  method;        /* STORED (for zip only) or DEFLATED */
sl@0
    92
    int   last_flush;    /* value of flush param for previous deflate call */
sl@0
    93
sl@0
    94
                /* used by deflate.c: */
sl@0
    95
sl@0
    96
    uInt  w_size;        /* LZ77 window size (32K by default) */
sl@0
    97
    uInt  w_bits;        /* log2(w_size)  (8..16) */
sl@0
    98
    uInt  w_mask;        /* w_size - 1 */
sl@0
    99
sl@0
   100
    Bytef *window;
sl@0
   101
    /* Sliding window. Input bytes are read into the second half of the window,
sl@0
   102
     * and move to the first half later to keep a dictionary of at least wSize
sl@0
   103
     * bytes. With this organization, matches are limited to a distance of
sl@0
   104
     * wSize-MAX_MATCH bytes, but this ensures that IO is always
sl@0
   105
     * performed with a length multiple of the block size. Also, it limits
sl@0
   106
     * the window size to 64K, which is quite useful on MSDOS.
sl@0
   107
     * To do: use the user input buffer as sliding window.
sl@0
   108
     */
sl@0
   109
sl@0
   110
    ulg window_size;
sl@0
   111
    /* Actual size of window: 2*wSize, except when the user input buffer
sl@0
   112
     * is directly used as sliding window.
sl@0
   113
     */
sl@0
   114
sl@0
   115
    Posf *prev;
sl@0
   116
    /* Link to older string with same hash index. To limit the size of this
sl@0
   117
     * array to 64K, this link is maintained only for the last 32K strings.
sl@0
   118
     * An index in this array is thus a window index modulo 32K.
sl@0
   119
     */
sl@0
   120
sl@0
   121
    Posf *head; /* Heads of the hash chains or NIL. */
sl@0
   122
sl@0
   123
    uInt  ins_h;          /* hash index of string to be inserted */
sl@0
   124
    uInt  hash_size;      /* number of elements in hash table */
sl@0
   125
    uInt  hash_bits;      /* log2(hash_size) */
sl@0
   126
    uInt  hash_mask;      /* hash_size-1 */
sl@0
   127
sl@0
   128
    uInt  hash_shift;
sl@0
   129
    /* Number of bits by which ins_h must be shifted at each input
sl@0
   130
     * step. It must be such that after MIN_MATCH steps, the oldest
sl@0
   131
     * byte no longer takes part in the hash key, that is:
sl@0
   132
     *   hash_shift * MIN_MATCH >= hash_bits
sl@0
   133
     */
sl@0
   134
sl@0
   135
    long block_start;
sl@0
   136
    /* Window position at the beginning of the current output block. Gets
sl@0
   137
     * negative when the window is moved backwards.
sl@0
   138
     */
sl@0
   139
sl@0
   140
    uInt match_length;           /* length of best match */
sl@0
   141
    IPos prev_match;             /* previous match */
sl@0
   142
    int match_available;         /* set if previous match exists */
sl@0
   143
    uInt strstart;               /* start of string to insert */
sl@0
   144
    uInt match_start;            /* start of matching string */
sl@0
   145
    uInt lookahead;              /* number of valid bytes ahead in window */
sl@0
   146
sl@0
   147
    uInt prev_length;
sl@0
   148
    /* Length of the best match at previous step. Matches not greater than this
sl@0
   149
     * are discarded. This is used in the lazy match evaluation.
sl@0
   150
     */
sl@0
   151
sl@0
   152
    uInt max_chain_length;
sl@0
   153
    /* To speed up deflation, hash chains are never searched beyond this
sl@0
   154
     * length.  A higher limit improves compression ratio but degrades the
sl@0
   155
     * speed.
sl@0
   156
     */
sl@0
   157
sl@0
   158
    uInt max_lazy_match;
sl@0
   159
    /* Attempt to find a better match only when the current match is strictly
sl@0
   160
     * smaller than this value. This mechanism is used only for compression
sl@0
   161
     * levels >= 4.
sl@0
   162
     */
sl@0
   163
#   define max_insert_length  max_lazy_match
sl@0
   164
    /* Insert new strings in the hash table only if the match length is not
sl@0
   165
     * greater than this length. This saves time but degrades compression.
sl@0
   166
     * max_insert_length is used only for compression levels <= 3.
sl@0
   167
     */
sl@0
   168
sl@0
   169
    int level;    /* compression level (1..9) */
sl@0
   170
    int strategy; /* favor or force Huffman coding*/
sl@0
   171
sl@0
   172
    uInt good_match;
sl@0
   173
    /* Use a faster search when the previous match is longer than this */
sl@0
   174
sl@0
   175
    int nice_match; /* Stop searching when current match exceeds this */
sl@0
   176
sl@0
   177
                /* used by trees.c: */
sl@0
   178
    /* Didn't use ct_data typedef below to supress compiler warning */
sl@0
   179
    struct ct_data_s dyn_ltree[HEAP_SIZE];   /* literal and length tree */
sl@0
   180
    struct ct_data_s dyn_dtree[2*D_CODES+1]; /* distance tree */
sl@0
   181
    struct ct_data_s bl_tree[2*BL_CODES+1];  /* Huffman tree for bit lengths */
sl@0
   182
sl@0
   183
    struct tree_desc_s l_desc;               /* desc. for literal tree */
sl@0
   184
    struct tree_desc_s d_desc;               /* desc. for distance tree */
sl@0
   185
    struct tree_desc_s bl_desc;              /* desc. for bit length tree */
sl@0
   186
sl@0
   187
    ush bl_count[MAX_BITS+1];
sl@0
   188
    /* number of codes at each bit length for an optimal tree */
sl@0
   189
sl@0
   190
    int heap[2*L_CODES+1];      /* heap used to build the Huffman trees */
sl@0
   191
    int heap_len;               /* number of elements in the heap */
sl@0
   192
    int heap_max;               /* element of largest frequency */
sl@0
   193
    /* The sons of heap[n] are heap[2*n] and heap[2*n+1]. heap[0] is not used.
sl@0
   194
     * The same heap array is used to build all trees.
sl@0
   195
     */
sl@0
   196
sl@0
   197
    uch depth[2*L_CODES+1];
sl@0
   198
    /* Depth of each subtree used as tie breaker for trees of equal frequency
sl@0
   199
     */
sl@0
   200
sl@0
   201
    uchf *l_buf;          /* buffer for literals or lengths */
sl@0
   202
sl@0
   203
    uInt  lit_bufsize;
sl@0
   204
    /* Size of match buffer for literals/lengths.  There are 4 reasons for
sl@0
   205
     * limiting lit_bufsize to 64K:
sl@0
   206
     *   - frequencies can be kept in 16 bit counters
sl@0
   207
     *   - if compression is not successful for the first block, all input
sl@0
   208
     *     data is still in the window so we can still emit a stored block even
sl@0
   209
     *     when input comes from standard input.  (This can also be done for
sl@0
   210
     *     all blocks if lit_bufsize is not greater than 32K.)
sl@0
   211
     *   - if compression is not successful for a file smaller than 64K, we can
sl@0
   212
     *     even emit a stored file instead of a stored block (saving 5 bytes).
sl@0
   213
     *     This is applicable only for zip (not gzip or zlib).
sl@0
   214
     *   - creating new Huffman trees less frequently may not provide fast
sl@0
   215
     *     adaptation to changes in the input data statistics. (Take for
sl@0
   216
     *     example a binary file with poorly compressible code followed by
sl@0
   217
     *     a highly compressible string table.) Smaller buffer sizes give
sl@0
   218
     *     fast adaptation but have of course the overhead of transmitting
sl@0
   219
     *     trees more frequently.
sl@0
   220
     *   - I can't count above 4
sl@0
   221
     */
sl@0
   222
sl@0
   223
    uInt last_lit;      /* running index in l_buf */
sl@0
   224
sl@0
   225
    ushf *d_buf;
sl@0
   226
    /* Buffer for distances. To simplify the code, d_buf and l_buf have
sl@0
   227
     * the same number of elements. To use different lengths, an extra flag
sl@0
   228
     * array would be necessary.
sl@0
   229
     */
sl@0
   230
sl@0
   231
    ulg opt_len;        /* bit length of current block with optimal trees */
sl@0
   232
    ulg static_len;     /* bit length of current block with static trees */
sl@0
   233
    uInt matches;       /* number of string matches in current block */
sl@0
   234
    int last_eob_len;   /* bit length of EOB code for last block */
sl@0
   235
sl@0
   236
#ifdef DEBUG
sl@0
   237
    ulg compressed_len; /* total bit length of compressed file mod 2^32 */
sl@0
   238
    ulg bits_sent;      /* bit length of compressed data sent mod 2^32 */
sl@0
   239
#endif
sl@0
   240
sl@0
   241
    ush bi_buf;
sl@0
   242
    /* Output buffer. bits are inserted starting at the bottom (least
sl@0
   243
     * significant bits).
sl@0
   244
     */
sl@0
   245
    int bi_valid;
sl@0
   246
    /* Number of valid bits in bi_buf.  All bits above the last valid bit
sl@0
   247
     * are always zero.
sl@0
   248
     */
sl@0
   249
sl@0
   250
} FAR deflate_state;
sl@0
   251
sl@0
   252
/* Output a byte on the stream.
sl@0
   253
 * IN assertion: there is enough room in pending_buf.
sl@0
   254
 */
sl@0
   255
#define put_byte(s, c) {s->pending_buf[s->pending++] = (c);}
sl@0
   256
sl@0
   257
sl@0
   258
#define MIN_LOOKAHEAD (MAX_MATCH+MIN_MATCH+1)
sl@0
   259
/* Minimum amount of lookahead, except at the end of the input file.
sl@0
   260
 * See deflate.c for comments about the MIN_MATCH+1.
sl@0
   261
 */
sl@0
   262
sl@0
   263
#define MAX_DIST(s)  ((s)->w_size-MIN_LOOKAHEAD)
sl@0
   264
/* In order to simplify the code, particularly on 16 bit machines, match
sl@0
   265
 * distances are limited to MAX_DIST instead of WSIZE.
sl@0
   266
 */
sl@0
   267
sl@0
   268
        /* in trees.c */
sl@0
   269
void _tr_init         OF((deflate_state *s));
sl@0
   270
int  _tr_tally        OF((deflate_state *s, unsigned dist, unsigned lc));
sl@0
   271
void _tr_flush_block  OF((deflate_state *s, charf *buf, ulg stored_len,
sl@0
   272
			  int eof));
sl@0
   273
void _tr_align        OF((deflate_state *s));
sl@0
   274
void _tr_stored_block OF((deflate_state *s, charf *buf, ulg stored_len,
sl@0
   275
                          int eof));
sl@0
   276
sl@0
   277
#define d_code(dist) \
sl@0
   278
   ((dist) < 256 ? _dist_code[dist] : _dist_code[256+((dist)>>7)])
sl@0
   279
/* Mapping from a distance to a distance code. dist is the distance - 1 and
sl@0
   280
 * must not have side effects. _dist_code[256] and _dist_code[257] are never
sl@0
   281
 * used.
sl@0
   282
 */
sl@0
   283
sl@0
   284
#ifndef DEBUG
sl@0
   285
/* Inline versions of _tr_tally for speed: */
sl@0
   286
sl@0
   287
#if defined(GEN_TREES_H) || !defined(STDC)
sl@0
   288
  extern uch _length_code[];
sl@0
   289
  extern uch _dist_code[];
sl@0
   290
#else
sl@0
   291
  extern const uch _length_code[];
sl@0
   292
  extern const uch _dist_code[];
sl@0
   293
#endif
sl@0
   294
sl@0
   295
# define _tr_tally_lit(s, c, flush) \
sl@0
   296
  { uch cc = (c); \
sl@0
   297
    s->d_buf[s->last_lit] = 0; \
sl@0
   298
    s->l_buf[s->last_lit++] = cc; \
sl@0
   299
    s->dyn_ltree[cc].Freq++; \
sl@0
   300
    flush = (s->last_lit == s->lit_bufsize-1); \
sl@0
   301
   }
sl@0
   302
# define _tr_tally_dist(s, distance, length, flush) \
sl@0
   303
  { uch len = (length); \
sl@0
   304
    ush dist = (distance); \
sl@0
   305
    s->d_buf[s->last_lit] = dist; \
sl@0
   306
    s->l_buf[s->last_lit++] = len; \
sl@0
   307
    dist--; \
sl@0
   308
    s->dyn_ltree[_length_code[len]+LITERALS+1].Freq++; \
sl@0
   309
    s->dyn_dtree[d_code(dist)].Freq++; \
sl@0
   310
    flush = (s->last_lit == s->lit_bufsize-1); \
sl@0
   311
  }
sl@0
   312
#else
sl@0
   313
# define _tr_tally_lit(s, c, flush) flush = _tr_tally(s, 0, c)
sl@0
   314
# define _tr_tally_dist(s, distance, length, flush) \
sl@0
   315
              flush = _tr_tally(s, distance, length) 
sl@0
   316
#endif
sl@0
   317
sl@0
   318
#endif