diff options
author | Igor Sysoev <igor@sysoev.ru> | 2005-03-19 12:38:37 +0000 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2005-03-19 12:38:37 +0000 |
commit | c15717285d2157a603bb1b130b26d7baa549be7e (patch) | |
tree | 56dc8346b22bb2660eecd3bc086d263ac6d67326 /src/http/ngx_http_variables.h | |
parent | e12fbfe82a176cd386cdcecfeabf43ac8fd870a4 (diff) | |
download | nginx-release-0.1.25.tar.gz nginx-release-0.1.25.zip |
nginx-0.1.25-RELEASE importrelease-0.1.25
*) Bugfix: nginx did run on Linux parisc.
*) Feature: nginx now does not start under FreeBSD if the sysctl
kern.ipc.somaxconn value is too big.
*) Bugfix: if a request was internally redirected by the
ngx_http_index_module module to the ngx_http_proxy_module or
ngx_http_fastcgi_module modules, then the index file was not closed
after request completion.
*) Feature: the "proxy_pass" can be used in location with regular
expression.
*) Feature: the ngx_http_rewrite_filter_module module supports the
condition like "if ($HTTP_USER_AGENT ~ MSIE)".
*) Bugfix: nginx started too slow if the large number of addresses and
text values were used in the "geo" directive.
*) Change: a variable name must be declared as "$name" in the "geo"
directive. The previous variant without "$" is still supported, but
will be removed soon.
*) Feature: the "%{VARIABLE}v" logging parameter.
*) Feature: the "set $name value" directive.
*) Bugfix: gcc 4.0 compatibility.
*) Feature: the --with-openssl-opt=OPTIONS autoconfiguration directive.
Diffstat (limited to 'src/http/ngx_http_variables.h')
-rw-r--r-- | src/http/ngx_http_variables.h | 30 |
1 files changed, 13 insertions, 17 deletions
diff --git a/src/http/ngx_http_variables.h b/src/http/ngx_http_variables.h index c7ccdc12e..bf80386cb 100644 --- a/src/http/ngx_http_variables.h +++ b/src/http/ngx_http_variables.h @@ -17,45 +17,41 @@ #define NGX_HTTP_VARIABLE_NOT_FOUND (ngx_http_variable_value_t *) -1 -typedef struct { +struct ngx_http_variable_value_s { ngx_uint_t value; ngx_str_t text; -} ngx_http_variable_value_t; - +}; typedef struct ngx_http_variable_s ngx_http_variable_t; typedef ngx_http_variable_value_t * - (*ngx_http_get_variable_pt) (ngx_http_request_t *r, void *var); + (*ngx_http_get_variable_pt) (ngx_http_request_t *r, uintptr_t data); struct ngx_http_variable_s { - ngx_str_t name; - ngx_uint_t index; - ngx_http_get_variable_pt handler; - void *data; - ngx_uint_t uses; + ngx_str_t name; + ngx_uint_t index; + ngx_http_get_variable_pt handler; + uintptr_t data; }; -typedef ngx_http_variable_value_t * - (*ngx_http_get_core_variable_pt) (ngx_http_request_t *r, uintptr_t data); - typedef struct { - ngx_str_t name; - ngx_http_get_core_variable_pt handler; - uintptr_t data; + ngx_str_t name; + ngx_http_get_variable_pt handler; + uintptr_t data; } ngx_http_core_variable_t; -ngx_http_variable_t *ngx_http_add_variable(ngx_conf_t *cf); +ngx_http_variable_t *ngx_http_add_variable(ngx_conf_t *cf, ngx_str_t *name, + ngx_uint_t set); ngx_int_t ngx_http_get_variable_index(ngx_http_core_main_conf_t *cmcf, ngx_str_t *name); ngx_http_variable_value_t *ngx_http_get_indexed_variable(ngx_http_request_t *r, ngx_uint_t index); ngx_http_variable_value_t *ngx_http_get_variable(ngx_http_request_t *r, ngx_str_t *name); -ngx_int_t ngx_http_core_variables_init(ngx_cycle_t *cycle); +ngx_int_t ngx_http_variables_init(ngx_cycle_t *cycle); #endif /* _NGX_HTTP_VARIABLES_H_INCLUDED_ */ |