Mercurial > hg > nginx
diff src/http/modules/ngx_http_range_filter.c @ 117:f6e3c5d019b6
nginx-0.0.1-2003-07-11-19:17:50 import
author | Igor Sysoev <igor@sysoev.ru> |
---|---|
date | Fri, 11 Jul 2003 15:17:50 +0000 |
parents | d7f606e25b99 |
children | b27548f540ad |
line wrap: on
line diff
--- a/src/http/modules/ngx_http_range_filter.c +++ b/src/http/modules/ngx_http_range_filter.c @@ -43,6 +43,7 @@ static int ngx_http_range_header_filter( int rc, boundary, len, i; char *p; off_t start, end; + ngx_table_elt_t *accept_ranges; ngx_http_range_t *range; ngx_http_range_filter_ctx_t *ctx; @@ -51,11 +52,24 @@ static int ngx_http_range_header_filter( || r->headers_out.status != NGX_HTTP_OK || r->headers_out.content_length == -1 /* STUB: we currently support ranges for file hunks only */ - || r->filter & NGX_HTTP_FILTER_NEED_IN_MEMORY - || r->headers_in.range == NULL + || r->filter & NGX_HTTP_FILTER_NEED_IN_MEMORY) + { + return next_header_filter(r); + } + + if (r->headers_in.range == NULL || r->headers_in.range->value.len < 7 || ngx_strncasecmp(r->headers_in.range->value.data, "bytes=", 6) != 0) { + ngx_test_null(accept_ranges, + ngx_push_table(r->headers_out.headers), + NGX_ERROR); + + accept_ranges->key.len = sizeof("Accept-Ranges") - 1; + accept_ranges->key.data = "Accept-Ranges"; + accept_ranges->value.len = sizeof("bytes") - 1; + accept_ranges->value.data = "bytes"; + return next_header_filter(r); }