comparison src/http/ngx_http_script.c @ 479:c52408583801 release-0.1.14

nginx-0.1.14-RELEASE import *) Feature: the autoconfiguration directives: --http-client-body-temp-path=PATH, --http-proxy-temp-path=PATH, and --http-fastcgi-temp-path=PATH *) Change: the directory name for the temporary files with the client request body is specified by directive client_body_temp_path, by default it is <prefix>/client_body_temp. *) Feature: the ngx_http_fastcgi_module and the directives: fastcgi_pass, fastcgi_root, fastcgi_index, fastcgi_params, fastcgi_connect_timeout, fastcgi_send_timeout, fastcgi_read_timeout, fastcgi_send_lowat, fastcgi_header_buffer_size, fastcgi_buffers, fastcgi_busy_buffers_size, fastcgi_temp_path, fastcgi_max_temp_file_size, fastcgi_temp_file_write_size, fastcgi_next_upstream, and fastcgi_x_powered_by. *) Bugfix: the "[alert] zero size buf" error; the bug had appeared in 0.1.3. *) Change: the URI must be specified after the host name in the proxy_pass directive. *) Change: the %3F symbol in the URI was considered as the argument string start. *) Feature: the unix domain sockets support in the ngx_http_proxy_module. *) Feature: the ssl_engine and ssl_ciphers directives. Thanks to Sergey Skvortsov for SSL-accelerator.
author Igor Sysoev <igor@sysoev.ru>
date Tue, 18 Jan 2005 13:03:58 +0000
parents a88a3e4e158f
children cd3117ad9aab
comparison
equal deleted inserted replaced
478:e6576f690993 479:c52408583801
7 #include <ngx_config.h> 7 #include <ngx_config.h>
8 #include <ngx_core.h> 8 #include <ngx_core.h>
9 #include <ngx_http.h> 9 #include <ngx_http.h>
10 10
11 11
12 char *ngx_http_script_copy(ngx_http_request_t *r, 12 u_char *ngx_http_script_copy(ngx_http_request_t *r, u_char *buf, void *data)
13 ngx_http_script_code_t *code,
14 char *p, size_t len)
15 { 13 {
16 return ngx_cpymem(p, code->offset, code->len < len ? code->len : len); 14 u_char **p = data;
15
16 ngx_http_script_code_t *code;
17
18 code = (ngx_http_script_code_t *)
19 ((char *) data - sizeof(ngx_http_script_code_t));
20
21 return ngx_cpymem(buf, *p, code->data_len);
17 } 22 }
18 23
19 24
20 char *ngx_http_script_header_in(ngx_http_request_t *r, 25 u_char *ngx_http_script_header_in(ngx_http_request_t *r,
21 ngx_http_script_code_t *code, 26 u_char *buf, void *data)
22 char *p, size_t len)
23 { 27 {
24 ngx_str_t *s; 28 size_t *offset = data;
25 29
26 s = (ngx_str_t *) (((char *) r->headers_in) + code->offset); 30 ngx_table_elt_t *h;
27 31
28 return ngx_cpymem(p, s->data, s->len < len ? s->len : len); 32 h = *(ngx_table_elt_t **) (((char *) r->headers_in) + *offset);
33
34 return ngx_cpymem(p, h->value.data, h->value.len);
29 } 35 }
30 36
31 37
32 /* the log script codes */ 38 u_char *ngx_http_script_request_line(ngx_http_request_t *r,
33 39 u_char *buf, void *data)
34 char *ngx_http_script_request_line(ngx_http_request_t *r, char *p, size_t len)
35 { 40 {
36 return ngx_cpymem(p, r->request_line.data, 41 return ngx_cpymem(p, r->request_line.data, r->request_line.len);
37 r->request_line.len < len ? r->request_line.len : len);
38 } 42 }
39 43
40 44
41 char *ngx_http_script_status(ngx_http_request_t *r, char *p, size_t len) 45 u_char *ngx_http_script_status(ngx_http_request_t *r, u_char *buf, void *data)
42 { 46 {
43 return ngx_snprintf(p, len, "%d", r->headers_out.status); 47 return ngx_sprintf(buf, "%ui", r->headers_out.status);
44 } 48 }
45 49
46 50
47 char *ngx_http_script_sent(ngx_http_request_t *r, char *p, size_t len) 51 u_char *ngx_http_script_sent(ngx_http_request_t *r, u_char *buf, void *data)
48 { 52 {
49 return ngx_sprintf(p, "%O", r->connection->sent); 53 return ngx_sprintf(buf, "%O", r->connection->sent);
50 } 54 }