]>
git.saurik.com Git - wxWidgets.git/blob - src/zlib/infback.c
   1 /* infback.c -- inflate using a call-back interface 
   2  * Copyright (C) 1995-2003 Mark Adler 
   3  * For conditions of distribution and use, see copyright notice in zlib.h 
   7    This code is largely copied from inflate.c.  Normally either infback.o or 
   8    inflate.o would be linked into an application--not both.  The interface 
   9    with inffast.c is retained so that optimized assembler-coded versions of 
  10    inflate_fast() can be used with either inflate.c or infback.c. 
  18 /* function prototypes */ 
  19 local 
void fixedtables 
OF((struct inflate_state FAR 
*state
)); 
  22    strm provides memory allocation functions in zalloc and zfree, or 
  23    Z_NULL to use the library memory allocation functions. 
  25    windowBits is in the range 8..15, and window is a user-supplied 
  26    window and output buffer that is 2**windowBits bytes. 
  28 int ZEXPORT 
inflateBackInit_(strm
, windowBits
, window
, version
, stream_size
) 
  31 unsigned char FAR 
*window
; 
  35     struct inflate_state FAR 
*state
; 
  37     if (version 
== Z_NULL 
|| version
[0] != ZLIB_VERSION
[0] || 
  38         stream_size 
!= (int)(sizeof(z_stream
))) 
  39         return Z_VERSION_ERROR
; 
  40     if (strm 
== Z_NULL 
|| window 
== Z_NULL 
|| 
  41         windowBits 
< 8 || windowBits 
> 15) 
  42         return Z_STREAM_ERROR
; 
  43     strm
->msg 
= Z_NULL
;                 /* in case we return an error */ 
  44     if (strm
->zalloc 
== (alloc_func
)0) { 
  45         strm
->zalloc 
= zcalloc
; 
  46         strm
->opaque 
= (voidpf
)0; 
  48     if (strm
->zfree 
== (free_func
)0) strm
->zfree 
= zcfree
; 
  49     state 
= (struct inflate_state FAR 
*)ZALLOC(strm
, 1, 
  50                                                sizeof(struct inflate_state
)); 
  51     if (state 
== Z_NULL
) return Z_MEM_ERROR
; 
  52     Tracev((stderr
, "inflate: allocated\n")); 
  53     strm
->state 
= (voidpf
)state
; 
  54     state
->wbits 
= windowBits
; 
  55     state
->wsize 
= 1U << windowBits
; 
  56     state
->window 
= window
; 
  63    Return state with length and distance decoding tables and index sizes set to 
  64    fixed code decoding.  Normally this returns fixed tables from inffixed.h. 
  65    If BUILDFIXED is defined, then instead this routine builds the tables the 
  66    first time it's called, and returns those tables the first time and 
  67    thereafter.  This reduces the size of the code by about 2K bytes, in 
  68    exchange for a little execution time.  However, BUILDFIXED should not be 
  69    used for threaded applications, since the rewriting of the tables and virgin 
  70    may not be thread-safe. 
  72 local 
void fixedtables(state
) 
  73 struct inflate_state FAR 
*state
; 
  76     static int virgin 
= 1; 
  77     static code 
*lenfix
, *distfix
; 
  78     static code fixed
[544]; 
  80     /* build fixed huffman tables if first call (may not be thread safe) */ 
  85         /* literal/length table */ 
  87         while (sym 
< 144) state
->lens
[sym
++] = 8; 
  88         while (sym 
< 256) state
->lens
[sym
++] = 9; 
  89         while (sym 
< 280) state
->lens
[sym
++] = 7; 
  90         while (sym 
< 288) state
->lens
[sym
++] = 8; 
  94         inflate_table(LENS
, state
->lens
, 288, &(next
), &(bits
), state
->work
); 
  98         while (sym 
< 32) state
->lens
[sym
++] = 5; 
 101         inflate_table(DISTS
, state
->lens
, 32, &(next
), &(bits
), state
->work
); 
 103         /* do this just once */ 
 106 #else /* !BUILDFIXED */ 
 107 #   include "inffixed.h" 
 108 #endif /* BUILDFIXED */ 
 109     state
->lencode 
= lenfix
; 
 111     state
->distcode 
= distfix
; 
 115 /* Macros for inflateBack(): */ 
 117 /* Load returned state from inflate_fast() */ 
 120         put = strm->next_out; \ 
 121         left = strm->avail_out; \ 
 122         next = strm->next_in; \ 
 123         have = strm->avail_in; \ 
 124         hold = state->hold; \ 
 125         bits = state->bits; \ 
 128 /* Set state from registers for inflate_fast() */ 
 131         strm->next_out = put; \ 
 132         strm->avail_out = left; \ 
 133         strm->next_in = next; \ 
 134         strm->avail_in = have; \ 
 135         state->hold = hold; \ 
 136         state->bits = bits; \ 
 139 /* Clear the input bit accumulator */ 
 146 /* Assure that some input is available.  If input is requested, but denied, 
 147    then return a Z_BUF_ERROR from inflateBack(). */ 
 151             have = in(in_desc, &next); \ 
 160 /* Get a byte of input into the bit accumulator, or return from inflateBack() 
 161    with an error if there is no input available. */ 
 166         hold += (unsigned long)(*next++) << bits; \ 
 170 /* Assure that there are at least n bits in the bit accumulator.  If there is 
 171    not enough available input to do that, then return from inflateBack() with 
 173 #define NEEDBITS(n) \ 
 175         while (bits < (unsigned)(n)) \ 
 179 /* Return the low n bits of the bit accumulator (n < 16) */ 
 181     ((unsigned)hold & ((1U << (n)) - 1)) 
 183 /* Remove n bits from the bit accumulator */ 
 184 #define DROPBITS(n) \ 
 187         bits -= (unsigned)(n); \ 
 190 /* Remove zero to seven bits as needed to go to a byte boundary */ 
 197 /* Assure that some output space is available, by writing out the window 
 198    if it's full.  If the write fails, return from inflateBack() with a 
 203             put = state->window; \ 
 204             left = state->wsize; \ 
 205             state->whave = left; \ 
 206             if (out(out_desc, put, left)) { \ 
 214    strm provides the memory allocation functions and window buffer on input, 
 215    and provides information on the unused input on return.  For Z_DATA_ERROR 
 216    returns, strm will also provide an error message. 
 218    in() and out() are the call-back input and output functions.  When 
 219    inflateBack() needs more input, it calls in().  When inflateBack() has 
 220    filled the window with output, or when it completes with data in the 
 221    window, it calls out() to write out the data.  The application must not 
 222    change the provided input until in() is called again or inflateBack() 
 223    returns.  The application must not change the window/output buffer until 
 224    inflateBack() returns. 
 226    in() and out() are called with a descriptor parameter provided in the 
 227    inflateBack() call.  This parameter can be a structure that provides the 
 228    information required to do the read or write, as well as accumulated 
 229    information on the input and output such as totals and check values. 
 231    in() should return zero on failure.  out() should return non-zero on 
 232    failure.  If either in() or out() fails, than inflateBack() returns a 
 233    Z_BUF_ERROR.  strm->next_in can be checked for Z_NULL to see whether it 
 234    was in() or out() that caused in the error.  Otherwise,  inflateBack() 
 235    returns Z_STREAM_END on success, Z_DATA_ERROR for an deflate format 
 236    error, or Z_MEM_ERROR if it could not allocate memory for the state. 
 237    inflateBack() can also return Z_STREAM_ERROR if the input parameters 
 238    are not correct, i.e. strm is Z_NULL or the state was not initialized. 
 240 int ZEXPORT 
inflateBack(strm
, in
, in_desc
, out
, out_desc
) 
 247     struct inflate_state FAR 
*state
; 
 248     unsigned char FAR 
*next
;    /* next input */ 
 249     unsigned char FAR 
*put
;     /* next output */ 
 250     unsigned have
, left
;        /* available input and output */ 
 251     unsigned long hold
;         /* bit buffer */ 
 252     unsigned bits
;              /* bits in bit buffer */ 
 253     unsigned copy
;              /* number of stored or match bytes to copy */ 
 254     unsigned char FAR 
*from
;    /* where to copy match bytes from */ 
 255     code 
this;                  /* current decoding table entry */ 
 256     code last
;                  /* parent table entry */ 
 257     unsigned len
;               /* length to copy for repeats, bits to drop */ 
 258     int ret
;                    /* return code */ 
 259     static const unsigned short order
[19] = /* permutation of code lengths */ 
 260         {16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15}; 
 262     /* Check that the strm exists and that the state was initialized */ 
 263     if (strm 
== Z_NULL 
|| strm
->state 
== Z_NULL
) 
 264         return Z_STREAM_ERROR
; 
 265     state 
= (struct inflate_state FAR 
*)strm
->state
; 
 267     /* Reset the state */ 
 272     next 
= strm
->next_in
; 
 273     have 
= next 
!= Z_NULL 
? strm
->avail_in 
: 0; 
 279     /* Inflate until end of block marked as last */ 
 281         switch (state
->mode
) { 
 283             /* determine and dispatch block type */ 
 290             state
->last 
= BITS(1); 
 293             case 0:                             /* stored block */ 
 294                 Tracev((stderr
, "inflate:     stored block%s\n", 
 295                         state
->last 
? " (last)" : "")); 
 296                 state
->mode 
= STORED
; 
 298             case 1:                             /* fixed block */ 
 300                 Tracev((stderr
, "inflate:     fixed codes block%s\n", 
 301                         state
->last 
? " (last)" : "")); 
 302                 state
->mode 
= LEN
;              /* decode codes */ 
 304             case 2:                             /* dynamic block */ 
 305                 Tracev((stderr
, "inflate:     dynamic codes block%s\n", 
 306                         state
->last 
? " (last)" : "")); 
 310                 strm
->msg 
= (char *)"invalid block type"; 
 317             /* get and verify stored block length */ 
 318             BYTEBITS();                         /* go to byte boundary */ 
 320             if ((hold 
& 0xffff) != ((hold 
>> 16) ^ 0xffff)) { 
 321                 strm
->msg 
= (char *)"invalid stored block lengths"; 
 325             state
->length 
= (unsigned)hold 
& 0xffff; 
 326             Tracev((stderr
, "inflate:       stored length %u\n", 
 330             /* copy stored block from input to output */ 
 331             while (state
->length 
!= 0) { 
 332                 copy 
= state
->length
; 
 335                 if (copy 
> have
) copy 
= have
; 
 336                 if (copy 
> left
) copy 
= left
; 
 337                 zmemcpy(put
, next
, copy
); 
 342                 state
->length 
-= copy
; 
 344             Tracev((stderr
, "inflate:       stored end\n")); 
 349             /* get dynamic table entries descriptor */ 
 351             state
->nlen 
= BITS(5) + 257; 
 353             state
->ndist 
= BITS(5) + 1; 
 355             state
->ncode 
= BITS(4) + 4; 
 357 #ifndef PKZIP_BUG_WORKAROUND 
 358             if (state
->nlen 
> 286 || state
->ndist 
> 30) { 
 359                 strm
->msg 
= (char *)"too many length or distance symbols"; 
 364             Tracev((stderr
, "inflate:       table sizes ok\n")); 
 366             /* get code length code lengths (not a typo) */ 
 368             while (state
->have 
< state
->ncode
) { 
 370                 state
->lens
[order
[state
->have
++]] = (unsigned short)BITS(3); 
 373             while (state
->have 
< 19) 
 374                 state
->lens
[order
[state
->have
++]] = 0; 
 375             state
->next 
= state
->codes
; 
 376             state
->lencode 
= (code 
const FAR 
*)(state
->next
); 
 378             ret 
= inflate_table(CODES
, state
->lens
, 19, &(state
->next
), 
 379                                 &(state
->lenbits
), state
->work
); 
 381                 strm
->msg 
= (char *)"invalid code lengths set"; 
 385             Tracev((stderr
, "inflate:       code lengths ok\n")); 
 387             /* get length and distance code code lengths */ 
 389             while (state
->have 
< state
->nlen 
+ state
->ndist
) { 
 391                     this = state
->lencode
[BITS(state
->lenbits
)]; 
 392                     if ((unsigned)(this.bits
) <= bits
) break; 
 398                     state
->lens
[state
->have
++] = this.val
; 
 401                     if (this.val 
== 16) { 
 402                         NEEDBITS(this.bits 
+ 2); 
 404                         if (state
->have 
== 0) { 
 405                             strm
->msg 
= (char *)"invalid bit length repeat"; 
 409                         len 
= (unsigned)(state
->lens
[state
->have 
- 1]); 
 413                     else if (this.val 
== 17) { 
 414                         NEEDBITS(this.bits 
+ 3); 
 421                         NEEDBITS(this.bits 
+ 7); 
 427                     if (state
->have 
+ copy 
> state
->nlen 
+ state
->ndist
) { 
 428                         strm
->msg 
= (char *)"invalid bit length repeat"; 
 433                         state
->lens
[state
->have
++] = (unsigned short)len
; 
 437             /* handle error breaks in while */ 
 438             if (state
->mode 
== BAD
) break; 
 440             /* build code tables */ 
 441             state
->next 
= state
->codes
; 
 442             state
->lencode 
= (code 
const FAR 
*)(state
->next
); 
 444             ret 
= inflate_table(LENS
, state
->lens
, state
->nlen
, &(state
->next
), 
 445                                 &(state
->lenbits
), state
->work
); 
 447                 strm
->msg 
= (char *)"invalid literal/lengths set"; 
 451             state
->distcode 
= (code 
const FAR 
*)(state
->next
); 
 453             ret 
= inflate_table(DISTS
, state
->lens 
+ state
->nlen
, state
->ndist
, 
 454                             &(state
->next
), &(state
->distbits
), state
->work
); 
 456                 strm
->msg 
= (char *)"invalid distances set"; 
 460             Tracev((stderr
, "inflate:       codes ok\n")); 
 464             /* use inflate_fast() if we have enough input and output */ 
 465             if (have 
>= 6 && left 
>= 258) { 
 467                 if (state
->whave 
< state
->wsize
) 
 468                     state
->whave 
= state
->wsize 
- left
; 
 469                 inflate_fast(strm
, state
->wsize
); 
 474             /* get a literal, length, or end-of-block code */ 
 476                 this = state
->lencode
[BITS(state
->lenbits
)]; 
 477                 if ((unsigned)(this.bits
) <= bits
) break; 
 480             if (this.op 
&& (this.op 
& 0xf0) == 0) { 
 483                     this = state
->lencode
[last
.val 
+ 
 484                             (BITS(last
.bits 
+ last
.op
) >> last
.bits
)]; 
 485                     if ((unsigned)(last
.bits 
+ this.bits
) <= bits
) break; 
 491             state
->length 
= (unsigned)this.val
; 
 493             /* process literal */ 
 495                 Tracevv((stderr
, this.val 
>= 0x20 && this.val 
< 0x7f ? 
 496                         "inflate:         literal '%c'\n" : 
 497                         "inflate:         literal 0x%02x\n", this.val
)); 
 499                 *put
++ = (unsigned char)(state
->length
); 
 505             /* process end of block */ 
 507                 Tracevv((stderr
, "inflate:         end of block\n")); 
 514                 strm
->msg 
= (char *)"invalid literal/length code"; 
 519             /* length code -- get extra bits, if any */ 
 520             state
->extra 
= (unsigned)(this.op
) & 15; 
 521             if (state
->extra 
!= 0) { 
 522                 NEEDBITS(state
->extra
); 
 523                 state
->length 
+= BITS(state
->extra
); 
 524                 DROPBITS(state
->extra
); 
 526             Tracevv((stderr
, "inflate:         length %u\n", state
->length
)); 
 528             /* get distance code */ 
 530                 this = state
->distcode
[BITS(state
->distbits
)]; 
 531                 if ((unsigned)(this.bits
) <= bits
) break; 
 534             if ((this.op 
& 0xf0) == 0) { 
 537                     this = state
->distcode
[last
.val 
+ 
 538                             (BITS(last
.bits 
+ last
.op
) >> last
.bits
)]; 
 539                     if ((unsigned)(last
.bits 
+ this.bits
) <= bits
) break; 
 546                 strm
->msg 
= (char *)"invalid distance code"; 
 550             state
->offset 
= (unsigned)this.val
; 
 552             /* get distance extra bits, if any */ 
 553             state
->extra 
= (unsigned)(this.op
) & 15; 
 554             if (state
->extra 
!= 0) { 
 555                 NEEDBITS(state
->extra
); 
 556                 state
->offset 
+= BITS(state
->extra
); 
 557                 DROPBITS(state
->extra
); 
 559             if (state
->offset 
> state
->wsize 
- (state
->whave 
< state
->wsize 
? 
 561                 strm
->msg 
= (char *)"invalid distance too far back"; 
 565             Tracevv((stderr
, "inflate:         distance %u\n", state
->offset
)); 
 567             /* copy match from window to output */ 
 570                 copy 
= state
->wsize 
- state
->offset
; 
 576                     from 
= put 
- state
->offset
; 
 579                 if (copy 
> state
->length
) copy 
= state
->length
; 
 580                 state
->length 
-= copy
; 
 585             } while (state
->length 
!= 0); 
 589             /* inflate stream terminated properly -- write leftover output */ 
 591             if (left 
< state
->wsize
) { 
 592                 if (out(out_desc
, state
->window
, state
->wsize 
- left
)) 
 601         default:                /* can't happen, but makes compilers happy */ 
 602             ret 
= Z_STREAM_ERROR
; 
 606     /* Return unused input */ 
 608     strm
->next_in 
= next
; 
 609     strm
->avail_in 
= have
; 
 613 int ZEXPORT 
inflateBackEnd(strm
) 
 616     if (strm 
== Z_NULL 
|| strm
->state 
== Z_NULL 
|| strm
->zfree 
== (free_func
)0) 
 617         return Z_STREAM_ERROR
; 
 618     ZFREE(strm
, strm
->state
); 
 619     strm
->state 
= Z_NULL
; 
 620     Tracev((stderr
, "inflate: end\n"));