Mercurial > hg > nginx-ranges
comparison src/http/modules/ngx_http_range_filter_module.c @ 126:df17fbafec8f NGINX_0_3_10
nginx 0.3.10
*) Change: the "valid_referers" directive and the "$invalid_referer"
variable were moved to the new ngx_http_referer_module from the
ngx_http_rewrite_module.
*) Change: the "$apache_bytes_sent" variable name was changed to
"$body_bytes_sent".
*) Feature: the "$sent_http_..." variables.
*) Feature: the "if" directive supports the "=" and "!=" operations.
*) Feature: the "proxy_pass" directive supports the HTTPS protocol.
*) Feature: the "proxy_set_body" directive.
*) Feature: the "post_action" directive.
*) Feature: the ngx_http_empty_gif_module.
*) Feature: the "worker_cpu_affinity" directive for Linux.
*) Bugfix: the "rewrite" directive did not unescape URI part in
redirect, now it is unescaped except the %00-%25 and %7F-%FF
characters.
*) Bugfix: nginx could not be built by the icc 9.0 compiler.
*) Bugfix: if the SSI was enabled for zero size static file, then the
chunked response was encoded incorrectly.
author | Igor Sysoev <http://sysoev.ru> |
---|---|
date | Tue, 15 Nov 2005 00:00:00 +0300 |
parents | f63280c59dd5 |
children | 82d695e3d662 |
comparison
equal
deleted
inserted
replaced
125:97504de1f89e | 126:df17fbafec8f |
---|---|
298 content_range->value.len = ngx_sprintf(content_range->value.data, | 298 content_range->value.len = ngx_sprintf(content_range->value.data, |
299 "bytes */%O", | 299 "bytes */%O", |
300 r->headers_out.content_length_n) | 300 r->headers_out.content_length_n) |
301 - content_range->value.data; | 301 - content_range->value.data; |
302 | 302 |
303 r->headers_out.content_length_n = -1; | 303 ngx_http_clear_content_length(r); |
304 if (r->headers_out.content_length) { | |
305 r->headers_out.content_length->key.len = 0; | |
306 r->headers_out.content_length = NULL; | |
307 } | |
308 | 304 |
309 return rc; | 305 return rc; |
310 } | 306 } |
311 | 307 |
312 r->headers_out.status = NGX_HTTP_PARTIAL_CONTENT; | 308 r->headers_out.status = NGX_HTTP_PARTIAL_CONTENT; |
348 | 344 |
349 ctx = ngx_pcalloc(r->pool, sizeof(ngx_http_range_filter_ctx_t)); | 345 ctx = ngx_pcalloc(r->pool, sizeof(ngx_http_range_filter_ctx_t)); |
350 if (ctx == NULL) { | 346 if (ctx == NULL) { |
351 return NGX_ERROR; | 347 return NGX_ERROR; |
352 } | 348 } |
353 | 349 |
354 ngx_http_set_ctx(r, ctx, ngx_http_range_body_filter_module); | 350 ngx_http_set_ctx(r, ctx, ngx_http_range_body_filter_module); |
355 | 351 |
356 | 352 |
357 len = sizeof(CRLF "--") - 1 + NGX_ATOMIC_T_LEN | 353 len = sizeof(CRLF "--") - 1 + NGX_ATOMIC_T_LEN |
358 + sizeof(CRLF "Content-Type: ") - 1 | 354 + sizeof(CRLF "Content-Type: ") - 1 |