Ranges processing small optimization.
diff --git a/src/http/modules/ngx_http_range_filter_module.c b/src/http/modules/ngx_http_range_filter_module.c
index 6b45e2b..52e45ae 100644
--- a/src/http/modules/ngx_http_range_filter_module.c
+++ b/src/http/modules/ngx_http_range_filter_module.c
@@ -234,12 +234,13 @@
ngx_http_range_parse(ngx_http_request_t *r, ngx_http_range_filter_ctx_t *ctx)
{
u_char *p;
- off_t start, end, size;
+ off_t start, end, size, content_length;
ngx_uint_t suffix;
ngx_http_range_t *range;
p = r->headers_in.range->value.data + 6;
size = 0;
+ content_length = r->headers_out.content_length_n;
for ( ;; ) {
start = 0;
@@ -263,14 +264,14 @@
return NGX_HTTP_RANGE_NOT_SATISFIABLE;
}
- if (start >= r->headers_out.content_length_n) {
+ if (start >= content_length) {
goto skip;
}
while (*p == ' ') { p++; }
if (*p == ',' || *p == '\0') {
- end = r->headers_out.content_length_n;
+ end = content_length;
goto found;
}
@@ -294,16 +295,16 @@
}
if (suffix) {
- start = r->headers_out.content_length_n - end;
- end = r->headers_out.content_length_n - 1;
+ start = content_length - end;
+ end = content_length - 1;
}
if (start > end) {
goto skip;
}
- if (end >= r->headers_out.content_length_n) {
- end = r->headers_out.content_length_n;
+ if (end >= content_length) {
+ end = content_length;
} else {
end++;
@@ -332,7 +333,7 @@
return NGX_HTTP_RANGE_NOT_SATISFIABLE;
}
- if (size > r->headers_out.content_length_n) {
+ if (size > content_length) {
return NGX_DECLINED;
}