]> git.kaiwu.me - nginx.git/commitdiff
Merge of r4471:
authorMaxim Dounin <mdounin@mdounin.ru>
Mon, 5 Mar 2012 12:36:51 +0000 (12:36 +0000)
committerMaxim Dounin <mdounin@mdounin.ru>
Mon, 5 Mar 2012 12:36:51 +0000 (12:36 +0000)
Variables: honor no_cacheable for not_found variables.

Variables with the "not_found" flag set follow the same rules as ones with
the "valid" flag set.  Make sure ngx_http_get_flushed_variable() will flush
non-cacheable variables with the "not_found" flag set.

This fixes at least one known problem with $args not available in a subrequest
(with args) when there were no args in the main request and $args variable was
queried in the main request (reported by Laurence Rowe aka elro on irc).

Also this eliminates unneeded call to ngx_http_get_indexed_variable() in
cacheable case (as it will return cached value anyway).

src/http/ngx_http_variables.c

index c936cc43d71aee5faf960d5d73e5b8a60e789942..a9eb0afb71902f6775ceabcc8a02502a9bdb0ec3 100644 (file)
@@ -428,7 +428,7 @@ ngx_http_get_flushed_variable(ngx_http_request_t *r, ngx_uint_t index)
 
     v = &r->variables[index];
 
-    if (v->valid) {
+    if (v->valid || v->not_found) {
         if (!v->no_cacheable) {
             return v;
         }