243{
246 unsigned char FAR *put;
249 unsigned bits;
250 unsigned copy;
251 unsigned char FAR *from;
254 unsigned len;
255 int ret;
256 static const unsigned short order[19] =
257 {16, 17, 18, 0, 8, 7, 9, 6, 10, 5, 11, 4, 12, 3, 13, 2, 14, 1, 15};
258
259
263
264
269 next = strm->next_in;
272 bits = 0;
275
276
277 for (;;)
278 switch (state->
mode) {
280
284 break;
285 }
290 case 0:
291 Tracev((stderr,
"inflate: stored block%s\n",
292 state->
last ?
" (last)" :
""));
294 break;
295 case 1:
297 Tracev((stderr,
"inflate: fixed codes block%s\n",
298 state->
last ?
" (last)" :
""));
300 break;
301 case 2:
302 Tracev((stderr,
"inflate: dynamic codes block%s\n",
303 state->
last ?
" (last)" :
""));
305 break;
306 case 3:
307 strm->msg = (char *)"invalid block type";
309 }
311 break;
312
314
317 if ((
hold & 0xffff) != ((
hold >> 16) ^ 0xffff)) {
318 strm->msg = (char *)"invalid stored block lengths";
320 break;
321 }
323 Tracev((stderr,
"inflate: stored length %u\n",
326
327
328 while (state->
length != 0) {
333 if (copy > left) copy = left;
337 left -= copy;
338 put += copy;
340 }
341 Tracev((stderr,
"inflate: stored end\n"));
343 break;
344
346
354#ifndef PKZIP_BUG_WORKAROUND
355 if (state->
nlen > 286 || state->
ndist > 30) {
356 strm->msg = (char *)"too many length or distance symbols";
358 break;
359 }
360#endif
361 Tracev((stderr,
"inflate: table sizes ok\n"));
362
363
367 state->
lens[order[state->
have++]] = (
unsigned short)
BITS(3);
369 }
370 while (state->
have < 19)
371 state->
lens[order[state->
have++]] = 0;
377 if (ret) {
378 strm->msg = (char *)"invalid code lengths set";
380 break;
381 }
382 Tracev((stderr,
"inflate: code lengths ok\n"));
383
384
387 for (;;) {
389 if ((
unsigned)(here.
bits) <= bits)
break;
391 }
396 }
397 else {
398 if (here.
val == 16) {
401 if (state->
have == 0) {
402 strm->msg = (char *)"invalid bit length repeat";
404 break;
405 }
406 len = (unsigned)(state->
lens[state->
have - 1]);
409 }
410 else if (here.
val == 17) {
413 len = 0;
416 }
417 else {
420 len = 0;
423 }
425 strm->msg = (char *)"invalid bit length repeat";
427 break;
428 }
429 while (copy--)
430 state->
lens[state->
have++] = (
unsigned short)len;
431 }
432 }
433
434
436
437
438 if (state->
lens[256] == 0) {
439 strm->msg = (char *)"invalid code -- missing end-of-block";
441 break;
442 }
443
444
445
446
452 if (ret) {
453 strm->msg = (char *)"invalid literal/lengths set";
455 break;
456 }
461 if (ret) {
462 strm->msg = (char *)"invalid distances set";
464 break;
465 }
466 Tracev((stderr,
"inflate: codes ok\n"));
468
470
471 if (
have >= 6 && left >= 258) {
477 break;
478 }
479
480
481 for (;;) {
483 if ((
unsigned)(here.
bits) <= bits)
break;
485 }
486 if (here.
op && (here.
op & 0xf0) == 0) {
488 for (;;) {
491 if ((
unsigned)(
last.bits + here.
bits) <= bits)
break;
493 }
495 }
498
499
502 "inflate: literal '%c'\n" :
503 "inflate: literal 0x%02x\n", here.
val));
505 *put++ = (
unsigned char)(state->
length);
506 left--;
508 break;
509 }
510
511
513 Tracevv((stderr,
"inflate: end of block\n"));
515 break;
516 }
517
518
520 strm->msg = (char *)"invalid literal/length code";
522 break;
523 }
524
525
526 state->
extra = (unsigned)(here.
op) & 15;
527 if (state->
extra != 0) {
531 }
533
534
535 for (;;) {
537 if ((
unsigned)(here.
bits) <= bits)
break;
539 }
540 if ((here.
op & 0xf0) == 0) {
542 for (;;) {
545 if ((
unsigned)(
last.bits + here.
bits) <= bits)
break;
547 }
549 }
552 strm->msg = (char *)"invalid distance code";
554 break;
555 }
557
558
559 state->
extra = (unsigned)(here.
op) & 15;
560 if (state->
extra != 0) {
564 }
566 left : 0)) {
567 strm->msg = (char *)"invalid distance too far back";
569 break;
570 }
572
573
574 do {
577 if (copy < left) {
578 from = put + copy;
579 copy = left - copy;
580 }
581 else {
582 from = put - state->
offset;
583 copy = left;
584 }
587 left -= copy;
588 do {
589 *put++ = *from++;
590 } while (--copy);
591 }
while (state->
length != 0);
592 break;
593
595
597 if (left < state->
wsize) {
598 if (out(out_desc, state->
window, state->
wsize - left))
600 }
601 goto inf_leave;
602
605 goto inf_leave;
606
607 default:
609 goto inf_leave;
610 }
611
612
613 inf_leave:
614 strm->next_in =
next;
615 strm->avail_in =
have;
616 return ret;
617}
local void fixedtables(struct inflate_state FAR *state)
void ZLIB_INTERNAL inflate_fast(z_streamp strm, unsigned start)
code const FAR * distcode
unsigned char FAR * window
void ZLIB_INTERNAL zmemcpy(Bytef *dest, const Bytef *source, uInt len)