Fix bug in gzclose() when gzwrite() runs out of memory.

If the deflateInit2() called for the first gzwrite() failed with a
Z_MEM_ERROR, then a subsequent gzclose() would try to free an
already freed pointer.  This fixes that.
pull/30/head
Mark Adler 12 years ago
parent 0cf495a1ca
commit c4888637ea
  1. 11
      gzwrite.c

@ -556,12 +556,13 @@ int ZEXPORT gzclose_w(file)
/* flush, free memory, and close file */ /* flush, free memory, and close file */
if (gz_comp(state, Z_FINISH) == -1) if (gz_comp(state, Z_FINISH) == -1)
ret = state->err; ret = state->err;
if (!state->direct) { if (state->size) {
(void)deflateEnd(&(state->strm)); if (!state->direct) {
free(state->out); (void)deflateEnd(&(state->strm));
} free(state->out);
if (state->size) }
free(state->in); free(state->in);
}
gz_error(state, Z_OK, NULL); gz_error(state, Z_OK, NULL);
free(state->path); free(state->path);
if (close(state->fd) == -1) if (close(state->fd) == -1)

Loading…
Cancel
Save