os/ossrv/compressionlibs/ziplib/src/zlib/inftrees.cpp
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
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
/* inftrees.cpp -- generate Huffman trees for efficient decoding
sl@0
     6
 * Copyright (C) 1995-2005 Mark Adler
sl@0
     7
 * For conditions of distribution and use, see copyright notice in zlib.h
sl@0
     8
 */
sl@0
     9
sl@0
    10
#include "zutil.h"
sl@0
    11
#include "inftrees.h"
sl@0
    12
sl@0
    13
#define MAXBITS 15
sl@0
    14
sl@0
    15
sl@0
    16
const char inflate_copyright[] =
sl@0
    17
   " inflate 1.2.3 Copyright 1995-2005 Mark Adler ";
sl@0
    18
/*
sl@0
    19
  If you use the zlib library in a product, an acknowledgment is welcome
sl@0
    20
  in the documentation of your product. If for some reason you cannot
sl@0
    21
  include such an acknowledgment, I would appreciate that you keep this
sl@0
    22
  copyright string in the executable of your product.
sl@0
    23
 */
sl@0
    24
sl@0
    25
/*
sl@0
    26
   Build a set of tables to decode the provided canonical Huffman code.
sl@0
    27
   The code lengths are lens[0..codes-1].  The result starts at *table,
sl@0
    28
   whose indices are 0..2^bits-1.  work is a writable array of at least
sl@0
    29
   lens shorts, which is used as a work area.  type is the type of code
sl@0
    30
   to be generated, CODES, LENS, or DISTS.  On return, zero is success,
sl@0
    31
   -1 is an invalid code, and +1 means that ENOUGH isn't enough.  table
sl@0
    32
   on return points to the next available entry's address.  bits is the
sl@0
    33
   requested root table index bits, and on return it is the actual root
sl@0
    34
   table index bits.  It will differ if the request is greater than the
sl@0
    35
   longest code or if it is less than the shortest code.
sl@0
    36
 */
sl@0
    37
#ifdef __SYMBIAN32__
sl@0
    38
int inflate_table(codetype type,unsigned short FAR * lens,unsigned codes, code FAR * FAR * table,unsigned FAR * bits,unsigned short FAR * work)
sl@0
    39
#else
sl@0
    40
int inflate_table(type, lens, codes, table, bits, work)
sl@0
    41
codetype type;
sl@0
    42
unsigned short FAR *lens;
sl@0
    43
unsigned codes;
sl@0
    44
code FAR * FAR *table;
sl@0
    45
unsigned FAR *bits;
sl@0
    46
unsigned short FAR *work;
sl@0
    47
#endif //__SYMBIAN32__
sl@0
    48
{
sl@0
    49
	// Line to stop compiler warning about unused mandatory global variable 'inflate_copyright'
sl@0
    50
	char dontCare = inflate_copyright[0]; dontCare = dontCare;
sl@0
    51
	
sl@0
    52
    unsigned len;               /* a code's length in bits */
sl@0
    53
    unsigned sym;               /* index of code symbols */
sl@0
    54
    unsigned min, max;          /* minimum and maximum code lengths */
sl@0
    55
    unsigned root;              /* number of index bits for root table */
sl@0
    56
    unsigned curr;              /* number of index bits for current table */
sl@0
    57
    unsigned drop;              /* code bits to drop for sub-table */
sl@0
    58
    int left;                   /* number of prefix codes available */
sl@0
    59
    unsigned used;              /* code entries in table used */
sl@0
    60
    unsigned huff;              /* Huffman code */
sl@0
    61
    unsigned incr;              /* for incrementing code, index */
sl@0
    62
    unsigned fill;              /* index for replicating entries */
sl@0
    63
    unsigned low;               /* low bits for current root entry */
sl@0
    64
    unsigned mask;              /* mask for low root bits */
sl@0
    65
    
sl@0
    66
/*  Need to replace "this" variable with "current" as "this" is a reserved 
sl@0
    67
 *  keyword in C++ which is prefectly fine for a c code. As this file
sl@0
    68
 *  has been changed to C++ "this" needs to be changed.
sl@0
    69
 */ 
sl@0
    70
#   define this current   
sl@0
    71
    code this;                  /* table entry for duplication */
sl@0
    72
    code FAR *next;             /* next available space in table */
sl@0
    73
    const unsigned short FAR *base;     /* base value table to use */
sl@0
    74
    const unsigned short FAR *extra;    /* extra bits table to use */
sl@0
    75
    int end;                    /* use base and extra for symbol > end */
sl@0
    76
    unsigned short count[MAXBITS+1];    /* number of codes of each length */
sl@0
    77
    unsigned short offs[MAXBITS+1];     /* offsets in table for each length */
sl@0
    78
    static const unsigned short lbase[31] = { /* Length codes 257..285 base */
sl@0
    79
        3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,
sl@0
    80
        35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0};
sl@0
    81
    static const unsigned short lext[31] = { /* Length codes 257..285 extra */
sl@0
    82
        16, 16, 16, 16, 16, 16, 16, 16, 17, 17, 17, 17, 18, 18, 18, 18,
sl@0
    83
        19, 19, 19, 19, 20, 20, 20, 20, 21, 21, 21, 21, 16, 201, 196};
sl@0
    84
    static const unsigned short dbase[32] = { /* Distance codes 0..29 base */
sl@0
    85
        1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,
sl@0
    86
        257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,
sl@0
    87
        8193, 12289, 16385, 24577, 0, 0};
sl@0
    88
    static const unsigned short dext[32] = { /* Distance codes 0..29 extra */
sl@0
    89
        16, 16, 16, 16, 17, 17, 18, 18, 19, 19, 20, 20, 21, 21, 22, 22,
sl@0
    90
        23, 23, 24, 24, 25, 25, 26, 26, 27, 27,
sl@0
    91
        28, 28, 29, 29, 64, 64};
sl@0
    92
sl@0
    93
    /*
sl@0
    94
       Process a set of code lengths to create a canonical Huffman code.  The
sl@0
    95
       code lengths are lens[0..codes-1].  Each length corresponds to the
sl@0
    96
       symbols 0..codes-1.  The Huffman code is generated by first sorting the
sl@0
    97
       symbols by length from short to long, and retaining the symbol order
sl@0
    98
       for codes with equal lengths.  Then the code starts with all zero bits
sl@0
    99
       for the first code of the shortest length, and the codes are integer
sl@0
   100
       increments for the same length, and zeros are appended as the length
sl@0
   101
       increases.  For the deflate format, these bits are stored backwards
sl@0
   102
       from their more natural integer increment ordering, and so when the
sl@0
   103
       decoding tables are built in the large loop below, the integer codes
sl@0
   104
       are incremented backwards.
sl@0
   105
sl@0
   106
       This routine assumes, but does not check, that all of the entries in
sl@0
   107
       lens[] are in the range 0..MAXBITS.  The caller must assure this.
sl@0
   108
       1..MAXBITS is interpreted as that code length.  zero means that that
sl@0
   109
       symbol does not occur in this code.
sl@0
   110
sl@0
   111
       The codes are sorted by computing a count of codes for each length,
sl@0
   112
       creating from that a table of starting indices for each length in the
sl@0
   113
       sorted table, and then entering the symbols in order in the sorted
sl@0
   114
       table.  The sorted table is work[], with that space being provided by
sl@0
   115
       the caller.
sl@0
   116
sl@0
   117
       The length counts are used for other purposes as well, i.e. finding
sl@0
   118
       the minimum and maximum length codes, determining if there are any
sl@0
   119
       codes at all, checking for a valid set of lengths, and looking ahead
sl@0
   120
       at length counts to determine sub-table sizes when building the
sl@0
   121
       decoding tables.
sl@0
   122
     */
sl@0
   123
sl@0
   124
    /* accumulate lengths for codes (assumes lens[] all in 0..MAXBITS) */
sl@0
   125
    for (len = 0; len <= MAXBITS; len++)
sl@0
   126
        count[len] = 0;
sl@0
   127
    for (sym = 0; sym < codes; sym++)
sl@0
   128
        count[lens[sym]]++;
sl@0
   129
sl@0
   130
    /* bound code lengths, force root to be within code lengths */
sl@0
   131
    root = *bits;
sl@0
   132
    for (max = MAXBITS; max >= 1; max--)
sl@0
   133
        if (count[max] != 0) break;
sl@0
   134
    if (root > max) root = max;
sl@0
   135
    if (max == 0) {                     /* no symbols to code at all */
sl@0
   136
        this.op = (unsigned char)64;    /* invalid code marker */
sl@0
   137
        this.bits = (unsigned char)1;
sl@0
   138
        this.val = (unsigned short)0;
sl@0
   139
        *(*table)++ = this;             /* make a table to force an error */
sl@0
   140
        *(*table)++ = this;
sl@0
   141
        *bits = 1;
sl@0
   142
        return 0;     /* no symbols, but wait for decoding to report error */
sl@0
   143
    }
sl@0
   144
    for (min = 1; min <= MAXBITS; min++)
sl@0
   145
        if (count[min] != 0) break;
sl@0
   146
    if (root < min) root = min;
sl@0
   147
sl@0
   148
    /* check for an over-subscribed or incomplete set of lengths */
sl@0
   149
    left = 1;
sl@0
   150
    for (len = 1; len <= MAXBITS; len++) {
sl@0
   151
        left <<= 1;
sl@0
   152
        left -= count[len];
sl@0
   153
        if (left < 0) return -1;        /* over-subscribed */
sl@0
   154
    }
sl@0
   155
    if (left > 0 && (type == CODES || max != 1))
sl@0
   156
        return -1;                      /* incomplete set */
sl@0
   157
sl@0
   158
    /* generate offsets into symbol table for each length for sorting */
sl@0
   159
    offs[1] = 0;
sl@0
   160
    for (len = 1; len < MAXBITS; len++)
sl@0
   161
        offs[len + 1] = offs[len] + count[len];
sl@0
   162
sl@0
   163
    /* sort symbols by length, by symbol order within each length */
sl@0
   164
    for (sym = 0; sym < codes; sym++)
sl@0
   165
        if (lens[sym] != 0) work[offs[lens[sym]]++] = (unsigned short)sym;
sl@0
   166
sl@0
   167
    /*
sl@0
   168
       Create and fill in decoding tables.  In this loop, the table being
sl@0
   169
       filled is at next and has curr index bits.  The code being used is huff
sl@0
   170
       with length len.  That code is converted to an index by dropping drop
sl@0
   171
       bits off of the bottom.  For codes where len is less than drop + curr,
sl@0
   172
       those top drop + curr - len bits are incremented through all values to
sl@0
   173
       fill the table with replicated entries.
sl@0
   174
sl@0
   175
       root is the number of index bits for the root table.  When len exceeds
sl@0
   176
       root, sub-tables are created pointed to by the root entry with an index
sl@0
   177
       of the low root bits of huff.  This is saved in low to check for when a
sl@0
   178
       new sub-table should be started.  drop is zero when the root table is
sl@0
   179
       being filled, and drop is root when sub-tables are being filled.
sl@0
   180
sl@0
   181
       When a new sub-table is needed, it is necessary to look ahead in the
sl@0
   182
       code lengths to determine what size sub-table is needed.  The length
sl@0
   183
       counts are used for this, and so count[] is decremented as codes are
sl@0
   184
       entered in the tables.
sl@0
   185
sl@0
   186
       used keeps track of how many table entries have been allocated from the
sl@0
   187
       provided *table space.  It is checked when a LENS table is being made
sl@0
   188
       against the space in *table, ENOUGH, minus the maximum space needed by
sl@0
   189
       the worst case distance code, MAXD.  This should never happen, but the
sl@0
   190
       sufficiency of ENOUGH has not been proven exhaustively, hence the check.
sl@0
   191
       This assumes that when type == LENS, bits == 9.
sl@0
   192
sl@0
   193
       sym increments through all symbols, and the loop terminates when
sl@0
   194
       all codes of length max, i.e. all codes, have been processed.  This
sl@0
   195
       routine permits incomplete codes, so another loop after this one fills
sl@0
   196
       in the rest of the decoding tables with invalid code markers.
sl@0
   197
     */
sl@0
   198
sl@0
   199
    /* set up for code type */
sl@0
   200
    switch (type) {
sl@0
   201
    case CODES:
sl@0
   202
        base = extra = work;    /* dummy value--not used */
sl@0
   203
        end = 19;
sl@0
   204
        break;
sl@0
   205
    case LENS:
sl@0
   206
        base = lbase;
sl@0
   207
        base -= 257;
sl@0
   208
        extra = lext;
sl@0
   209
        extra -= 257;
sl@0
   210
        end = 256;
sl@0
   211
        break;
sl@0
   212
    default:            /* DISTS */
sl@0
   213
        base = dbase;
sl@0
   214
        extra = dext;
sl@0
   215
        end = -1;
sl@0
   216
    }
sl@0
   217
sl@0
   218
    /* initialize state for loop */
sl@0
   219
    huff = 0;                   /* starting code */
sl@0
   220
    sym = 0;                    /* starting code symbol */
sl@0
   221
    len = min;                  /* starting code length */
sl@0
   222
    next = *table;              /* current table to fill in */
sl@0
   223
    curr = root;                /* current table index bits */
sl@0
   224
    drop = 0;                   /* current bits to drop from code for index */
sl@0
   225
    low = (unsigned)(-1);       /* trigger new sub-table when len > root */
sl@0
   226
    used = 1U << root;          /* use root table entries */
sl@0
   227
    mask = used - 1;            /* mask for comparing low */
sl@0
   228
sl@0
   229
    /* check available table space */
sl@0
   230
    if (type == LENS && used >= ENOUGH - MAXD)
sl@0
   231
        return 1;
sl@0
   232
sl@0
   233
    /* process all codes and make table entries */
sl@0
   234
    for (;;) {
sl@0
   235
        /* create table entry */
sl@0
   236
        this.bits = (unsigned char)(len - drop);
sl@0
   237
        if ((int)(work[sym]) < end) {
sl@0
   238
            this.op = (unsigned char)0;
sl@0
   239
            this.val = work[sym];
sl@0
   240
        }
sl@0
   241
        else if ((int)(work[sym]) > end) {
sl@0
   242
            this.op = (unsigned char)(extra[work[sym]]);
sl@0
   243
            this.val = base[work[sym]];
sl@0
   244
        }
sl@0
   245
        else {
sl@0
   246
            this.op = (unsigned char)(32 + 64);         /* end of block */
sl@0
   247
            this.val = 0;
sl@0
   248
        }
sl@0
   249
sl@0
   250
        /* replicate for those indices with low len bits equal to huff */
sl@0
   251
        incr = 1U << (len - drop);
sl@0
   252
        fill = 1U << curr;
sl@0
   253
        min = fill;                 /* save offset to next table */
sl@0
   254
        do {
sl@0
   255
            fill -= incr;
sl@0
   256
            next[(huff >> drop) + fill] = this;
sl@0
   257
        } while (fill != 0);
sl@0
   258
sl@0
   259
        /* backwards increment the len-bit code huff */
sl@0
   260
        incr = 1U << (len - 1);
sl@0
   261
        while (huff & incr)
sl@0
   262
            incr >>= 1;
sl@0
   263
        if (incr != 0) {
sl@0
   264
            huff &= incr - 1;
sl@0
   265
            huff += incr;
sl@0
   266
        }
sl@0
   267
        else
sl@0
   268
            huff = 0;
sl@0
   269
sl@0
   270
        /* go to next symbol, update count, len */
sl@0
   271
        sym++;
sl@0
   272
        if (--(count[len]) == 0) {
sl@0
   273
            if (len == max) break;
sl@0
   274
            len = lens[work[sym]];
sl@0
   275
        }
sl@0
   276
sl@0
   277
        /* create new sub-table if needed */
sl@0
   278
        if (len > root && (huff & mask) != low) {
sl@0
   279
            /* if first time, transition to sub-tables */
sl@0
   280
            if (drop == 0)
sl@0
   281
                drop = root;
sl@0
   282
sl@0
   283
            /* increment past last table */
sl@0
   284
            next += min;            /* here min is 1 << curr */
sl@0
   285
sl@0
   286
            /* determine length of next table */
sl@0
   287
            curr = len - drop;
sl@0
   288
            left = (int)(1 << curr);
sl@0
   289
            while (curr + drop < max) {
sl@0
   290
                left -= count[curr + drop];
sl@0
   291
                if (left <= 0) break;
sl@0
   292
                curr++;
sl@0
   293
                left <<= 1;
sl@0
   294
            }
sl@0
   295
sl@0
   296
            /* check for enough space */
sl@0
   297
            used += 1U << curr;
sl@0
   298
            if (type == LENS && used >= ENOUGH - MAXD)
sl@0
   299
                return 1;
sl@0
   300
sl@0
   301
            /* point entry in root table to sub-table */
sl@0
   302
            low = huff & mask;
sl@0
   303
            (*table)[low].op = (unsigned char)curr;
sl@0
   304
            (*table)[low].bits = (unsigned char)root;
sl@0
   305
            (*table)[low].val = (unsigned short)(next - *table);
sl@0
   306
        }
sl@0
   307
    }
sl@0
   308
sl@0
   309
    /*
sl@0
   310
       Fill in rest of table for incomplete codes.  This loop is similar to the
sl@0
   311
       loop above in incrementing huff for table indices.  It is assumed that
sl@0
   312
       len is equal to curr + drop, so there is no loop needed to increment
sl@0
   313
       through high index bits.  When the current sub-table is filled, the loop
sl@0
   314
       drops back to the root table to fill in any remaining entries there.
sl@0
   315
     */
sl@0
   316
    this.op = (unsigned char)64;                /* invalid code marker */
sl@0
   317
    this.bits = (unsigned char)(len - drop);
sl@0
   318
    this.val = (unsigned short)0;
sl@0
   319
    while (huff != 0) {
sl@0
   320
        /* when done with sub-table, drop back to root table */
sl@0
   321
        if (drop != 0 && (huff & mask) != low) {
sl@0
   322
            drop = 0;
sl@0
   323
            len = root;
sl@0
   324
            next = *table;
sl@0
   325
            this.bits = (unsigned char)len;
sl@0
   326
        }
sl@0
   327
sl@0
   328
        /* put invalid code marker in table */
sl@0
   329
        next[huff >> drop] = this;
sl@0
   330
sl@0
   331
        /* backwards increment the len-bit code huff */
sl@0
   332
        incr = 1U << (len - 1);
sl@0
   333
        while (huff & incr)
sl@0
   334
            incr >>= 1;
sl@0
   335
        if (incr != 0) {
sl@0
   336
            huff &= incr - 1;
sl@0
   337
            huff += incr;
sl@0
   338
        }
sl@0
   339
        else
sl@0
   340
            huff = 0;
sl@0
   341
    }
sl@0
   342
sl@0
   343
    /* set return parameters */
sl@0
   344
    *table += used;
sl@0
   345
    *bits = root;
sl@0
   346
    return 0;
sl@0
   347
}
sl@0
   348
sl@0
   349
sl@0
   350
sl@0
   351
sl@0
   352
sl@0
   353