Annotation of coherent/g/usr/bin/gzip/inflate.c, revision 1.1.1.1

1.1       root        1: /* inflate.c -- Not copyrighted 1992 by Mark Adler
                      2:    version c10p1, 10 January 1993 */
                      3: 
                      4: /* You can do whatever you like with this source file, though I would
                      5:    prefer that if you modify it and redistribute it that you include
                      6:    comments to that effect with your name and the date.  Thank you.
                      7:    [The history has been moved to the file ChangeLog.]
                      8:  */
                      9: 
                     10: /*
                     11:    Inflate deflated (PKZIP's method 8 compressed) data.  The compression
                     12:    method searches for as much of the current string of bytes (up to a
                     13:    length of 258) in the previous 32K bytes.  If it doesn't find any
                     14:    matches (of at least length 3), it codes the next byte.  Otherwise, it
                     15:    codes the length of the matched string and its distance backwards from
                     16:    the current position.  There is a single Huffman code that codes both
                     17:    single bytes (called "literals") and match lengths.  A second Huffman
                     18:    code codes the distance information, which follows a length code.  Each
                     19:    length or distance code actually represents a base value and a number
                     20:    of "extra" (sometimes zero) bits to get to add to the base value.  At
                     21:    the end of each deflated block is a special end-of-block (EOB) literal/
                     22:    length code.  The decoding process is basically: get a literal/length
                     23:    code; if EOB then done; if a literal, emit the decoded byte; if a
                     24:    length then get the distance and emit the referred-to bytes from the
                     25:    sliding window of previously emitted data.
                     26: 
                     27:    There are (currently) three kinds of inflate blocks: stored, fixed, and
                     28:    dynamic.  The compressor deals with some chunk of data at a time, and
                     29:    decides which method to use on a chunk-by-chunk basis.  A chunk might
                     30:    typically be 32K or 64K.  If the chunk is uncompressible, then the
                     31:    "stored" method is used.  In this case, the bytes are simply stored as
                     32:    is, eight bits per byte, with none of the above coding.  The bytes are
                     33:    preceded by a count, since there is no longer an EOB code.
                     34: 
                     35:    If the data is compressible, then either the fixed or dynamic methods
                     36:    are used.  In the dynamic method, the compressed data is preceded by
                     37:    an encoding of the literal/length and distance Huffman codes that are
                     38:    to be used to decode this block.  The representation is itself Huffman
                     39:    coded, and so is preceded by a description of that code.  These code
                     40:    descriptions take up a little space, and so for small blocks, there is
                     41:    a predefined set of codes, called the fixed codes.  The fixed method is
                     42:    used if the block codes up smaller that way (usually for quite small
                     43:    chunks), otherwise the dynamic method is used.  In the latter case, the
                     44:    codes are customized to the probabilities in the current block, and so
                     45:    can code it much better than the pre-determined fixed codes.
                     46:  
                     47:    The Huffman codes themselves are decoded using a mutli-level table
                     48:    lookup, in order to maximize the speed of decoding plus the speed of
                     49:    building the decoding tables.  See the comments below that precede the
                     50:    lbits and dbits tuning parameters.
                     51:  */
                     52: 
                     53: 
                     54: /*
                     55:    Notes beyond the 1.93a appnote.txt:
                     56: 
                     57:    1. Distance pointers never point before the beginning of the output
                     58:       stream.
                     59:    2. Distance pointers can point back across blocks, up to 32k away.
                     60:    3. There is an implied maximum of 7 bits for the bit length table and
                     61:       15 bits for the actual data.
                     62:    4. If only one code exists, then it is encoded using one bit.  (Zero
                     63:       would be more efficient, but perhaps a little confusing.)  If two
                     64:       codes exist, they are coded using one bit each (0 and 1).
                     65:    5. There is no way of sending zero distance codes--a dummy must be
                     66:       sent if there are none.  (History: a pre 2.0 version of PKZIP would
                     67:       store blocks with no distance codes, but this was discovered to be
                     68:       too harsh a criterion.)  Valid only for 1.93a.  2.04c does allow
                     69:       zero distance codes, which is sent as one code of zero bits in
                     70:       length.
                     71:    6. There are up to 286 literal/length codes.  Code 256 represents the
                     72:       end-of-block.  Note however that the static length tree defines
                     73:       288 codes just to fill out the Huffman codes.  Codes 286 and 287
                     74:       cannot be used though, since there is no length base or extra bits
                     75:       defined for them.  Similarily, there are up to 30 distance codes.
                     76:       However, static trees define 32 codes (all 5 bits) to fill out the
                     77:       Huffman codes, but the last two had better not show up in the data.
                     78:    7. Unzip can check dynamic Huffman blocks for complete code sets.
                     79:       The exception is that a single code would not be complete (see #4).
                     80:    8. The five bits following the block type is really the number of
                     81:       literal codes sent minus 257.
                     82:    9. Length codes 8,16,16 are interpreted as 13 length codes of 8 bits
                     83:       (1+6+6).  Therefore, to output three times the length, you output
                     84:       three codes (1+1+1), whereas to output four times the same length,
                     85:       you only need two codes (1+3).  Hmm.
                     86:   10. In the tree reconstruction algorithm, Code = Code + Increment
                     87:       only if BitLength(i) is not zero.  (Pretty obvious.)
                     88:   11. Correction: 4 Bits: # of Bit Length codes - 4     (4 - 19)
                     89:   12. Note: length code 284 can represent 227-258, but length code 285
                     90:       really is 258.  The last length deserves its own, short code
                     91:       since it gets used a lot in very redundant files.  The length
                     92:       258 is special since 258 - 3 (the min match length) is 255.
                     93:   13. The literal/length and distance code bit lengths are read as a
                     94:       single stream of lengths.  It is possible (and advantageous) for
                     95:       a repeat code (16, 17, or 18) to go across the boundary between
                     96:       the two sets of lengths.
                     97:  */
                     98: 
                     99: #ifndef lint
                    100: static char rcsid[] = "$Id: inflate.c,v 0.10 1993/02/04 13:21:06 jloup Exp $";
                    101: #endif
                    102: 
                    103: #include "tailor.h"
                    104: #include "gzip.h"
                    105: #define slide window
                    106: 
                    107: #include <stdio.h>
                    108: 
                    109: #if defined(STDC_HEADERS) || !defined(NO_STDLIB_H)
                    110: #  include <sys/types.h>
                    111: #  include <stdlib.h>
                    112: #endif
                    113: 
                    114: /* Huffman code lookup table entry--this entry is four bytes for machines
                    115:    that have 16-bit pointers (e.g. PC's in the small or medium model).
                    116:    Valid extra bits are 0..13.  e == 15 is EOB (end of block), e == 16
                    117:    means that v is a literal, 16 < e < 32 means that v is a pointer to
                    118:    the next table, which codes e - 16 bits, and lastly e == 99 indicates
                    119:    an unused code.  If a code with e == 99 is looked up, this implies an
                    120:    error in the data. */
                    121: struct huft {
                    122:   uch e;                /* number of extra bits or operation */
                    123:   uch b;                /* number of bits in this code or subcode */
                    124:   union {
                    125:     ush n;              /* literal, length base, or distance base */
                    126:     struct huft *t;     /* pointer to next level of table */
                    127:   } v;
                    128: };
                    129: 
                    130: 
                    131: /* Function prototypes */
                    132: int huft_build OF((unsigned *, unsigned, unsigned, ush *, ush *,
                    133:                    struct huft **, int *));
                    134: int huft_free OF((struct huft *));
                    135: int inflate_codes OF((struct huft *, struct huft *, int, int));
                    136: int inflate_stored OF((void));
                    137: int inflate_fixed OF((void));
                    138: int inflate_dynamic OF((void));
                    139: int inflate_block OF((int *));
                    140: int inflate OF((void));
                    141: 
                    142: 
                    143: /* The inflate algorithm uses a sliding 32K byte window on the uncompressed
                    144:    stream to find repeated byte strings.  This is implemented here as a
                    145:    circular buffer.  The index is updated simply by incrementing and then
                    146:    and'ing with 0x7fff (32K-1). */
                    147: /* It is left to other modules to supply the 32K area.  It is assumed
                    148:    to be usable as if it were declared "uch slide[32768];" or as just
                    149:    "uch *slide;" and then malloc'ed in the latter case.  The definition
                    150:    must be in unzip.h, included above. */
                    151: /* unsigned wp;             current position in slide */
                    152: #define wp outcnt
                    153: #define flush_output(w) (wp=(w),flush_window())
                    154: 
                    155: /* Tables for deflate from PKZIP's appnote.txt. */
                    156: static unsigned border[] = {    /* Order of the bit length code lengths */
                    157:         16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15};
                    158: static ush cplens[] = {         /* Copy lengths for literal codes 257..285 */
                    159:         3, 4, 5, 6, 7, 8, 9, 10, 11, 13, 15, 17, 19, 23, 27, 31,
                    160:         35, 43, 51, 59, 67, 83, 99, 115, 131, 163, 195, 227, 258, 0, 0};
                    161:         /* note: see note #13 above about the 258 in this list. */
                    162: static ush cplext[] = {         /* Extra bits for literal codes 257..285 */
                    163:         0, 0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 2, 2, 2, 2,
                    164:         3, 3, 3, 3, 4, 4, 4, 4, 5, 5, 5, 5, 0, 99, 99}; /* 99==invalid */
                    165: static ush cpdist[] = {         /* Copy offsets for distance codes 0..29 */
                    166:         1, 2, 3, 4, 5, 7, 9, 13, 17, 25, 33, 49, 65, 97, 129, 193,
                    167:         257, 385, 513, 769, 1025, 1537, 2049, 3073, 4097, 6145,
                    168:         8193, 12289, 16385, 24577};
                    169: static ush cpdext[] = {         /* Extra bits for distance codes */
                    170:         0, 0, 0, 0, 1, 1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 6,
                    171:         7, 7, 8, 8, 9, 9, 10, 10, 11, 11,
                    172:         12, 12, 13, 13};
                    173: 
                    174: 
                    175: 
                    176: /* Macros for inflate() bit peeking and grabbing.
                    177:    The usage is:
                    178:    
                    179:         NEEDBITS(j)
                    180:         x = b & mask_bits[j];
                    181:         DUMPBITS(j)
                    182: 
                    183:    where NEEDBITS makes sure that b has at least j bits in it, and
                    184:    DUMPBITS removes the bits from b.  The macros use the variable k
                    185:    for the number of bits in b.  Normally, b and k are register
                    186:    variables for speed, and are initialized at the begining of a
                    187:    routine that uses these macros from a global bit buffer and count.
                    188: 
                    189:    If we assume that EOB will be the longest code, then we will never
                    190:    ask for bits with NEEDBITS that are beyond the end of the stream.
                    191:    So, NEEDBITS should not read any more bytes than are needed to
                    192:    meet the request.  Then no bytes need to be "returned" to the buffer
                    193:    at the end of the last block.
                    194: 
                    195:    However, this assumption is not true for fixed blocks--the EOB code
                    196:    is 7 bits, but the other literal/length codes can be 8 or 9 bits.
                    197:    (The EOB code is shorter than other codes becuase fixed blocks are
                    198:    generally short.  So, while a block always has an EOB, many other
                    199:    literal/length codes have a significantly lower probability of
                    200:    showing up at all.)  However, by making the first table have a
                    201:    lookup of seven bits, the EOB code will be found in that first
                    202:    lookup, and so will not require that too many bits be pulled from
                    203:    the stream.
                    204:  */
                    205: 
                    206: ulg bb;                         /* bit buffer */
                    207: unsigned bk;                    /* bits in bit buffer */
                    208: 
                    209: ush mask_bits[] = {
                    210:     0x0000,
                    211:     0x0001, 0x0003, 0x0007, 0x000f, 0x001f, 0x003f, 0x007f, 0x00ff,
                    212:     0x01ff, 0x03ff, 0x07ff, 0x0fff, 0x1fff, 0x3fff, 0x7fff, 0xffff
                    213: };
                    214: 
                    215: #ifdef CRYPT
                    216:   uch cc;
                    217: #  define NEXTBYTE() \
                    218:      (decrypt ? (cc = get_byte(), zdecode(cc), cc) : get_byte())
                    219: #else
                    220: #  define NEXTBYTE()  (uch)get_byte()
                    221: #endif
                    222: #define NEEDBITS(n) {while(k<(n)){b|=((ulg)NEXTBYTE())<<k;k+=8;}}
                    223: #define DUMPBITS(n) {b>>=(n);k-=(n);}
                    224: 
                    225: 
                    226: /*
                    227:    Huffman code decoding is performed using a multi-level table lookup.
                    228:    The fastest way to decode is to simply build a lookup table whose
                    229:    size is determined by the longest code.  However, the time it takes
                    230:    to build this table can also be a factor if the data being decoded
                    231:    is not very long.  The most common codes are necessarily the
                    232:    shortest codes, so those codes dominate the decoding time, and hence
                    233:    the speed.  The idea is you can have a shorter table that decodes the
                    234:    shorter, more probable codes, and then point to subsidiary tables for
                    235:    the longer codes.  The time it costs to decode the longer codes is
                    236:    then traded against the time it takes to make longer tables.
                    237: 
                    238:    This results of this trade are in the variables lbits and dbits
                    239:    below.  lbits is the number of bits the first level table for literal/
                    240:    length codes can decode in one step, and dbits is the same thing for
                    241:    the distance codes.  Subsequent tables are also less than or equal to
                    242:    those sizes.  These values may be adjusted either when all of the
                    243:    codes are shorter than that, in which case the longest code length in
                    244:    bits is used, or when the shortest code is *longer* than the requested
                    245:    table size, in which case the length of the shortest code in bits is
                    246:    used.
                    247: 
                    248:    There are two different values for the two tables, since they code a
                    249:    different number of possibilities each.  The literal/length table
                    250:    codes 286 possible values, or in a flat code, a little over eight
                    251:    bits.  The distance table codes 30 possible values, or a little less
                    252:    than five bits, flat.  The optimum values for speed end up being
                    253:    about one bit more than those, so lbits is 8+1 and dbits is 5+1.
                    254:    The optimum values may differ though from machine to machine, and
                    255:    possibly even between compilers.  Your mileage may vary.
                    256:  */
                    257: 
                    258: 
                    259: int lbits = 9;          /* bits in base literal/length lookup table */
                    260: int dbits = 6;          /* bits in base distance lookup table */
                    261: 
                    262: 
                    263: /* If BMAX needs to be larger than 16, then h and x[] should be ulg. */
                    264: #define BMAX 16         /* maximum bit length of any code (16 for explode) */
                    265: #define N_MAX 288       /* maximum number of codes in any set */
                    266: 
                    267: 
                    268: unsigned hufts;         /* track memory usage */
                    269: 
                    270: 
                    271: int huft_build(b, n, s, d, e, t, m)
                    272: unsigned *b;            /* code lengths in bits (all assumed <= BMAX) */
                    273: unsigned n;             /* number of codes (assumed <= N_MAX) */
                    274: unsigned s;             /* number of simple-valued codes (0..s-1) */
                    275: ush *d;                 /* list of base values for non-simple codes */
                    276: ush *e;                 /* list of extra bits for non-simple codes */
                    277: struct huft **t;        /* result: starting table */
                    278: int *m;                 /* maximum lookup bits, returns actual */
                    279: /* Given a list of code lengths and a maximum table size, make a set of
                    280:    tables to decode that set of codes.  Return zero on success, one if
                    281:    the given code set is incomplete (the tables are still built in this
                    282:    case), two if the input is invalid (all zero length codes or an
                    283:    oversubscribed set of lengths), and three if not enough memory. */
                    284: {
                    285:   unsigned a;                   /* counter for codes of length k */
                    286:   unsigned c[BMAX+1];           /* bit length count table */
                    287:   unsigned f;                   /* i repeats in table every f entries */
                    288:   int g;                        /* maximum code length */
                    289:   int h;                        /* table level */
                    290:   register unsigned i;          /* counter, current code */
                    291:   register unsigned j;          /* counter */
                    292:   register int k;               /* number of bits in current code */
                    293:   int l;                        /* bits per table (returned in m) */
                    294:   register unsigned *p;         /* pointer into c[], b[], or v[] */
                    295:   register struct huft *q;      /* points to current table */
                    296:   struct huft r;                /* table entry for structure assignment */
                    297:   struct huft *u[BMAX];         /* table stack */
                    298:   unsigned v[N_MAX];            /* values in order of bit length */
                    299:   register int w;               /* bits before this table == (l * h) */
                    300:   unsigned x[BMAX+1];           /* bit offsets, then code stack */
                    301:   unsigned *xp;                 /* pointer into x */
                    302:   int y;                        /* number of dummy codes added */
                    303:   unsigned z;                   /* number of entries in current table */
                    304: 
                    305: 
                    306:   /* Generate counts for each bit length */
                    307:   memzero(c, sizeof(c));
                    308:   p = b;  i = n;
                    309:   do {
                    310:     Tracecv(*p, (stderr, (n-i >= ' ' && n-i <= '~' ? "%c %d\n" : "0x%x %d\n"), 
                    311:            n-i, *p));
                    312:     c[*p++]++;                  /* assume all entries <= BMAX */
                    313:   } while (--i);
                    314:   if (c[0] == n)                /* null input--all zero length codes */
                    315:   {
                    316:     *t = (struct huft *)NULL;
                    317:     *m = 0;
                    318:     return 0;
                    319:   }
                    320: 
                    321: 
                    322:   /* Find minimum and maximum length, bound *m by those */
                    323:   l = *m;
                    324:   for (j = 1; j <= BMAX; j++)
                    325:     if (c[j])
                    326:       break;
                    327:   k = j;                        /* minimum code length */
                    328:   if ((unsigned)l < j)
                    329:     l = j;
                    330:   for (i = BMAX; i; i--)
                    331:     if (c[i])
                    332:       break;
                    333:   g = i;                        /* maximum code length */
                    334:   if ((unsigned)l > i)
                    335:     l = i;
                    336:   *m = l;
                    337: 
                    338: 
                    339:   /* Adjust last length count to fill out codes, if needed */
                    340:   for (y = 1 << j; j < i; j++, y <<= 1)
                    341:     if ((y -= c[j]) < 0)
                    342:       return 2;                 /* bad input: more codes than bits */
                    343:   if ((y -= c[i]) < 0)
                    344:     return 2;
                    345:   c[i] += y;
                    346: 
                    347: 
                    348:   /* Generate starting offsets into the value table for each length */
                    349:   x[1] = j = 0;
                    350:   p = c + 1;  xp = x + 2;
                    351:   while (--i) {                 /* note that i == g from above */
                    352:     *xp++ = (j += *p++);
                    353:   }
                    354: 
                    355: 
                    356:   /* Make a table of values in order of bit lengths */
                    357:   p = b;  i = 0;
                    358:   do {
                    359:     if ((j = *p++) != 0)
                    360:       v[x[j]++] = i;
                    361:   } while (++i < n);
                    362: 
                    363: 
                    364:   /* Generate the Huffman codes and for each, make the table entries */
                    365:   x[0] = i = 0;                 /* first Huffman code is zero */
                    366:   p = v;                        /* grab values in bit order */
                    367:   h = -1;                       /* no tables yet--level -1 */
                    368:   w = -l;                       /* bits decoded == (l * h) */
                    369:   u[0] = (struct huft *)NULL;   /* just to keep compilers happy */
                    370:   q = (struct huft *)NULL;      /* ditto */
                    371:   z = 0;                        /* ditto */
                    372: 
                    373:   /* go through the bit lengths (k already is bits in shortest code) */
                    374:   for (; k <= g; k++)
                    375:   {
                    376:     a = c[k];
                    377:     while (a--)
                    378:     {
                    379:       /* here i is the Huffman code of length k bits for value *p */
                    380:       /* make tables up to required level */
                    381:       while (k > w + l)
                    382:       {
                    383:         h++;
                    384:         w += l;                 /* previous table always l bits */
                    385: 
                    386:         /* compute minimum size table less than or equal to l bits */
                    387:         z = (z = g - w) > (unsigned)l ? l : z;  /* upper limit on table size */
                    388:         if ((f = 1 << (j = k - w)) > a + 1)     /* try a k-w bit table */
                    389:         {                       /* too few codes for k-w bit table */
                    390:           f -= a + 1;           /* deduct codes from patterns left */
                    391:           xp = c + k;
                    392:           while (++j < z)       /* try smaller tables up to z bits */
                    393:           {
                    394:             if ((f <<= 1) <= *++xp)
                    395:               break;            /* enough codes to use up j bits */
                    396:             f -= *xp;           /* else deduct codes from patterns */
                    397:           }
                    398:         }
                    399:         z = 1 << j;             /* table entries for j-bit table */
                    400: 
                    401:         /* allocate and link in new table */
                    402:         if ((q = (struct huft *)malloc((z + 1)*sizeof(struct huft))) ==
                    403:             (struct huft *)NULL)
                    404:         {
                    405:           if (h)
                    406:             huft_free(u[0]);
                    407:           return 3;             /* not enough memory */
                    408:         }
                    409:         hufts += z + 1;         /* track memory usage */
                    410:         *t = q + 1;             /* link to list for huft_free() */
                    411:         *(t = &(q->v.t)) = (struct huft *)NULL;
                    412:         u[h] = ++q;             /* table starts after link */
                    413: 
                    414:         /* connect to last table, if there is one */
                    415:         if (h)
                    416:         {
                    417:           x[h] = i;             /* save pattern for backing up */
                    418:           r.b = (uch)l;         /* bits to dump before this table */
                    419:           r.e = (uch)(16 + j);  /* bits in this table */
                    420:           r.v.t = q;            /* pointer to this table */
                    421:           j = i >> (w - l);     /* (get around Turbo C bug) */
                    422:           u[h-1][j] = r;        /* connect to last table */
                    423:         }
                    424:       }
                    425: 
                    426:       /* set up table entry in r */
                    427:       r.b = (uch)(k - w);
                    428:       if (p >= v + n)
                    429:         r.e = 99;               /* out of values--invalid code */
                    430:       else if (*p < s)
                    431:       {
                    432:         r.e = (uch)(*p < 256 ? 16 : 15);    /* 256 is end-of-block code */
                    433:         r.v.n = *p++;           /* simple code is just the value */
                    434:       }
                    435:       else
                    436:       {
                    437:         r.e = (uch)e[*p - s];   /* non-simple--look up in lists */
                    438:         r.v.n = d[*p++ - s];
                    439:       }
                    440: 
                    441:       /* fill code-like entries with r */
                    442:       f = 1 << (k - w);
                    443:       for (j = i >> w; j < z; j += f)
                    444:         q[j] = r;
                    445: 
                    446:       /* backwards increment the k-bit code i */
                    447:       for (j = 1 << (k - 1); i & j; j >>= 1)
                    448:         i ^= j;
                    449:       i ^= j;
                    450: 
                    451:       /* backup over finished tables */
                    452:       while ((i & ((1 << w) - 1)) != x[h])
                    453:       {
                    454:         h--;                    /* don't need to update q */
                    455:         w -= l;
                    456:       }
                    457:     }
                    458:   }
                    459: 
                    460: 
                    461:   /* Return true (1) if we were given an incomplete table */
                    462:   return y != 0 && g != 1;
                    463: }
                    464: 
                    465: 
                    466: 
                    467: int huft_free(t)
                    468: struct huft *t;         /* table to free */
                    469: /* Free the malloc'ed tables built by huft_build(), which makes a linked
                    470:    list of the tables it made, with the links in a dummy first entry of
                    471:    each table. */
                    472: {
                    473:   register struct huft *p, *q;
                    474: 
                    475: 
                    476:   /* Go through linked list, freeing from the malloced (t[-1]) address. */
                    477:   p = t;
                    478:   while (p != (struct huft *)NULL)
                    479:   {
                    480:     q = (--p)->v.t;
                    481:     free(p);
                    482:     p = q;
                    483:   } 
                    484:   return 0;
                    485: }
                    486: 
                    487: 
                    488: int inflate_codes(tl, td, bl, bd)
                    489: struct huft *tl, *td;   /* literal/length and distance decoder tables */
                    490: int bl, bd;             /* number of bits decoded by tl[] and td[] */
                    491: /* inflate (decompress) the codes in a deflated (compressed) block.
                    492:    Return an error code or zero if it all goes ok. */
                    493: {
                    494:   register unsigned e;  /* table entry flag/number of extra bits */
                    495:   unsigned n, d;        /* length and index for copy */
                    496:   unsigned w;           /* current window position */
                    497:   struct huft *t;       /* pointer to table entry */
                    498:   unsigned ml, md;      /* masks for bl and bd bits */
                    499:   register ulg b;       /* bit buffer */
                    500:   register unsigned k;  /* number of bits in bit buffer */
                    501: 
                    502: 
                    503:   /* make local copies of globals */
                    504:   b = bb;                       /* initialize bit buffer */
                    505:   k = bk;
                    506:   w = wp;                       /* initialize window position */
                    507: 
                    508:   /* inflate the coded data */
                    509:   ml = mask_bits[bl];           /* precompute masks for speed */
                    510:   md = mask_bits[bd];
                    511:   for (;;)                      /* do until end of block */
                    512:   {
                    513:     NEEDBITS((unsigned)bl)
                    514:     if ((e = (t = tl + ((unsigned)b & ml))->e) > 16)
                    515:       do {
                    516:         if (e == 99)
                    517:           return 1;
                    518:         DUMPBITS(t->b)
                    519:         e -= 16;
                    520:         NEEDBITS(e)
                    521:       } while ((e = (t = t->v.t + ((unsigned)b & mask_bits[e]))->e) > 16);
                    522:     DUMPBITS(t->b)
                    523:     if (e == 16)                /* then it's a literal */
                    524:     {
                    525:       slide[w++] = (uch)t->v.n;
                    526:       Tracevv((stderr, "%c", slide[w-1]));
                    527:       if (w == WSIZE)
                    528:       {
                    529:         flush_output(w);
                    530:         w = 0;
                    531:       }
                    532:     }
                    533:     else                        /* it's an EOB or a length */
                    534:     {
                    535:       /* exit if end of block */
                    536:       if (e == 15)
                    537:         break;
                    538: 
                    539:       /* get length of block to copy */
                    540:       NEEDBITS(e)
                    541:       n = t->v.n + ((unsigned)b & mask_bits[e]);
                    542:       DUMPBITS(e);
                    543: 
                    544:       /* decode distance of block to copy */
                    545:       NEEDBITS((unsigned)bd)
                    546:       if ((e = (t = td + ((unsigned)b & md))->e) > 16)
                    547:         do {
                    548:           if (e == 99)
                    549:             return 1;
                    550:           DUMPBITS(t->b)
                    551:           e -= 16;
                    552:           NEEDBITS(e)
                    553:         } while ((e = (t = t->v.t + ((unsigned)b & mask_bits[e]))->e) > 16);
                    554:       DUMPBITS(t->b)
                    555:       NEEDBITS(e)
                    556:       d = w - t->v.n - ((unsigned)b & mask_bits[e]);
                    557:       DUMPBITS(e)
                    558:       Tracevv((stderr,"\\[%d,%d]", w-d, n));
                    559: 
                    560:       /* do the copy */
                    561:       do {
                    562:         n -= (e = (e = WSIZE - ((d &= WSIZE-1) > w ? d : w)) > n ? n : e);
                    563: #if !defined(NOMEMCPY) && !defined(DEBUG)
                    564:         if (w - d >= e)         /* (this test assumes unsigned comparison) */
                    565:         {
                    566:           memcpy(slide + w, slide + d, e);
                    567:           w += e;
                    568:           d += e;
                    569:         }
                    570:         else                      /* do it slow to avoid memcpy() overlap */
                    571: #endif /* !NOMEMCPY */
                    572:           do {
                    573:             slide[w++] = slide[d++];
                    574:            Tracevv((stderr, "%c", slide[w-1]));
                    575:           } while (--e);
                    576:         if (w == WSIZE)
                    577:         {
                    578:           flush_output(w);
                    579:           w = 0;
                    580:         }
                    581:       } while (n);
                    582:     }
                    583:   }
                    584: 
                    585: 
                    586:   /* restore the globals from the locals */
                    587:   wp = w;                       /* restore global window pointer */
                    588:   bb = b;                       /* restore global bit buffer */
                    589:   bk = k;
                    590: 
                    591:   /* done */
                    592:   return 0;
                    593: }
                    594: 
                    595: 
                    596: 
                    597: int inflate_stored()
                    598: /* "decompress" an inflated type 0 (stored) block. */
                    599: {
                    600:   unsigned n;           /* number of bytes in block */
                    601:   unsigned w;           /* current window position */
                    602:   register ulg b;       /* bit buffer */
                    603:   register unsigned k;  /* number of bits in bit buffer */
                    604: 
                    605: 
                    606:   /* make local copies of globals */
                    607:   b = bb;                       /* initialize bit buffer */
                    608:   k = bk;
                    609:   w = wp;                       /* initialize window position */
                    610: 
                    611: 
                    612:   /* go to byte boundary */
                    613:   n = k & 7;
                    614:   DUMPBITS(n);
                    615: 
                    616: 
                    617:   /* get the length and its complement */
                    618:   NEEDBITS(16)
                    619:   n = ((unsigned)b & 0xffff);
                    620:   DUMPBITS(16)
                    621:   NEEDBITS(16)
                    622:   if (n != (unsigned)((~b) & 0xffff))
                    623:     return 1;                   /* error in compressed data */
                    624:   DUMPBITS(16)
                    625: 
                    626: 
                    627:   /* read and output the compressed data */
                    628:   while (n--)
                    629:   {
                    630:     NEEDBITS(8)
                    631:     slide[w++] = (uch)b;
                    632:     if (w == WSIZE)
                    633:     {
                    634:       flush_output(w);
                    635:       w = 0;
                    636:     }
                    637:     DUMPBITS(8)
                    638:   }
                    639: 
                    640: 
                    641:   /* restore the globals from the locals */
                    642:   wp = w;                       /* restore global window pointer */
                    643:   bb = b;                       /* restore global bit buffer */
                    644:   bk = k;
                    645:   return 0;
                    646: }
                    647: 
                    648: 
                    649: 
                    650: int inflate_fixed()
                    651: /* decompress an inflated type 1 (fixed Huffman codes) block.  We should
                    652:    either replace this with a custom decoder, or at least precompute the
                    653:    Huffman tables. */
                    654: {
                    655:   int i;                /* temporary variable */
                    656:   struct huft *tl;      /* literal/length code table */
                    657:   struct huft *td;      /* distance code table */
                    658:   int bl;               /* lookup bits for tl */
                    659:   int bd;               /* lookup bits for td */
                    660:   unsigned l[288];      /* length list for huft_build */
                    661: 
                    662: 
                    663:   /* set up literal table */
                    664:   for (i = 0; i < 144; i++)
                    665:     l[i] = 8;
                    666:   for (; i < 256; i++)
                    667:     l[i] = 9;
                    668:   for (; i < 280; i++)
                    669:     l[i] = 7;
                    670:   for (; i < 288; i++)          /* make a complete, but wrong code set */
                    671:     l[i] = 8;
                    672:   bl = 7;
                    673:   if ((i = huft_build(l, 288, 257, cplens, cplext, &tl, &bl)) != 0)
                    674:     return i;
                    675: 
                    676: 
                    677:   /* set up distance table */
                    678:   for (i = 0; i < 30; i++)      /* make an incomplete code set */
                    679:     l[i] = 5;
                    680:   bd = 5;
                    681:   if ((i = huft_build(l, 30, 0, cpdist, cpdext, &td, &bd)) > 1)
                    682:   {
                    683:     huft_free(tl);
                    684:     return i;
                    685:   }
                    686: 
                    687: 
                    688:   /* decompress until an end-of-block code */
                    689:   if (inflate_codes(tl, td, bl, bd))
                    690:     return 1;
                    691: 
                    692: 
                    693:   /* free the decoding tables, return */
                    694:   huft_free(tl);
                    695:   huft_free(td);
                    696:   return 0;
                    697: }
                    698: 
                    699: 
                    700: 
                    701: int inflate_dynamic()
                    702: /* decompress an inflated type 2 (dynamic Huffman codes) block. */
                    703: {
                    704:   int i;                /* temporary variables */
                    705:   unsigned j;
                    706:   unsigned l;           /* last length */
                    707:   unsigned m;           /* mask for bit lengths table */
                    708:   unsigned n;           /* number of lengths to get */
                    709:   struct huft *tl;      /* literal/length code table */
                    710:   struct huft *td;      /* distance code table */
                    711:   int bl;               /* lookup bits for tl */
                    712:   int bd;               /* lookup bits for td */
                    713:   unsigned nb;          /* number of bit length codes */
                    714:   unsigned nl;          /* number of literal/length codes */
                    715:   unsigned nd;          /* number of distance codes */
                    716: #ifdef PKZIP_BUG_WORKAROUND
                    717:   unsigned ll[288+32];  /* literal/length and distance code lengths */
                    718: #else
                    719:   unsigned ll[286+30];  /* literal/length and distance code lengths */
                    720: #endif
                    721:   register ulg b;       /* bit buffer */
                    722:   register unsigned k;  /* number of bits in bit buffer */
                    723: 
                    724: 
                    725:   /* make local bit buffer */
                    726:   b = bb;
                    727:   k = bk;
                    728: 
                    729: 
                    730:   /* read in table lengths */
                    731:   NEEDBITS(5)
                    732:   nl = 257 + ((unsigned)b & 0x1f);      /* number of literal/length codes */
                    733:   DUMPBITS(5)
                    734:   NEEDBITS(5)
                    735:   nd = 1 + ((unsigned)b & 0x1f);        /* number of distance codes */
                    736:   DUMPBITS(5)
                    737:   NEEDBITS(4)
                    738:   nb = 4 + ((unsigned)b & 0xf);         /* number of bit length codes */
                    739:   DUMPBITS(4)
                    740: #ifdef PKZIP_BUG_WORKAROUND
                    741:   if (nl > 288 || nd > 32)
                    742: #else
                    743:   if (nl > 286 || nd > 30)
                    744: #endif
                    745:     return 1;                   /* bad lengths */
                    746: 
                    747: 
                    748:   /* read in bit-length-code lengths */
                    749:   for (j = 0; j < nb; j++)
                    750:   {
                    751:     NEEDBITS(3)
                    752:     ll[border[j]] = (unsigned)b & 7;
                    753:     DUMPBITS(3)
                    754:   }
                    755:   for (; j < 19; j++)
                    756:     ll[border[j]] = 0;
                    757: 
                    758: 
                    759:   /* build decoding table for trees--single level, 7 bit lookup */
                    760:   bl = 7;
                    761:   if ((i = huft_build(ll, 19, 19, NULL, NULL, &tl, &bl)) != 0)
                    762:   {
                    763:     if (i == 1)
                    764:       huft_free(tl);
                    765:     return i;                   /* incomplete code set */
                    766:   }
                    767: 
                    768: 
                    769:   /* read in literal and distance code lengths */
                    770:   n = nl + nd;
                    771:   m = mask_bits[bl];
                    772:   i = l = 0;
                    773:   while ((unsigned)i < n)
                    774:   {
                    775:     NEEDBITS((unsigned)bl)
                    776:     j = (td = tl + ((unsigned)b & m))->b;
                    777:     DUMPBITS(j)
                    778:     j = td->v.n;
                    779:     if (j < 16)                 /* length of code in bits (0..15) */
                    780:       ll[i++] = l = j;          /* save last length in l */
                    781:     else if (j == 16)           /* repeat last length 3 to 6 times */
                    782:     {
                    783:       NEEDBITS(2)
                    784:       j = 3 + ((unsigned)b & 3);
                    785:       DUMPBITS(2)
                    786:       if ((unsigned)i + j > n)
                    787:         return 1;
                    788:       while (j--)
                    789:         ll[i++] = l;
                    790:     }
                    791:     else if (j == 17)           /* 3 to 10 zero length codes */
                    792:     {
                    793:       NEEDBITS(3)
                    794:       j = 3 + ((unsigned)b & 7);
                    795:       DUMPBITS(3)
                    796:       if ((unsigned)i + j > n)
                    797:         return 1;
                    798:       while (j--)
                    799:         ll[i++] = 0;
                    800:       l = 0;
                    801:     }
                    802:     else                        /* j == 18: 11 to 138 zero length codes */
                    803:     {
                    804:       NEEDBITS(7)
                    805:       j = 11 + ((unsigned)b & 0x7f);
                    806:       DUMPBITS(7)
                    807:       if ((unsigned)i + j > n)
                    808:         return 1;
                    809:       while (j--)
                    810:         ll[i++] = 0;
                    811:       l = 0;
                    812:     }
                    813:   }
                    814: 
                    815: 
                    816:   /* free decoding table for trees */
                    817:   huft_free(tl);
                    818: 
                    819: 
                    820:   /* restore the global bit buffer */
                    821:   bb = b;
                    822:   bk = k;
                    823: 
                    824: 
                    825:   /* build the decoding tables for literal/length and distance codes */
                    826:   bl = lbits;
                    827:   if ((i = huft_build(ll, nl, 257, cplens, cplext, &tl, &bl)) != 0)
                    828:   {
                    829:     if (i == 1) {
                    830:       fprintf(stderr, " incomplete literal tree\n");
                    831:       huft_free(tl);
                    832:     }
                    833:     return i;                   /* incomplete code set */
                    834:   }
                    835:   bd = dbits;
                    836:   if ((i = huft_build(ll + nl, nd, 0, cpdist, cpdext, &td, &bd)) != 0)
                    837:   {
                    838:     if (i == 1) {
                    839:       fprintf(stderr, " incomplete distance tree\n");
                    840: #ifdef PKZIP_BUG_WORKAROUND
                    841:       i = 0;
                    842:     }
                    843: #else
                    844:       huft_free(td);
                    845:     }
                    846:     huft_free(tl);
                    847:     return i;                   /* incomplete code set */
                    848: #endif
                    849:   }
                    850: 
                    851: 
                    852:   /* decompress until an end-of-block code */
                    853:   if (inflate_codes(tl, td, bl, bd))
                    854:     return 1;
                    855: 
                    856: 
                    857:   /* free the decoding tables, return */
                    858:   huft_free(tl);
                    859:   huft_free(td);
                    860:   return 0;
                    861: }
                    862: 
                    863: 
                    864: 
                    865: int inflate_block(e)
                    866: int *e;                 /* last block flag */
                    867: /* decompress an inflated block */
                    868: {
                    869:   unsigned t;           /* block type */
                    870:   register ulg b;       /* bit buffer */
                    871:   register unsigned k;  /* number of bits in bit buffer */
                    872: 
                    873: 
                    874:   /* make local bit buffer */
                    875:   b = bb;
                    876:   k = bk;
                    877: 
                    878: 
                    879:   /* read in last block bit */
                    880:   NEEDBITS(1)
                    881:   *e = (int)b & 1;
                    882:   DUMPBITS(1)
                    883: 
                    884: 
                    885:   /* read in block type */
                    886:   NEEDBITS(2)
                    887:   t = (unsigned)b & 3;
                    888:   DUMPBITS(2)
                    889: 
                    890: 
                    891:   /* restore the global bit buffer */
                    892:   bb = b;
                    893:   bk = k;
                    894: 
                    895: 
                    896:   /* inflate that block type */
                    897:   if (t == 2)
                    898:     return inflate_dynamic();
                    899:   if (t == 0)
                    900:     return inflate_stored();
                    901:   if (t == 1)
                    902:     return inflate_fixed();
                    903: 
                    904: 
                    905:   /* bad block type */
                    906:   return 2;
                    907: }
                    908: 
                    909: 
                    910: 
                    911: int inflate()
                    912: /* decompress an inflated entry */
                    913: {
                    914:   int e;                /* last block flag */
                    915:   int r;                /* result code */
                    916:   unsigned h;           /* maximum struct huft's malloc'ed */
                    917: 
                    918: 
                    919:   /* initialize window, bit buffer */
                    920:   wp = 0;
                    921:   bk = 0;
                    922:   bb = 0;
                    923: 
                    924: 
                    925:   /* decompress until the last block */
                    926:   h = 0;
                    927:   do {
                    928:     hufts = 0;
                    929:     if ((r = inflate_block(&e)) != 0)
                    930:       return r;
                    931:     if (hufts > h)
                    932:       h = hufts;
                    933:   } while (!e);
                    934: 
                    935:   /* Undo too much lookahead. The next read will be byte aligned so we
                    936:    * can discard unused bits in the last meaningful byte.
                    937:    */
                    938:   while (bk >= 8) {
                    939:     bk -= 8;
                    940:     inptr--;
                    941:   }
                    942: 
                    943:   /* flush out slide */
                    944:   flush_output(wp);
                    945: 
                    946: 
                    947:   /* return success */
                    948: #ifdef DEBUG
                    949:   fprintf(stderr, "<%u> ", h);
                    950: #endif /* DEBUG */
                    951:   return 0;
                    952: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.