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:
commit
c73e4e8d65
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user