1
0
mirror of https://github.com/rkd77/elinks.git synced 2025-01-03 14:57:44 -05:00

bug 534: Fixed (?)

This commit is contained in:
Witold Filipczyk 2007-08-02 11:07:55 +02:00 committed by Witold Filipczyk
parent 4cccedabc9
commit b3845a7998

View File

@ -1010,14 +1010,19 @@ decompress_data(struct connection *conn, unsigned char *data, int len,
off_t *length_of_block; off_t *length_of_block;
unsigned char *output = NULL; unsigned char *output = NULL;
length_of_block = (http->length == LEN_CHUNKED ? &http->chunk_remaining
: &http->length);
#define BIG_READ 65536 #define BIG_READ 65536
if (http->length == LEN_CHUNKED) {
if (http->chunk_remaining == CHUNK_ZERO_SIZE)
state = FINISHING;
else
length_of_block = &http->chunk_remaining;
} else {
length_of_block = &http->length;
if (!*length_of_block) { if (!*length_of_block) {
/* Going to finish this decoding bussiness. */ /* Going to finish this decoding bussiness. */
state = FINISHING; state = FINISHING;
} }
}
if (conn->content_encoding == ENCODING_NONE) { if (conn->content_encoding == ENCODING_NONE) {
*new_len = len; *new_len = len;
@ -1221,8 +1226,8 @@ read_chunked_http_data(struct connection *conn, struct read_buffer *rb)
int len; int len;
int zero = (http->chunk_remaining == CHUNK_ZERO_SIZE); int zero = (http->chunk_remaining == CHUNK_ZERO_SIZE);
if (zero) http->chunk_remaining = 0; if (zero) len = 0;
len = http->chunk_remaining; else len = http->chunk_remaining;
if (http->chunk_remaining > INT_MAX) if (http->chunk_remaining > INT_MAX)
int_lower_bound(&len, rb->length); int_lower_bound(&len, rb->length);