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