annotate src/os/unix/ngx_time.c @ 660:d0f7a625f27c NGINX_1_1_14

nginx 1.1.14 *) Feature: multiple "limit_req" limits may be used simultaneously. *) Bugfix: in error handling while connecting to a backend. Thanks to Piotr Sikora. *) Bugfix: in AIO error handling on FreeBSD. *) Bugfix: in the OpenSSL library initialization. *) Bugfix: the "proxy_redirect" directives might not be correctly inherited. *) Bugfix: memory leak during reconfiguration if the "pcre_jit" directive was used.
author Igor Sysoev <http://sysoev.ru>
date Mon, 30 Jan 2012 00:00:00 +0400
parents a094317ba307
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 /*
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
3 * Copyright (C) Igor Sysoev
660
d0f7a625f27c nginx 1.1.14
Igor Sysoev <http://sysoev.ru>
parents: 404
diff changeset
4 * Copyright (C) Nginx, Inc.
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5 */
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_config.h>
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9 #include <ngx_core.h>
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11
404
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
12 /*
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
13 * FreeBSD does not test /etc/localtime change, however, we can workaround it
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
14 * by calling tzset() with TZ and then without TZ to update timezone.
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
15 * The trick should work since FreeBSD 2.1.0.
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
16 *
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
17 * Linux does not test /etc/localtime change in localtime(),
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
18 * but may stat("/etc/localtime") several times in every strftime(),
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
19 * therefore we use it to update timezone.
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
20 *
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
21 * Solaris does not test /etc/TIMEZONE change too and no workaround available.
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
22 */
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
23
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
24 void
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
25 ngx_timezone_update(void)
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
26 {
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
27 #if (NGX_FREEBSD)
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
28
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
29 if (getenv("TZ")) {
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
30 return;
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
31 }
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
32
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
33 putenv("TZ=UTC");
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
34
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
35 tzset();
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
36
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
37 unsetenv("TZ");
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
38
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
39 tzset();
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
40
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
41 #elif (NGX_LINUX)
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
42 time_t s;
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
43 struct tm *t;
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
44 char buf[4];
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
45
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
46 s = time(0);
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
47
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
48 t = localtime(&s);
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
49
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
50 strftime(buf, 4, "%H", t);
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
51
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
52 #endif
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
53 }
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
54
a094317ba307 nginx 0.7.14
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
55
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
56 void
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
57 ngx_localtime(time_t s, ngx_tm_t *tm)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
58 {
18
6f8b0dc0f8dd nginx 0.1.9
Igor Sysoev <http://sysoev.ru>
parents: 0
diff changeset
59 #if (NGX_HAVE_LOCALTIME_R)
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
60 (void) localtime_r(&s, tm);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
61
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
62 #else
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
63 ngx_tm_t *t;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
64
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
65 t = localtime(&s);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
66 *tm = *t;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
67
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
68 #endif
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
69
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
70 tm->ngx_tm_mon++;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
71 tm->ngx_tm_year += 1900;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
72 }
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
73
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
74
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
75 void
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
76 ngx_libc_localtime(time_t s, struct tm *tm)
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
77 {
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
78 #if (NGX_HAVE_LOCALTIME_R)
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
79 (void) localtime_r(&s, tm);
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
80
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
81 #else
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
82 struct tm *t;
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
83
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
84 t = localtime(&s);
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
85 *tm = *t;
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
86
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
87 #endif
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
88 }
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
89
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
90
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
91 void
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
92 ngx_libc_gmtime(time_t s, struct tm *tm)
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
93 {
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
94 #if (NGX_HAVE_LOCALTIME_R)
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
95 (void) gmtime_r(&s, tm);
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
96
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
97 #else
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
98 struct tm *t;
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
99
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 66
diff changeset
100 t = gmtime(&s);
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
101 *tm = *t;
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
102
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
103 #endif
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 18
diff changeset
104 }