wininet: Make sure to not read over chunk end in read_gzip_data.

This commit is contained in:
Jacek Caban 2009-12-17 00:02:47 +01:00 committed by Alexandre Julliard
parent 6d8c4572ef
commit 78b2cedaa6
1 changed files with 6 additions and 3 deletions
dlls/wininet

View File

@ -1952,6 +1952,7 @@ static DWORD read_gzip_data(http_request_t *req, BYTE *buf, int size, BOOL sync,
#ifdef HAVE_ZLIB #ifdef HAVE_ZLIB
z_stream *zstream = &req->gzip_stream->zstream; z_stream *zstream = &req->gzip_stream->zstream;
DWORD buf_avail;
int zres; int zres;
while(read < size && !req->gzip_stream->end_of_data) { while(read < size && !req->gzip_stream->end_of_data) {
@ -1960,14 +1961,16 @@ static DWORD read_gzip_data(http_request_t *req, BYTE *buf, int size, BOOL sync,
break; break;
} }
buf_avail = req->dwContentLength == ~0 ? req->read_size : min(req->read_size, req->dwContentLength-req->dwContentRead);
zstream->next_in = req->read_buf+req->read_pos; zstream->next_in = req->read_buf+req->read_pos;
zstream->avail_in = req->read_size; zstream->avail_in = buf_avail;
zstream->next_out = buf+read; zstream->next_out = buf+read;
zstream->avail_out = size-read; zstream->avail_out = size-read;
zres = inflate(zstream, Z_FULL_FLUSH); zres = inflate(zstream, Z_FULL_FLUSH);
read = size - zstream->avail_out; read = size - zstream->avail_out;
req->dwContentRead += req->read_size-zstream->avail_in; req->dwContentRead += buf_avail-zstream->avail_in;
remove_data(req, req->read_size-zstream->avail_in); remove_data(req, buf_avail-zstream->avail_in);
if(zres == Z_STREAM_END) { if(zres == Z_STREAM_END) {
TRACE("end of data\n"); TRACE("end of data\n");
req->gzip_stream->end_of_data = TRUE; req->gzip_stream->end_of_data = TRUE;