Mercurial > hg > nginx-vendor-1-0
annotate src/os/unix/ngx_time.c @ 644:ad25218fd14b NGINX_1_0_12
nginx 1.0.12
*) Feature: the "TLSv1.1" and "TLSv1.2" parameters of the
"ssl_protocols" directive.
*) Feature: the "if" SSI command supports captures in regular
expressions.
*) Bugfix: the "if" SSI command did not work inside the "block" command.
*) Bugfix: in AIO error handling on FreeBSD.
*) Bugfix: in the OpenSSL library initialization.
*) Bugfix: the "worker_cpu_affinity" directive might not work.
*) Bugfix: the "limit_conn_log_level" and "limit_req_log_level"
directives might not work.
*) Bugfix: the "read_ahead" directive might not work combined with
"try_files" and "open_file_cache".
*) Bugfix: the "proxy_cache_use_stale" directive with "error" parameter
did not return answer from cache if there were no live upstreams.
*) Bugfix: a segmentation fault might occur in a worker process if small
time was used in the "inactive" parameter of the "proxy_cache_path"
directive.
*) Bugfix: responses from cache might hang.
*) Bugfix: in error handling while connecting to a backend.
Thanks to Piotr Sikora.
*) Bugfix: in the "epoll" event method.
Thanks to Yichun Zhang.
*) Bugfix: the $sent_http_cache_control variable might contain a wrong
value if the "expires" directive was used.
Thanks to Yichun Zhang.
*) Bugfix: the "limit_rate" directive did not allow to use full
throughput, even if limit value was very high.
*) Bugfix: the "sendfile_max_chunk" directive did not work, if the
"limit_rate" directive was used.
*) Bugfix: nginx could not be built on Solaris; the bug had appeared in
1.0.11.
*) Bugfix: in the ngx_http_scgi_module.
*) Bugfix: in the ngx_http_mp4_module.
author | Igor Sysoev <http://sysoev.ru> |
---|---|
date | Mon, 06 Feb 2012 00:00:00 +0400 |
parents | a094317ba307 |
children |
rev | line source |
---|---|
0 | 1 |
2 /* | |
3 * Copyright (C) Igor Sysoev | |
644 | 4 * Copyright (C) Nginx, Inc. |
0 | 5 */ |
6 | |
7 | |
8 #include <ngx_config.h> | |
9 #include <ngx_core.h> | |
10 | |
11 | |
404 | 12 /* |
13 * FreeBSD does not test /etc/localtime change, however, we can workaround it | |
14 * by calling tzset() with TZ and then without TZ to update timezone. | |
15 * The trick should work since FreeBSD 2.1.0. | |
16 * | |
17 * Linux does not test /etc/localtime change in localtime(), | |
18 * but may stat("/etc/localtime") several times in every strftime(), | |
19 * therefore we use it to update timezone. | |
20 * | |
21 * Solaris does not test /etc/TIMEZONE change too and no workaround available. | |
22 */ | |
23 | |
24 void | |
25 ngx_timezone_update(void) | |
26 { | |
27 #if (NGX_FREEBSD) | |
28 | |
29 if (getenv("TZ")) { | |
30 return; | |
31 } | |
32 | |
33 putenv("TZ=UTC"); | |
34 | |
35 tzset(); | |
36 | |
37 unsetenv("TZ"); | |
38 | |
39 tzset(); | |
40 | |
41 #elif (NGX_LINUX) | |
42 time_t s; | |
43 struct tm *t; | |
44 char buf[4]; | |
45 | |
46 s = time(0); | |
47 | |
48 t = localtime(&s); | |
49 | |
50 strftime(buf, 4, "%H", t); | |
51 | |
52 #endif | |
53 } | |
54 | |
55 | |
112 | 56 void |
57 ngx_localtime(time_t s, ngx_tm_t *tm) | |
0 | 58 { |
18 | 59 #if (NGX_HAVE_LOCALTIME_R) |
112 | 60 (void) localtime_r(&s, tm); |
0 | 61 |
62 #else | |
63 ngx_tm_t *t; | |
64 | |
112 | 65 t = localtime(&s); |
0 | 66 *tm = *t; |
67 | |
68 #endif | |
69 | |
70 tm->ngx_tm_mon++; | |
71 tm->ngx_tm_year += 1900; | |
72 } | |
58 | 73 |
74 | |
112 | 75 void |
76 ngx_libc_localtime(time_t s, struct tm *tm) | |
58 | 77 { |
78 #if (NGX_HAVE_LOCALTIME_R) | |
112 | 79 (void) localtime_r(&s, tm); |
58 | 80 |
81 #else | |
82 struct tm *t; | |
83 | |
112 | 84 t = localtime(&s); |
58 | 85 *tm = *t; |
86 | |
87 #endif | |
88 } | |
89 | |
90 | |
112 | 91 void |
92 ngx_libc_gmtime(time_t s, struct tm *tm) | |
58 | 93 { |
94 #if (NGX_HAVE_LOCALTIME_R) | |
112 | 95 (void) gmtime_r(&s, tm); |
58 | 96 |
97 #else | |
98 struct tm *t; | |
99 | |
112 | 100 t = gmtime(&s); |
58 | 101 *tm = *t; |
102 | |
103 #endif | |
104 } |