annotate src/core/ngx_file.c @ 514:43cc6f0b77ce NGINX_0_8_9

nginx 0.8.9 *) Feature: now the start cache loader runs in a separate process; this should improve large caches handling. *) Feature: now temporarily files and permanent storage area may reside at different file systems.
author Igor Sysoev <http://sysoev.ru>
date Mon, 17 Aug 2009 00:00:00 +0400
parents f39b9e29530d
children 7efcdb937752
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
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
4 */
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 #include <ngx_config.h>
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_core.h>
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10
44
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
11 static ngx_atomic_uint_t ngx_temp_number;
250
fbf2b2f66c9f nginx 0.4.10
Igor Sysoev <http://sysoev.ru>
parents: 218
diff changeset
12 static ngx_atomic_uint_t ngx_random_number;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
13
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
14
42
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
15 ssize_t
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
16 ngx_write_chain_to_temp_file(ngx_temp_file_t *tf, ngx_chain_t *chain)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
17 {
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
18 ngx_int_t rc;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
19
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
20 if (tf->file.fd == NGX_INVALID_FILE) {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
21 rc = ngx_create_temp_file(&tf->file, tf->path, tf->pool,
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 276
diff changeset
22 tf->persistent, tf->clean, tf->access);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
23
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
24 if (rc == NGX_ERROR || rc == NGX_AGAIN) {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
25 return rc;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
26 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
27
216
fa32d59d9a15 nginx 0.3.55
Igor Sysoev <http://sysoev.ru>
parents: 210
diff changeset
28 if (tf->log_level) {
fa32d59d9a15 nginx 0.3.55
Igor Sysoev <http://sysoev.ru>
parents: 210
diff changeset
29 ngx_log_error(tf->log_level, tf->file.log, 0, "%s %V",
186
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
30 tf->warn, &tf->file.name);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
31 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
32 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
33
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
34 return ngx_write_chain_to_file(&tf->file, chain, tf->offset, tf->pool);
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
35 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
36
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
37
42
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
38 ngx_int_t
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
39 ngx_create_temp_file(ngx_file_t *file, ngx_path_t *path, ngx_pool_t *pool,
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 276
diff changeset
40 ngx_uint_t persistent, ngx_uint_t clean, ngx_uint_t access)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
41 {
282
675a39fd14cd nginx 0.5.11
Igor Sysoev <http://sysoev.ru>
parents: 278
diff changeset
42 uint32_t n;
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
43 ngx_err_t err;
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
44 ngx_pool_cleanup_t *cln;
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
45 ngx_pool_cleanup_file_t *clnf;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
46
282
675a39fd14cd nginx 0.5.11
Igor Sysoev <http://sysoev.ru>
parents: 278
diff changeset
47 file->name.len = path->name.len + 1 + path->len + 10;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
48
382
984bb0b1399b nginx 0.7.3
Igor Sysoev <http://sysoev.ru>
parents: 366
diff changeset
49 file->name.data = ngx_pnalloc(pool, file->name.len + 1);
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 48
diff changeset
50 if (file->name.data == NULL) {
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
51 return NGX_ERROR;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
52 }
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
53
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
54 #if 0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
55 for (i = 0; i < file->name.len; i++) {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
56 file->name.data[i] = 'X';
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
57 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
58 #endif
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
59
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
60 ngx_memcpy(file->name.data, path->name.data, path->name.len);
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
61
282
675a39fd14cd nginx 0.5.11
Igor Sysoev <http://sysoev.ru>
parents: 278
diff changeset
62 n = (uint32_t) ngx_next_temp_number(0);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
63
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
64 cln = ngx_pool_cleanup_add(pool, sizeof(ngx_pool_cleanup_file_t));
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
65 if (cln == NULL) {
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
66 return NGX_ERROR;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
67 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
68
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
69 for ( ;; ) {
66
818201e5a553 nginx 0.1.33
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
70 (void) ngx_sprintf(file->name.data + path->name.len + 1 + path->len,
282
675a39fd14cd nginx 0.5.11
Igor Sysoev <http://sysoev.ru>
parents: 278
diff changeset
71 "%010uD%Z", n);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
72
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
73 ngx_create_hashed_filename(path, file->name.data, file->name.len);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
74
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
75 ngx_log_debug1(NGX_LOG_DEBUG_CORE, file->log, 0,
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
76 "hashed path: %s", file->name.data);
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
77
276
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
78 file->fd = ngx_open_tempfile(file->name.data, persistent, access);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
79
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
80 ngx_log_debug1(NGX_LOG_DEBUG_CORE, file->log, 0,
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
81 "temp fd:%d", file->fd);
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
82
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
83 if (file->fd != NGX_INVALID_FILE) {
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
84
278
704622b2528a nginx 0.5.9
Igor Sysoev <http://sysoev.ru>
parents: 276
diff changeset
85 cln->handler = clean ? ngx_pool_delete_file : ngx_pool_cleanup_file;
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
86 clnf = cln->data;
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
87
112
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
88 clnf->fd = file->fd;
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
89 clnf->name = file->name.data;
408f195b3482 nginx 0.3.3
Igor Sysoev <http://sysoev.ru>
parents: 110
diff changeset
90 clnf->log = pool->log;
58
b55cbf18157e nginx 0.1.29
Igor Sysoev <http://sysoev.ru>
parents: 50
diff changeset
91
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
92 return NGX_OK;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
93 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
94
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
95 err = ngx_errno;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
96
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
97 if (err == NGX_EEXIST) {
282
675a39fd14cd nginx 0.5.11
Igor Sysoev <http://sysoev.ru>
parents: 278
diff changeset
98 n = (uint32_t) ngx_next_temp_number(1);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
99 continue;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
100 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
101
514
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
102 if ((path->level[0] == 0) || (err != NGX_ENOPATH)) {
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
103 ngx_log_error(NGX_LOG_CRIT, file->log, err,
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
104 ngx_open_tempfile_n " \"%s\" failed",
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
105 file->name.data);
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
106 return NGX_ERROR;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
107 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
108
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
109 if (ngx_create_path(file, path) == NGX_ERROR) {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
110 return NGX_ERROR;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
111 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
112 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
113 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
114
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
115
42
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
116 void
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
117 ngx_create_hashed_filename(ngx_path_t *path, u_char *file, size_t len)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
118 {
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
119 size_t i, level;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
120 ngx_uint_t n;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
121
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
122 i = path->name.len + 1;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
123
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
124 file[path->name.len + path->len] = '/';
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
125
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
126 for (n = 0; n < 3; n++) {
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
127 level = path->level[n];
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
128
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
129 if (level == 0) {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
130 break;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
131 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
132
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
133 len -= level;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
134 file[i - 1] = '/';
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
135 ngx_memcpy(&file[i], &file[len], level);
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
136 i += level + 1;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
137 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
138 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
139
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
140
42
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
141 ngx_int_t
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
142 ngx_create_path(ngx_file_t *file, ngx_path_t *path)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
143 {
66
818201e5a553 nginx 0.1.33
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
144 size_t pos;
818201e5a553 nginx 0.1.33
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
145 ngx_err_t err;
818201e5a553 nginx 0.1.33
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
146 ngx_uint_t i;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
147
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
148 pos = path->name.len;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
149
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
150 for (i = 0; i < 3; i++) {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
151 if (path->level[i] == 0) {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
152 break;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
153 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
154
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
155 pos += path->level[i] + 1;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
156
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
157 file->name.data[pos] = '\0';
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
158
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
159 ngx_log_debug1(NGX_LOG_DEBUG_CORE, file->log, 0,
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
160 "temp file: \"%s\"", file->name.data);
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
161
218
1bf60f8c5c9e nginx 0.3.56
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
162 if (ngx_create_dir(file->name.data, 0700) == NGX_FILE_ERROR) {
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
163 err = ngx_errno;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
164 if (err != NGX_EEXIST) {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
165 ngx_log_error(NGX_LOG_CRIT, file->log, err,
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
166 ngx_create_dir_n " \"%s\" failed",
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
167 file->name.data);
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
168 return NGX_ERROR;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
169 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
170 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
171
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
172 file->name.data[pos] = '/';
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
173 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
174
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
175 return NGX_OK;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
176 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
177
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
178
186
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
179 ngx_err_t
218
1bf60f8c5c9e nginx 0.3.56
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
180 ngx_create_full_path(u_char *dir, ngx_uint_t access)
186
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
181 {
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
182 u_char *p, ch;
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
183 ngx_err_t err;
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
184
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
185 for (p = dir + 1; *p; p++) {
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
186 ch = *p;
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
187
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
188 if (ch != '/') {
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
189 continue;
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
190 }
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
191
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
192 *p = '\0';
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
193
218
1bf60f8c5c9e nginx 0.3.56
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
194 if (ngx_create_dir(dir, access) == NGX_FILE_ERROR) {
186
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
195 err = ngx_errno;
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
196 if (err != NGX_EEXIST) {
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
197 return err;
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
198 }
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
199 }
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
200
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
201 *p = '/';
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
202 }
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
203
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
204 return 0;
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
205 }
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
206
54aabf2b0bc6 nginx 0.3.40
Igor Sysoev <http://sysoev.ru>
parents: 182
diff changeset
207
42
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
208 void
48
6cfc63e68377 nginx 0.1.24
Igor Sysoev <http://sysoev.ru>
parents: 44
diff changeset
209 ngx_init_temp_number(void)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
210 {
42
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
211 ngx_temp_number = 0;
250
fbf2b2f66c9f nginx 0.4.10
Igor Sysoev <http://sysoev.ru>
parents: 218
diff changeset
212 ngx_random_number = 123456;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
213 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
214
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
215
44
4989c3d25945 nginx 0.1.22
Igor Sysoev <http://sysoev.ru>
parents: 42
diff changeset
216 ngx_atomic_uint_t
42
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
217 ngx_next_temp_number(ngx_uint_t collision)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
218 {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
219 if (collision) {
250
fbf2b2f66c9f nginx 0.4.10
Igor Sysoev <http://sysoev.ru>
parents: 218
diff changeset
220 ngx_temp_number += ngx_random_number;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
221 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
222
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
223 return ngx_temp_number++;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
224 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
225
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
226
42
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
227 char *
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
228 ngx_conf_set_path_slot(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
229 {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
230 char *p = conf;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
231
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
232 ssize_t level;
178
87699398f955 nginx 0.3.36
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
233 ngx_str_t *value;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
234 ngx_uint_t i, n;
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
235 ngx_path_t *path, **slot;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
236
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
237 slot = (ngx_path_t **) (p + cmd->offset);
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
238
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
239 if (*slot) {
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
240 return "is duplicate";
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
241 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
242
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 48
diff changeset
243 path = ngx_pcalloc(cf->pool, sizeof(ngx_path_t));
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 48
diff changeset
244 if (path == NULL) {
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
245 return NGX_CONF_ERROR;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
246 }
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
247
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
248 value = cf->args->elts;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
249
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
250 path->name = value[1];
178
87699398f955 nginx 0.3.36
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
251
210
14050d2bec9b nginx 0.3.52
Igor Sysoev <http://sysoev.ru>
parents: 186
diff changeset
252 if (path->name.data[path->name.len - 1] == '/') {
14050d2bec9b nginx 0.3.52
Igor Sysoev <http://sysoev.ru>
parents: 186
diff changeset
253 path->name.len--;
14050d2bec9b nginx 0.3.52
Igor Sysoev <http://sysoev.ru>
parents: 186
diff changeset
254 }
14050d2bec9b nginx 0.3.52
Igor Sysoev <http://sysoev.ru>
parents: 186
diff changeset
255
454
a8424ffa495c nginx 0.7.39
Igor Sysoev <http://sysoev.ru>
parents: 430
diff changeset
256 if (ngx_conf_full_name(cf->cycle, &path->name, 0) != NGX_OK) {
178
87699398f955 nginx 0.3.36
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
257 return NULL;
87699398f955 nginx 0.3.36
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
258 }
87699398f955 nginx 0.3.36
Igor Sysoev <http://sysoev.ru>
parents: 112
diff changeset
259
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
260 path->len = 0;
514
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
261 path->manager = NULL;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
262 path->loader = NULL;
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
263 path->conf_file = cf->conf_file->file.name.data;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
264 path->line = cf->conf_file->line;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
265
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
266 for (i = 0, n = 2; n < cf->args->nelts; i++, n++) {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
267 level = ngx_atoi(value[n].data, value[n].len);
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
268 if (level == NGX_ERROR || level == 0) {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
269 return "invalid value";
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
270 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
271
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
272 path->level[i] = level;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
273 path->len += level + 1;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
274 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
275
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
276 while (i < 3) {
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
277 path->level[i++] = 0;
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
278 }
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
279
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
280 *slot = path;
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
281
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
282 if (ngx_add_path(cf, slot) == NGX_ERROR) {
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
283 return NGX_CONF_ERROR;
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
284 }
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
285
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
286 return NGX_CONF_OK;
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
287 }
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
288
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
289
318
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
290 char *
464
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
291 ngx_conf_merge_path_value(ngx_conf_t *cf, ngx_path_t **path, ngx_path_t *prev,
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
292 ngx_path_init_t *init)
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
293 {
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
294 if (*path) {
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
295 return NGX_CONF_OK;
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
296 }
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
297
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
298 if (prev) {
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
299 *path = prev;
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
300 return NGX_CONF_OK;
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
301 }
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
302
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
303 *path = ngx_palloc(cf->pool, sizeof(ngx_path_t));
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
304 if (*path == NULL) {
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
305 return NGX_CONF_ERROR;
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
306 }
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
307
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
308 (*path)->name = init->name;
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
309
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
310 if (ngx_conf_full_name(cf->cycle, &(*path)->name, 0) != NGX_OK) {
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
311 return NGX_CONF_ERROR;
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
312 }
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
313
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
314 (*path)->level[0] = init->level[0];
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
315 (*path)->level[1] = init->level[1];
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
316 (*path)->level[2] = init->level[2];
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
317
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
318 (*path)->len = init->level[0] + (init->level[0] ? 1 : 0)
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
319 + init->level[1] + (init->level[1] ? 1 : 0)
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
320 + init->level[2] + (init->level[2] ? 1 : 0);
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
321
468
56baf312c1b5 nginx 0.7.46
Igor Sysoev <http://sysoev.ru>
parents: 464
diff changeset
322 (*path)->manager = NULL;
514
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
323 (*path)->loader = NULL;
464
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
324 (*path)->conf_file = NULL;
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
325
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
326 if (ngx_add_path(cf, path) != NGX_OK) {
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
327 return NGX_CONF_ERROR;
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
328 }
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
329
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
330 return NGX_CONF_OK;
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
331 }
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
332
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
333
c8cfb6c462ef nginx 0.7.44
Igor Sysoev <http://sysoev.ru>
parents: 454
diff changeset
334 char *
318
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
335 ngx_conf_set_access_slot(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
336 {
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
337 char *confp = conf;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
338
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
339 u_char *p;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
340 ngx_str_t *value;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
341 ngx_uint_t i, right, shift, *access;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
342
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
343 access = (ngx_uint_t *) (confp + cmd->offset);
320
95183808f549 nginx 0.6.4
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
344
318
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
345 if (*access != NGX_CONF_UNSET_UINT) {
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
346 return "is duplicate";
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
347 }
320
95183808f549 nginx 0.6.4
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
348
318
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
349 value = cf->args->elts;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
350
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
351 *access = 0600;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
352
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
353 for (i = 1; i < cf->args->nelts; i++) {
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
354
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
355 p = value[i].data;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
356
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
357 if (ngx_strncmp(p, "user:", sizeof("user:") - 1) == 0) {
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
358 shift = 6;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
359 p += sizeof("user:") - 1;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
360
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
361 } else if (ngx_strncmp(p, "group:", sizeof("group:") - 1) == 0) {
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
362 shift = 3;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
363 p += sizeof("group:") - 1;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
364
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
365 } else if (ngx_strncmp(p, "all:", sizeof("all:") - 1) == 0) {
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
366 shift = 0;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
367 p += sizeof("all:") - 1;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
368
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
369 } else {
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
370 goto invalid;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
371 }
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
372
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
373 if (ngx_strcmp(p, "rw") == 0) {
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
374 right = 6;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
375
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
376 } else if (ngx_strcmp(p, "r") == 0) {
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
377 right = 4;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
378
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
379 } else {
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
380 goto invalid;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
381 }
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
382
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
383 *access |= right << shift;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
384 }
320
95183808f549 nginx 0.6.4
Igor Sysoev <http://sysoev.ru>
parents: 318
diff changeset
385
318
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
386 return NGX_CONF_OK;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
387
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
388 invalid:
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
389
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
390 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0, "invalid value \"%V\"", &value[i]);
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
391
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
392 return NGX_CONF_ERROR;
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
393 }
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
394
fc223117327f nginx 0.6.3
Igor Sysoev <http://sysoev.ru>
parents: 282
diff changeset
395
42
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
396 ngx_int_t
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
397 ngx_add_path(ngx_conf_t *cf, ngx_path_t **slot)
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
398 {
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
399 ngx_uint_t i, n;
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
400 ngx_path_t *path, **p;
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
401
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
402 path = *slot;
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
403
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
404 p = cf->cycle->pathes.elts;
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
405 for (i = 0; i < cf->cycle->pathes.nelts; i++) {
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
406 if (p[i]->name.len == path->name.len
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
407 && ngx_strcmp(p[i]->name.data, path->name.data) == 0)
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
408 {
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
409 for (n = 0; n < 3; n++) {
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
410 if (p[i]->level[n] != path->level[n]) {
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
411 if (path->conf_file == NULL) {
30
e1ada20fc595 nginx 0.1.15
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
412 if (p[i]->conf_file == NULL) {
e1ada20fc595 nginx 0.1.15
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
413 ngx_log_error(NGX_LOG_EMERG, cf->log, 0,
e1ada20fc595 nginx 0.1.15
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
414 "the default path name \"%V\" has "
e1ada20fc595 nginx 0.1.15
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
415 "the same name as another default path, "
e1ada20fc595 nginx 0.1.15
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
416 "but the different levels, you need to "
e1ada20fc595 nginx 0.1.15
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
417 "redefine one of them in http section",
e1ada20fc595 nginx 0.1.15
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
418 &p[i]->name);
e1ada20fc595 nginx 0.1.15
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
419 return NGX_ERROR;
e1ada20fc595 nginx 0.1.15
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
420 }
e1ada20fc595 nginx 0.1.15
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
421
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
422 ngx_log_error(NGX_LOG_EMERG, cf->log, 0,
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
423 "the path name \"%V\" in %s:%ui has "
30
e1ada20fc595 nginx 0.1.15
Igor Sysoev <http://sysoev.ru>
parents: 28
diff changeset
424 "the same name as default path, but "
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
425 "the different levels, you need to "
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
426 "define default path in http section",
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
427 &p[i]->name, p[i]->conf_file, p[i]->line);
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
428 return NGX_ERROR;
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
429 }
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
430
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
431 ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
432 "the same path name \"%V\" in %s:%ui "
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
433 "has the different levels than",
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
434 &p[i]->name, p[i]->conf_file, p[i]->line);
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
435 return NGX_ERROR;
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
436 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
437
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
438 if (p[i]->level[n] == 0) {
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
439 break;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
440 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
441 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
442
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
443 *slot = p[i];
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
444
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
445 return NGX_OK;
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
446 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
447 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
448
50
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 48
diff changeset
449 p = ngx_array_push(&cf->cycle->pathes);
72eb30262aac nginx 0.1.25
Igor Sysoev <http://sysoev.ru>
parents: 48
diff changeset
450 if (p == NULL) {
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
451 return NGX_ERROR;
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
452 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
453
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
454 *p = path;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
455
28
7ca9bdc82b3f nginx 0.1.14
Igor Sysoev <http://sysoev.ru>
parents: 16
diff changeset
456 return NGX_OK;
0
f0b350454894 nginx 0.1.0
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
457 }
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
458
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
459
42
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
460 ngx_int_t
41ccba1aba45 nginx 0.1.21
Igor Sysoev <http://sysoev.ru>
parents: 30
diff changeset
461 ngx_create_pathes(ngx_cycle_t *cycle, ngx_uid_t user)
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
462 {
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
463 ngx_err_t err;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
464 ngx_uint_t i;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
465 ngx_path_t **path;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
466
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
467 path = cycle->pathes.elts;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
468 for (i = 0; i < cycle->pathes.nelts; i++) {
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
469
218
1bf60f8c5c9e nginx 0.3.56
Igor Sysoev <http://sysoev.ru>
parents: 216
diff changeset
470 if (ngx_create_dir(path[i]->name.data, 0700) == NGX_FILE_ERROR) {
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
471 err = ngx_errno;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
472 if (err != NGX_EEXIST) {
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
473 ngx_log_error(NGX_LOG_EMERG, cycle->log, err,
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
474 ngx_create_dir_n " \"%s\" failed",
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
475 path[i]->name.data);
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
476 return NGX_ERROR;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
477 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
478 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
479
66
818201e5a553 nginx 0.1.33
Igor Sysoev <http://sysoev.ru>
parents: 58
diff changeset
480 if (user == (ngx_uid_t) NGX_CONF_UNSET_UINT) {
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
481 continue;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
482 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
483
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
484 #if !(NGX_WIN32)
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
485 {
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
486 ngx_file_info_t fi;
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
487
484
ed5e10fb40fc nginx 0.7.54
Igor Sysoev <http://sysoev.ru>
parents: 468
diff changeset
488 if (ngx_file_info((const char *) path[i]->name.data, &fi)
ed5e10fb40fc nginx 0.7.54
Igor Sysoev <http://sysoev.ru>
parents: 468
diff changeset
489 == NGX_FILE_ERROR)
ed5e10fb40fc nginx 0.7.54
Igor Sysoev <http://sysoev.ru>
parents: 468
diff changeset
490 {
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
491 ngx_log_error(NGX_LOG_EMERG, cycle->log, ngx_errno,
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
492 ngx_file_info_n " \"%s\" failed", path[i]->name.data);
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
493 return NGX_ERROR;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
494 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
495
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
496 if (fi.st_uid != user) {
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
497 if (chown((const char *) path[i]->name.data, user, -1) == -1) {
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
498 ngx_log_error(NGX_LOG_EMERG, cycle->log, ngx_errno,
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
499 "chown(\"%s\", %d) failed",
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
500 path[i]->name.data, user);
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
501 return NGX_ERROR;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
502 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
503 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
504
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
505 if ((fi.st_mode & (S_IRUSR|S_IWUSR|S_IXUSR))
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
506 != (S_IRUSR|S_IWUSR|S_IXUSR))
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
507 {
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
508 fi.st_mode |= (S_IRUSR|S_IWUSR|S_IXUSR);
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
509
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
510 if (chmod((const char *) path[i]->name.data, fi.st_mode) == -1) {
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
511 ngx_log_error(NGX_LOG_EMERG, cycle->log, ngx_errno,
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
512 "chmod() \"%s\" failed", path[i]->name.data);
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
513 return NGX_ERROR;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
514 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
515 }
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
516 }
16
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
517 #endif
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
518 }
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
519
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
520 return NGX_OK;
74b1868dd3cd nginx 0.1.8
Igor Sysoev <http://sysoev.ru>
parents: 10
diff changeset
521 }
272
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
522
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
523
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
524 ngx_int_t
362
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
525 ngx_ext_rename_file(ngx_str_t *src, ngx_str_t *to, ngx_ext_rename_file_t *ext)
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
526 {
514
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
527 u_char *name;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
528 ngx_err_t err;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
529 ngx_copy_file_t cf;
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
530
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
531 #if !(NGX_WIN32)
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
532
430
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 382
diff changeset
533 if (ext->access) {
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 382
diff changeset
534 if (ngx_change_file_access(src->data, ext->access) == NGX_FILE_ERROR) {
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 382
diff changeset
535 ngx_log_error(NGX_LOG_CRIT, ext->log, ngx_errno,
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 382
diff changeset
536 ngx_change_file_access_n " \"%s\" failed", src->data);
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 382
diff changeset
537 err = 0;
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 382
diff changeset
538 goto failed;
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 382
diff changeset
539 }
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
540 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
541
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
542 #endif
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
543
362
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
544 if (ext->time != -1) {
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
545 if (ngx_set_file_time(src->data, ext->fd, ext->time) != NGX_OK) {
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
546 ngx_log_error(NGX_LOG_CRIT, ext->log, ngx_errno,
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
547 ngx_set_file_time_n " \"%s\" failed", src->data);
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
548 err = 0;
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
549 goto failed;
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
550 }
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
551 }
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
552
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
553 if (ngx_rename_file(src->data, to->data) != NGX_FILE_ERROR) {
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
554 return NGX_OK;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
555 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
556
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
557 err = ngx_errno;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
558
514
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
559 if (err == NGX_ENOPATH) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
560
362
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
561 if (!ext->create_path) {
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
562 goto failed;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
563 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
564
430
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 382
diff changeset
565 err = ngx_create_full_path(to->data, ngx_dir_access(ext->path_access));
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
566
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
567 if (err) {
362
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
568 ngx_log_error(NGX_LOG_CRIT, ext->log, err,
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
569 ngx_create_dir_n " \"%s\" failed", to->data);
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
570 err = 0;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
571 goto failed;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
572 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
573
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
574 if (ngx_rename_file(src->data, to->data) != NGX_FILE_ERROR) {
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
575 return NGX_OK;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
576 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
577
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
578 err = ngx_errno;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
579 goto failed;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
580 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
581
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
582 #if (NGX_WIN32)
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
583
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
584 if (err == NGX_EEXIST) {
362
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
585 if (ngx_win32_rename_file(src, to, ext->log) == NGX_OK) {
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
586
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
587 if (ngx_rename_file(src->data, to->data) != NGX_FILE_ERROR) {
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
588 return NGX_OK;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
589 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
590
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
591 err = ngx_errno;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
592
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
593 } else {
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
594 err = 0;
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
595 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
596 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
597
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
598 #endif
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
599
514
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
600 if (err == NGX_EXDEV) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
601
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
602 cf.size = -1;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
603 cf.buf_size = 0;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
604 cf.access = ext->access;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
605 cf.time = ext->time;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
606 cf.log = ext->log;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
607
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
608 name = ngx_alloc(to->len + 1 + 10, ext->log);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
609 if (name == NULL) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
610 return NGX_ERROR;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
611 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
612
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
613 (void) ngx_sprintf(name, "%*s.%010uD%Z", to->len - 1, to->data,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
614 (uint32_t) ngx_next_temp_number(0));
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
615
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
616 if (ngx_copy_file(src->data, name, &cf) == NGX_OK) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
617
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
618 if (ngx_rename_file(name, to->data) == NGX_FILE_ERROR) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
619 ngx_free(name);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
620 goto failed;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
621 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
622
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
623 ngx_free(name);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
624
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
625 if (ngx_delete_file(src->data) == NGX_FILE_ERROR) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
626 ngx_log_error(NGX_LOG_CRIT, ext->log, ngx_errno,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
627 ngx_delete_file_n " \"%s\" failed", src->data);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
628
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
629 return NGX_ERROR;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
630 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
631
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
632 return NGX_OK;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
633 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
634
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
635 ngx_free(name);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
636 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
637
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
638 failed:
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
639
366
babd3d9efb62 nginx 0.6.27
Igor Sysoev <http://sysoev.ru>
parents: 362
diff changeset
640 if (ext->delete_file) {
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
641 if (ngx_delete_file(src->data) == NGX_FILE_ERROR) {
362
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
642 ngx_log_error(NGX_LOG_CRIT, ext->log, ngx_errno,
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
643 ngx_delete_file_n " \"%s\" failed", src->data);
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
644 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
645 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
646
514
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
647 if (err) {
362
54fad6c4b555 nginx 0.6.25
Igor Sysoev <http://sysoev.ru>
parents: 356
diff changeset
648 ngx_log_error(NGX_LOG_CRIT, ext->log, err,
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
649 ngx_rename_file_n " \"%s\" to \"%s\" failed",
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
650 src->data, to->data);
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
651 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
652
514
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
653 return NGX_ERROR;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
654 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
655
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
656
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
657 ngx_int_t
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
658 ngx_copy_file(u_char *from, u_char *to, ngx_copy_file_t *cf)
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
659 {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
660 char *buf;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
661 off_t size;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
662 size_t len;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
663 ssize_t n;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
664 ngx_fd_t fd, nfd;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
665 ngx_int_t rc;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
666 ngx_file_info_t fi;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
667
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
668 rc = NGX_ERROR;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
669 buf = NULL;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
670 nfd = NGX_INVALID_FILE;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
671
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
672 fd = ngx_open_file(from, NGX_FILE_RDONLY, NGX_FILE_OPEN, 0);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
673
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
674 if (fd == NGX_INVALID_FILE) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
675 ngx_log_error(NGX_LOG_CRIT, cf->log, ngx_errno,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
676 ngx_open_file_n " \"%s\" failed", from);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
677 goto failed;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
678 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
679
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
680 if (cf->size != -1) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
681 size = cf->size;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
682
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
683 } else {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
684 if (ngx_fd_info(fd, &fi) == NGX_FILE_ERROR) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
685 ngx_log_error(NGX_LOG_ALERT, cf->log, ngx_errno,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
686 ngx_fd_info_n " \"%s\" failed", from);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
687
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
688 goto failed;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
689 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
690
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
691 size = ngx_file_size(&fi);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
692 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
693
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
694 len = cf->buf_size ? cf->buf_size : 65536;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
695
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
696 if ((off_t) len > size) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
697 len = (size_t) size;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
698 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
699
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
700 buf = ngx_alloc(len, cf->log);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
701 if (buf == NULL) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
702 goto failed;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
703 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
704
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
705 nfd = ngx_open_file(to, NGX_FILE_WRONLY, NGX_FILE_CREATE_OR_OPEN,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
706 cf->access);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
707
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
708 if (nfd == NGX_INVALID_FILE) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
709 ngx_log_error(NGX_LOG_CRIT, cf->log, ngx_errno,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
710 ngx_open_file_n " \"%s\" failed", to);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
711 goto failed;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
712 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
713
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
714 while (size > 0) {
430
dac47e9ef0d5 nginx 0.7.27
Igor Sysoev <http://sysoev.ru>
parents: 382
diff changeset
715
514
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
716 if ((off_t) len > size) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
717 len = (size_t) size;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
718 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
719
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
720 n = ngx_read_fd(fd, buf, len);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
721
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
722 if (n == NGX_FILE_ERROR) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
723 ngx_log_error(NGX_LOG_ALERT, cf->log, ngx_errno,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
724 ngx_read_fd_n " \"%s\" failed", from);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
725 goto failed;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
726 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
727
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
728 if ((size_t) n != len) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
729 ngx_log_error(NGX_LOG_ALERT, cf->log, ngx_errno,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
730 ngx_read_fd_n " has read only %z of %uz from %s",
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
731 n, size, from);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
732 goto failed;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
733 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
734
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
735 n = ngx_write_fd(nfd, buf, len);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
736
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
737 if (n == NGX_FILE_ERROR) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
738 ngx_log_error(NGX_LOG_ALERT, cf->log, ngx_errno,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
739 ngx_write_fd_n " \"%s\" failed", to);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
740 goto failed;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
741 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
742
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
743 if ((size_t) n != len) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
744 ngx_log_error(NGX_LOG_ALERT, cf->log, ngx_errno,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
745 ngx_write_fd_n " has written only %z of %uz to %s",
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
746 n, size, to);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
747 goto failed;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
748 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
749
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
750 size -= n;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
751 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
752
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
753 if (ngx_set_file_time(to, nfd, cf->time) != NGX_OK) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
754 ngx_log_error(NGX_LOG_ALERT, cf->log, ngx_errno,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
755 ngx_set_file_time_n " \"%s\" failed", to);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
756 goto failed;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
757 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
758
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
759 rc = NGX_OK;
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
760
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
761 failed:
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
762
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
763 if (nfd != NGX_INVALID_FILE) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
764 if (ngx_close_file(nfd) == NGX_FILE_ERROR) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
765 ngx_log_error(NGX_LOG_ALERT, cf->log, ngx_errno,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
766 ngx_close_file_n " \"%s\" failed", to);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
767 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
768 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
769
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
770 if (fd != NGX_INVALID_FILE) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
771 if (ngx_close_file(fd) == NGX_FILE_ERROR) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
772 ngx_log_error(NGX_LOG_ALERT, cf->log, ngx_errno,
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
773 ngx_close_file_n " \"%s\" failed", from);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
774 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
775 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
776
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
777 if (buf) {
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
778 ngx_free(buf);
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
779 }
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
780
43cc6f0b77ce nginx 0.8.9
Igor Sysoev <http://sysoev.ru>
parents: 496
diff changeset
781 return rc;
356
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
782 }
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
783
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
784
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
785 /*
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
786 * ctx->init_handler() - see ctx->alloc
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
787 * ctx->file_handler() - file handler
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
788 * ctx->pre_tree_handler() - handler is called before entering directory
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
789 * ctx->post_tree_handler() - handler is called after leaving directory
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
790 * ctx->spec_handler() - special (socket, FIFO, etc.) file handler
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
791 *
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
792 * ctx->data - some data structure, it may be the same on all levels, or
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
793 * reallocated if ctx->alloc is nonzero
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
794 *
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
795 * ctx->alloc - a size of data structure that is allocated at every level
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
796 * and is initilialized by ctx->init_handler()
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
797 *
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
798 * ctx->log - a log
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
799 *
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
800 * on fatal (memory) error handler must return NGX_ABORT to stop walking tree
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
801 */
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
802
b743d290eb3b nginx 0.6.22
Igor Sysoev <http://sysoev.ru>
parents: 324
diff changeset
803 ngx_int_t
272
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
804 ngx_walk_tree(ngx_tree_ctx_t *ctx, ngx_str_t *tree)
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
805 {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
806 void *data, *prev;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
807 u_char *p, *name;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
808 size_t len;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
809 ngx_int_t rc;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
810 ngx_err_t err;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
811 ngx_str_t file, buf;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
812 ngx_dir_t dir;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
813
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
814 buf.len = 0;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
815 buf.data = NULL;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
816
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
817 ngx_log_debug1(NGX_LOG_DEBUG_CORE, ctx->log, 0,
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
818 "walk tree \"%V\"", tree);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
819
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
820 if (ngx_open_dir(tree, &dir) == NGX_ERROR) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
821 ngx_log_error(NGX_LOG_CRIT, ctx->log, ngx_errno,
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
822 ngx_open_dir_n " \"%s\" failed", tree->data);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
823 return NGX_ERROR;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
824 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
825
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
826 prev = ctx->data;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
827
276
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
828 if (ctx->alloc) {
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
829 data = ngx_alloc(ctx->alloc, ctx->log);
272
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
830 if (data == NULL) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
831 goto failed;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
832 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
833
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
834 if (ctx->init_handler(data, prev) == NGX_ABORT) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
835 goto failed;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
836 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
837
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
838 ctx->data = data;
322
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 320
diff changeset
839
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 320
diff changeset
840 } else {
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 320
diff changeset
841 data = NULL;
272
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
842 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
843
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
844 for ( ;; ) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
845
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
846 ngx_set_errno(0);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
847
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
848 if (ngx_read_dir(&dir) == NGX_ERROR) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
849 err = ngx_errno;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
850
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
851 if (err == NGX_ENOMOREFILES) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
852 rc = NGX_OK;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
853
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
854 } else {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
855 ngx_log_error(NGX_LOG_CRIT, ctx->log, err,
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
856 ngx_read_dir_n " \"%s\" failed", tree->data);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
857 rc = NGX_ERROR;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
858 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
859
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
860 goto done;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
861 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
862
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
863 len = ngx_de_namelen(&dir);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
864 name = ngx_de_name(&dir);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
865
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
866 ngx_log_debug2(NGX_LOG_DEBUG_CORE, ctx->log, 0,
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
867 "tree name %uz:\"%s\"", len, name);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
868
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
869 if (len == 1 && name[0] == '.') {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
870 continue;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
871 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
872
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
873 if (len == 2 && name[0] == '.' && name[1] == '.') {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
874 continue;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
875 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
876
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
877 file.len = tree->len + 1 + len;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
878
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
879 if (file.len + NGX_DIR_MASK_LEN > buf.len) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
880
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
881 if (buf.len) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
882 ngx_free(buf.data);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
883 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
884
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
885 buf.len = tree->len + 1 + len + NGX_DIR_MASK_LEN;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
886
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
887 buf.data = ngx_alloc(buf.len + 1, ctx->log);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
888 if (buf.data == NULL) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
889 goto failed;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
890 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
891 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
892
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
893 p = ngx_cpymem(buf.data, tree->data, tree->len);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
894 *p++ = '/';
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
895 ngx_memcpy(p, name, len + 1);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
896
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
897 file.data = buf.data;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
898
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
899 ngx_log_debug1(NGX_LOG_DEBUG_CORE, ctx->log, 0,
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
900 "tree path \"%s\"", file.data);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
901
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
902 if (!dir.valid_info) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
903 if (ngx_de_info(file.data, &dir) == NGX_FILE_ERROR) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
904 ngx_log_error(NGX_LOG_CRIT, ctx->log, ngx_errno,
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
905 ngx_de_info_n " \"%s\" failed", file.data);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
906 continue;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
907 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
908 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
909
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
910 if (ngx_de_is_file(&dir)) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
911
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
912 ngx_log_debug1(NGX_LOG_DEBUG_CORE, ctx->log, 0,
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
913 "tree file \"%s\"", file.data);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
914
276
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
915 ctx->size = ngx_de_size(&dir);
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
916 ctx->access = ngx_de_access(&dir);
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
917 ctx->mtime = ngx_de_mtime(&dir);
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
918
272
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
919 if (ctx->file_handler(ctx, &file) == NGX_ABORT) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
920 goto failed;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
921 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
922
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
923 } else if (ngx_de_is_dir(&dir)) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
924
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
925 ngx_log_debug1(NGX_LOG_DEBUG_CORE, ctx->log, 0,
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
926 "tree enter dir \"%s\"", file.data);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
927
276
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
928 ctx->access = ngx_de_access(&dir);
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
929 ctx->mtime = ngx_de_mtime(&dir);
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
930
272
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
931 if (ctx->pre_tree_handler(ctx, &file) == NGX_ABORT) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
932 goto failed;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
933 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
934
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
935 if (ngx_walk_tree(ctx, &file) == NGX_ABORT) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
936 goto failed;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
937 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
938
276
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
939 ctx->access = ngx_de_access(&dir);
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
940 ctx->mtime = ngx_de_mtime(&dir);
c5c2b2883984 nginx 0.5.8
Igor Sysoev <http://sysoev.ru>
parents: 272
diff changeset
941
272
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
942 if (ctx->post_tree_handler(ctx, &file) == NGX_ABORT) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
943 goto failed;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
944 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
945
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
946 } else {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
947
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
948 ngx_log_debug1(NGX_LOG_DEBUG_CORE, ctx->log, 0,
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
949 "tree special \"%s\"", file.data);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
950
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
951 if (ctx->spec_handler(ctx, &file) == NGX_ABORT) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
952 goto failed;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
953 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
954 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
955 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
956
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
957 failed:
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
958
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
959 rc = NGX_ABORT;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
960
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
961 done:
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
962
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
963 if (buf.len) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
964 ngx_free(buf.data);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
965 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
966
322
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 320
diff changeset
967 if (data) {
d16d691432c9 nginx 0.6.5
Igor Sysoev <http://sysoev.ru>
parents: 320
diff changeset
968 ngx_free(data);
272
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
969 ctx->data = prev;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
970 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
971
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
972 if (ngx_close_dir(&dir) == NGX_ERROR) {
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
973 ngx_log_error(NGX_LOG_CRIT, ctx->log, ngx_errno,
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
974 ngx_close_dir_n " \"%s\" failed", tree->data);
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
975 }
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
976
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
977 return rc;
29a6403156b0 nginx 0.5.6
Igor Sysoev <http://sysoev.ru>
parents: 250
diff changeset
978 }