X-Git-Url: https://mattmccutchen.net/rsync/rsync.git/blobdiff_plain/d4286ec49d07820feb4ac2b7fa6d8276585626e7..18b72cc8294b4b07bf1373154d2effc35eb10343:/zlib/infblock.c diff --git a/zlib/infblock.c b/zlib/infblock.c index f8940c7f..58f0628c 100644 --- a/zlib/infblock.c +++ b/zlib/infblock.c @@ -176,7 +176,7 @@ int r; break; case 3: /* illegal */ DUMPBITS(3) - s->mode = BAD; + s->mode = zBAD; z->msg = (char*)"invalid block type"; r = Z_DATA_ERROR; LEAVE @@ -186,7 +186,7 @@ int r; NEEDBITS(32) if ((((~b) >> 16) & 0xffff) != (b & 0xffff)) { - s->mode = BAD; + s->mode = zBAD; z->msg = (char*)"invalid stored block lengths"; r = Z_DATA_ERROR; LEAVE @@ -219,7 +219,7 @@ int r; #ifndef PKZIP_BUG_WORKAROUND if ((t & 0x1f) > 29 || ((t >> 5) & 0x1f) > 29) { - s->mode = BAD; + s->mode = zBAD; z->msg = (char*)"too many length or distance symbols"; r = Z_DATA_ERROR; LEAVE @@ -249,10 +249,12 @@ int r; &s->sub.trees.tb, s->hufts, z); if (t != Z_OK) { - ZFREE(z, s->sub.trees.blens); r = t; if (r == Z_DATA_ERROR) - s->mode = BAD; + { + ZFREE(z, s->sub.trees.blens); + s->mode = zBAD; + } LEAVE } s->sub.trees.index = 0; @@ -289,7 +291,7 @@ int r; (c == 16 && i < 1)) { ZFREE(z, s->sub.trees.blens); - s->mode = BAD; + s->mode = zBAD; z->msg = (char*)"invalid bit length repeat"; r = Z_DATA_ERROR; LEAVE @@ -317,10 +319,14 @@ int r; if (t != Z_OK) { if (t == (uInt)Z_DATA_ERROR) - s->mode = BAD; + { + ZFREE(z, s->sub.trees.blens); + s->mode = zBAD; + } r = t; LEAVE } + ZFREE(z, s->sub.trees.blens); Tracev((stderr, "inflate: trees ok\n")); if ((c = inflate_codes_new(bl, bd, tl, td, z)) == Z_NULL) { @@ -345,13 +351,6 @@ int r; s->mode = TYPE; break; } - if (k > 7) /* return unused byte, if any */ - { - Assert(k < 16, "inflate_codes grabbed too many bytes") - k -= 8; - n++; - p--; /* can always return one */ - } s->mode = DRY; case DRY: FLUSH @@ -361,7 +360,7 @@ int r; case DONE: r = Z_STREAM_END; LEAVE - case BAD: + case zBAD: r = Z_DATA_ERROR; LEAVE default: