wininet: Release gzip_buffer when opening new connection.
diff --git a/dlls/wininet/http.c b/dlls/wininet/http.c
index 5ae3e4d..b027af9 100644
--- a/dlls/wininet/http.c
+++ b/dlls/wininet/http.c
@@ -258,7 +258,7 @@
gzip_stream_t *gzip_stream;
int index, zres;
- gzip_stream = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(gzip_stream_t));
+ gzip_stream = heap_alloc_zero(sizeof(gzip_stream_t));
gzip_stream->zstream.zalloc = wininet_zalloc;
gzip_stream->zstream.zfree = wininet_zfree;
@@ -276,6 +276,14 @@
HTTP_DeleteCustomHeader(req, index);
}
+static void release_gzip_stream(http_request_t *req)
+{
+ if(!req->gzip_stream->end_of_data)
+ inflateEnd(&req->gzip_stream->zstream);
+ heap_free(req->gzip_stream);
+ req->gzip_stream = NULL;
+}
+
#else
static void init_gzip_stream(http_request_t *req)
@@ -283,6 +291,10 @@
ERR("gzip stream not supported, missing zlib.\n");
}
+static void release_gzip_stream(http_request_t *req)
+{
+}
+
#endif
/* set the request content length based on the headers */
@@ -1605,13 +1617,8 @@
HeapFree(GetProcessHeap(), 0, request->custHeaders[i].lpszValue);
}
-#ifdef HAVE_ZLIB
- if(request->gzip_stream) {
- if(!request->gzip_stream->end_of_data)
- inflateEnd(&request->gzip_stream->zstream);
- HeapFree(GetProcessHeap(), 0, request->gzip_stream);
- }
-#endif
+ if(request->gzip_stream)
+ release_gzip_stream(request);
HeapFree(GetProcessHeap(), 0, request->custHeaders);
}
@@ -4997,6 +5004,8 @@
lend:
request->read_pos = request->read_size = 0;
request->read_chunked = FALSE;
+ if(request->gzip_stream)
+ release_gzip_stream(request);
TRACE("%d <--\n", res);
return res;