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

Merge with git+ssh://pasky.or.cz/srv/git/elinks.git

This commit is contained in:
Witold Filipczyk 2006-11-05 15:48:45 +01:00 committed by Witold Filipczyk
commit c73e4e8d65
4 changed files with 426 additions and 390 deletions

778
po/fr.po

File diff suppressed because it is too large Load Diff

View File

@ -308,8 +308,8 @@ ecmascript_timeout_handler(void *i)
{ {
struct ecmascript_interpreter *interpreter = i; struct ecmascript_interpreter *interpreter = i;
assert(interpreter->vs->doc_view->document); assertm(interpreter->vs->doc_view, "setTimeout: vs with no document (e_f %d)", interpreter->vs->ecmascript_fragile);
kill_timer(&interpreter->vs->doc_view->document->timeout); interpreter->vs->doc_view->document->timeout = TIMER_ID_UNDEF;
ecmascript_eval(interpreter, &interpreter->code, NULL); ecmascript_eval(interpreter, &interpreter->code, NULL);
} }
@ -323,6 +323,7 @@ ecmascript_set_timeout(struct ecmascript_interpreter *interpreter, unsigned char
init_string(&interpreter->code); init_string(&interpreter->code);
add_to_string(&interpreter->code, code); add_to_string(&interpreter->code, code);
mem_free(code); mem_free(code);
kill_timer(&interpreter->vs->doc_view->document->timeout);
install_timer(&interpreter->vs->doc_view->document->timeout, timeout, ecmascript_timeout_handler, interpreter); install_timer(&interpreter->vs->doc_view->document->timeout, timeout, ecmascript_timeout_handler, interpreter);
} }

View File

@ -33,6 +33,7 @@ gzip_open(struct stream_encoded *stream, int fd)
static int static int
gzip_read(struct stream_encoded *stream, unsigned char *data, int len) gzip_read(struct stream_encoded *stream, unsigned char *data, int len)
{ {
gzclearerr((gzFile *) stream->data);
return gzread((gzFile *) stream->data, data, len); return gzread((gzFile *) stream->data, data, len);
} }

View File

@ -960,7 +960,8 @@ decompress_data(struct connection *conn, unsigned char *data, int len,
* causes further malfunction of zlib :[ ... so we will make sure that * causes further malfunction of zlib :[ ... so we will make sure that
* we will always have at least PIPE_BUF / 2 + 1 in the pipe (returning * we will always have at least PIPE_BUF / 2 + 1 in the pipe (returning
* early otherwise)). */ * early otherwise)). */
int to_read = PIPE_BUF / 2, did_read = 0; enum { NORMAL, FINISHING } state = NORMAL;
int did_read = 0;
int *length_of_block; int *length_of_block;
unsigned char *output = NULL; unsigned char *output = NULL;
@ -970,9 +971,7 @@ decompress_data(struct connection *conn, unsigned char *data, int len,
#define BIG_READ 65536 #define BIG_READ 65536
if (!*length_of_block) { if (!*length_of_block) {
/* Going to finish this decoding bussiness. */ /* Going to finish this decoding bussiness. */
/* Some nicely big value - empty encoded output queue by reading state = FINISHING;
* big chunks from it. */
to_read = BIG_READ;
} }
if (conn->content_encoding == ENCODING_NONE) { if (conn->content_encoding == ENCODING_NONE) {
@ -991,11 +990,14 @@ decompress_data(struct connection *conn, unsigned char *data, int len,
} }
do { do {
int init = 0; int to_read;
if (to_read == PIPE_BUF / 2) { if (state == NORMAL) {
/* ... we aren't finishing yet. */ /* ... we aren't finishing yet. */
int written = safe_write(conn->stream_pipes[1], data, int written;
to_read = PIPE_BUF / 2;
written = safe_write(conn->stream_pipes[1], data,
len > to_read ? to_read : len); len > to_read ? to_read : len);
if (written > 0) { if (written > 0) {
@ -1009,7 +1011,7 @@ decompress_data(struct connection *conn, unsigned char *data, int len,
* non-keep-alive and chunked */ * non-keep-alive and chunked */
if (!http->length) { if (!http->length) {
/* That's all, folks - let's finish this. */ /* That's all, folks - let's finish this. */
to_read = BIG_READ; state = FINISHING;
} else if (!len) { } else if (!len) {
/* We've done for this round (but not done /* We've done for this round (but not done
* completely). Thus we will get out with * completely). Thus we will get out with
@ -1022,6 +1024,11 @@ decompress_data(struct connection *conn, unsigned char *data, int len,
return output; return output;
} }
} }
} else {
/* state is FINISHING. Set to_read to some nice, big
* value to empty the encoded output queue by reading
* big chunks from it. */
to_read = BIG_READ;
} }
if (!conn->stream) { if (!conn->stream) {
@ -1030,14 +1037,17 @@ decompress_data(struct connection *conn, unsigned char *data, int len,
if (!conn->stream) return NULL; if (!conn->stream) return NULL;
/* On "startup" pipe is treated with care, but if everything /* On "startup" pipe is treated with care, but if everything
* was already written to the pipe, caution isn't necessary */ * was already written to the pipe, caution isn't necessary */
else if (to_read != BIG_READ) init = 1; if (state != FINISHING) {
} else init = 0; /* on init don't read too much */
to_read = PIPE_BUF / 32;
}
}
output = (unsigned char *) mem_realloc(output, *new_len + to_read); output = (unsigned char *) mem_realloc(output, *new_len + to_read);
if (!output) break; if (!output) break;
did_read = read_encoded(conn->stream, output + *new_len, did_read = read_encoded(conn->stream, output + *new_len,
init ? PIPE_BUF / 32 : to_read); /* on init don't read too much */ to_read);
if (did_read > 0) *new_len += did_read; if (did_read > 0) *new_len += did_read;
else if (did_read == -1) { else if (did_read == -1) {
mem_free_set(&output, NULL); mem_free_set(&output, NULL);