Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nginx/nginx.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIgor Sysoev <igor@sysoev.ru>2003-03-12 20:32:22 +0300
committerIgor Sysoev <igor@sysoev.ru>2003-03-12 20:32:22 +0300
commit90ace68b69606b885578686e19d499a50d5e80b7 (patch)
tree1229bcd0f438fa87bd6f3c08535e4e80bc02ff4d
parentb738757f359a79b346bcc40895ed0a5ca697e8e2 (diff)
nginx-0.0.1-2003-03-12-20:32:22 import
-rw-r--r--src/http/ngx_http_event.c8
-rw-r--r--src/http/ngx_http_special_response.c25
2 files changed, 24 insertions, 9 deletions
diff --git a/src/http/ngx_http_event.c b/src/http/ngx_http_event.c
index fa17f7248..efeacf83d 100644
--- a/src/http/ngx_http_event.c
+++ b/src/http/ngx_http_event.c
@@ -166,7 +166,7 @@ static int ngx_http_init_request(ngx_event_t *ev)
r->header_in = c->buffer;
ngx_test_null(r->pool, ngx_create_pool(ngx_http_request_pool_size, ev->log),
- ngx_http_close_request(r));
+ NGX_ERROR);
ngx_test_null(r->ctx,
ngx_pcalloc(r->pool, sizeof(void *) * ngx_http_max_module),
@@ -935,8 +935,9 @@ static int ngx_http_keepalive_handler(ngx_event_t *ev)
ngx_log_debug(ev->log, "http keepalive handler");
- if (ev->timedout)
+ if (ev->timedout) {
return NGX_DONE;
+ }
/* MSIE closes keepalive connection with RST flag
so we ignore ECONNRESET here */
@@ -946,8 +947,9 @@ static int ngx_http_keepalive_handler(ngx_event_t *ev)
n = ngx_event_recv(c, c->buffer->last, c->buffer->end - c->buffer->last);
ev->ignore_econnreset = 0;
- if (n == NGX_AGAIN || n == NGX_ERROR)
+ if (n == NGX_AGAIN || n == NGX_ERROR) {
return n;
+ }
ctx = (ngx_http_log_ctx_t *) ev->log->data;
ev->log->handler = NULL;
diff --git a/src/http/ngx_http_special_response.c b/src/http/ngx_http_special_response.c
index aa55de036..6bf62b3f7 100644
--- a/src/http/ngx_http_special_response.c
+++ b/src/http/ngx_http_special_response.c
@@ -76,6 +76,8 @@ static ngx_str_t error_pages[] = {
{ 0, NULL}, /* 412 */
{ 0, NULL}, /* 413 */
{ sizeof(error_414_page) - 1, error_414_page },
+ { 0, NULL}, /* 415 */
+ { 0, NULL}, /* 416 */
{ sizeof(error_500_page) - 1, error_500_page }
};
@@ -90,20 +92,31 @@ int ngx_http_special_response(ngx_http_request_t *r, int error)
r->headers_out.status = error;
- if (error < NGX_HTTP_BAD_REQUEST)
+ if (error < NGX_HTTP_BAD_REQUEST) {
err = error - NGX_HTTP_MOVED_PERMANENTLY;
- else if (error < NGX_HTTP_INTERNAL_SERVER_ERROR)
+ } else if (error < NGX_HTTP_INTERNAL_SERVER_ERROR) {
err = error - NGX_HTTP_BAD_REQUEST + 4;
- else
- err = error - NGX_HTTP_INTERNAL_SERVER_ERROR + 4 + 15;
+ } else {
+ err = error - NGX_HTTP_INTERNAL_SERVER_ERROR + 4 + 17;
+ }
+
+ if (r->keepalive != 0) {
+ switch (error) {
+ case NGX_HTTP_BAD_REQUEST:
+ case NGX_HTTP_REQUEST_URI_TOO_LARGE:
+ case NGX_HTTP_INTERNAL_SERVER_ERROR:
+ r->keepalive = 0;
+ }
+ }
- if (error_pages[err].len == 0)
+ if (error_pages[err].len == 0) {
r->headers_out.content_length = -1;
- else
+ } else {
r->headers_out.content_length = error_pages[err].len
+ len + sizeof(error_tail);
+ }
if (ngx_http_send_header(r) == NGX_ERROR) {
return NGX_ERROR;