projects
/
silc.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Added SILC Thread Queue API
[silc.git]
/
lib
/
zlib
/
infblock.c
diff --git
a/lib/zlib/infblock.c
b/lib/zlib/infblock.c
index f4920faa5ea06bee242cbb36c51e47ae0c82f434..dd7a6d40a8da1714a03fcd0631cdcb8ae7bc091c 100644
(file)
--- a/
lib/zlib/infblock.c
+++ b/
lib/zlib/infblock.c
@@
-1,5
+1,5
@@
/* infblock.c -- interpret and process block types to last block
/* infblock.c -- interpret and process block types to last block
- * Copyright (C) 1995-
1998
Mark Adler
+ * Copyright (C) 1995-
2002
Mark Adler
* For conditions of distribution and use, see copyright notice in zlib.h
*/
* For conditions of distribution and use, see copyright notice in zlib.h
*/
@@
-249,10
+249,12
@@
int r;
&s->sub.trees.tb, s->hufts, z);
if (t != Z_OK)
{
&s->sub.trees.tb, s->hufts, z);
if (t != Z_OK)
{
- ZFREE(z, s->sub.trees.blens);
r = t;
if (r == Z_DATA_ERROR)
r = t;
if (r == Z_DATA_ERROR)
+ {
+ ZFREE(z, s->sub.trees.blens);
s->mode = BAD;
s->mode = BAD;
+ }
LEAVE
}
s->sub.trees.index = 0;
LEAVE
}
s->sub.trees.index = 0;
@@
-313,11
+315,13
@@
int r;
t = inflate_trees_dynamic(257 + (t & 0x1f), 1 + ((t >> 5) & 0x1f),
s->sub.trees.blens, &bl, &bd, &tl, &td,
s->hufts, z);
t = inflate_trees_dynamic(257 + (t & 0x1f), 1 + ((t >> 5) & 0x1f),
s->sub.trees.blens, &bl, &bd, &tl, &td,
s->hufts, z);
- ZFREE(z, s->sub.trees.blens);
if (t != Z_OK)
{
if (t == (uInt)Z_DATA_ERROR)
if (t != Z_OK)
{
if (t == (uInt)Z_DATA_ERROR)
+ {
+ ZFREE(z, s->sub.trees.blens);
s->mode = BAD;
s->mode = BAD;
+ }
r = t;
LEAVE
}
r = t;
LEAVE
}
@@
-329,6
+333,7
@@
int r;
}
s->sub.decode.codes = c;
}
}
s->sub.decode.codes = c;
}
+ ZFREE(z, s->sub.trees.blens);
s->mode = CODES;
case CODES:
UPDATE
s->mode = CODES;
case CODES:
UPDATE