annotate src/core/ngx_hash.c @ 312:429900ca25ee NGINX_0_6_0

nginx 0.6.0 *) Feature: the "server_name", "map", and "valid_referers" directives support the "www.example.*" wildcards.
author Igor Sysoev <http://sysoev.ru>
date Thu, 14 Jun 2007 00:00:00 +0400
parents ff906029dd40
children 5e3b425174f6
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
56
3050baa54a26 nginx 0.1.28
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1
3050baa54a26 nginx 0.1.28
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 /*
3050baa54a26 nginx 0.1.28
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
3 * Copyright (C) Igor Sysoev
3050baa54a26 nginx 0.1.28
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
4 */
3050baa54a26 nginx 0.1.28
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5
3050baa54a26 nginx 0.1.28
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
3050baa54a26 nginx 0.1.28
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7 #include <ngx_config.h>
3050baa54a26 nginx 0.1.28
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_core.h>
3050baa54a26 nginx 0.1.28
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9
3050baa54a26 nginx 0.1.28
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
11 void *
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
12 ngx_hash_find(ngx_hash_t *hash, ngx_uint_t key, u_char *name, size_t len)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
13 {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
14 ngx_uint_t i;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
15 ngx_hash_elt_t *elt;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
16
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
17 #if 0
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
18 ngx_str_t line;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
19
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
20 line.len = len;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
21 line.data = name;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
22 ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, 0, "hf:\"%V\"", &line);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
23 #endif
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
24
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
25 elt = hash->buckets[key % hash->size];
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
26
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
27 if (elt == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
28 return NULL;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
29 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
30
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
31 while (elt->value) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
32 if (len != (size_t) elt->len) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
33 goto next;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
34 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
35
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
36 for (i = 0; i < len; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
37 if (name[i] != elt->name[i]) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
38 goto next;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
39 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
40 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
41
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
42 return elt->value;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
43
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
44 next:
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
45
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
46 elt = (ngx_hash_elt_t *) ngx_align_ptr(&elt->name[0] + elt->len,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
47 sizeof(void *));
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
48 continue;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
49 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
50
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
51 return NULL;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
52 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
53
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
54
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
55 void *
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
56 ngx_hash_find_wc_head(ngx_hash_wildcard_t *hwc, u_char *name, size_t len)
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
57 {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
58 void *value;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
59 ngx_uint_t i, n, key;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
60
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
61 #if 0
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
62 ngx_str_t line;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
63
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
64 line.len = len;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
65 line.data = name;
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
66 ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, 0, "wch:\"%V\"", &line);
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
67 #endif
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
68
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
69 n = len;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
70
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
71 while (n) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
72 if (name[n - 1] == '.') {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
73 break;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
74 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
75
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
76 n--;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
77 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
78
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
79 key = 0;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
80
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
81 for (i = n; i < len; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
82 key = ngx_hash(key, name[i]);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
83 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
84
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
85 #if 0
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
86 ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, 0, "key:\"%ui\"", key);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
87 #endif
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
88
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
89 value = ngx_hash_find(&hwc->hash, key, &name[n], len - n);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
90
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
91 if (value) {
140
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
92
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
93 /*
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
94 * the 2 low bits of value have the special meaning:
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
95 * 00 - value is data pointer,
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
96 * 01 - value is pointer to wildcard hash allowing
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
97 * "*.example.com" only,
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
98 * 11 - value is pointer to wildcard hash allowing
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
99 * both "example.com" and "*.example.com".
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
100 */
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
101
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
102 if ((uintptr_t) value & 1) {
140
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
103
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
104 hwc = (ngx_hash_wildcard_t *) ((uintptr_t) value & (uintptr_t) ~3);
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
105
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
106 if (n == 0) {
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
107 if ((uintptr_t) value & 2) {
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
108 return hwc->value;
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
109
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
110 } else {
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
111 return NULL;
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
112 }
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
113 }
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
114
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
115 value = ngx_hash_find_wc_head(hwc, name, n - 1);
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
116
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
117 if (value) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
118 return value;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
119 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
120
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
121 return hwc->value;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
122 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
123
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
124 return value;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
125 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
126
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
127 return hwc->value;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
128 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
129
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
130
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
131 void *
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
132 ngx_hash_find_wc_tail(ngx_hash_wildcard_t *hwc, u_char *name, size_t len)
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
133 {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
134 void *value;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
135 ngx_uint_t i, key;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
136
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
137 #if 0
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
138 ngx_str_t line;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
139
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
140 line.len = len;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
141 line.data = name;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
142 ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, 0, "wct:\"%V\"", &line);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
143 #endif
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
144
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
145 key = 0;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
146
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
147 for (i = 0; i < len; i++) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
148 if (name[i] == '.') {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
149 break;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
150 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
151
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
152 key = ngx_hash(key, name[i]);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
153 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
154
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
155 if (i == len) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
156 return NULL;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
157 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
158
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
159 #if 0
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
160 ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, 0, "key:\"%ui\"", key);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
161 #endif
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
162
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
163 value = ngx_hash_find(&hwc->hash, key, name, i);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
164
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
165 if (value) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
166
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
167 /*
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
168 * the 2 low bits of value have the special meaning:
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
169 * 00 - value is data pointer,
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
170 * 01 - value is pointer to wildcard hash allowing "example.*".
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
171 */
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
172
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
173 if ((uintptr_t) value & 1) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
174
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
175 i++;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
176
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
177 hwc = (ngx_hash_wildcard_t *) ((uintptr_t) value & (uintptr_t) ~3);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
178
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
179 value = ngx_hash_find_wc_tail(hwc, &name[i], len - i);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
180
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
181 if (value) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
182 return value;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
183 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
184
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
185 return hwc->value;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
186 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
187
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
188 return value;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
189 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
190
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
191 return hwc->value;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
192 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
193
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
194
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
195 void *
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
196 ngx_hash_find_combined(ngx_hash_combined_t *hash, ngx_uint_t key, u_char *name,
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
197 size_t len)
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
198 {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
199 void *value;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
200
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
201 if (hash->hash.buckets) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
202 value = ngx_hash_find(&hash->hash, key, name, len);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
203
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
204 if (value) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
205 return value;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
206 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
207 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
208
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
209 if (hash->wc_head && hash->wc_head->hash.buckets) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
210 value = ngx_hash_find_wc_head(hash->wc_head, name, len);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
211
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
212 if (value) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
213 return value;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
214 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
215 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
216
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
217 if (hash->wc_tail && hash->wc_tail->hash.buckets) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
218 value = ngx_hash_find_wc_tail(hash->wc_tail, name, len);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
219
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
220 if (value) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
221 return value;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
222 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
223 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
224
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
225 return NULL;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
226 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
227
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
228
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
229 #define NGX_HASH_ELT_SIZE(name) \
144
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
230 (sizeof(void *) + ngx_align((name)->key.len + 1, sizeof(void *)))
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
231
56
3050baa54a26 nginx 0.1.28
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
232 ngx_int_t
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
233 ngx_hash_init(ngx_hash_init_t *hinit, ngx_hash_key_t *names, ngx_uint_t nelts)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
234 {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
235 u_char *elts;
144
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
236 size_t len;
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
237 u_short *test;
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
238 ngx_uint_t i, n, key, size, start, bucket_size;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
239 ngx_hash_elt_t *elt, **buckets;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
240
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
241 for (n = 0; n < nelts; n++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
242 if (names[n].key.len >= 255) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
243 ngx_log_error(NGX_LOG_EMERG, hinit->pool->log, 0,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
244 "the \"%V\" value to hash is to long: %uz bytes, "
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
245 "the maximum length can be 255 bytes only",
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
246 &names[n].key, names[n].key.len);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
247 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
248 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
249
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
250 if (hinit->bucket_size < NGX_HASH_ELT_SIZE(&names[n]) + sizeof(void *))
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
251 {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
252 ngx_log_error(NGX_LOG_EMERG, hinit->pool->log, 0,
144
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
253 "could not build the %s, you should "
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
254 "increase %s_bucket_size: %i",
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
255 hinit->name, hinit->name, hinit->bucket_size);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
256 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
257 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
258 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
259
144
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
260 test = ngx_alloc(hinit->max_size * sizeof(u_short), hinit->pool->log);
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
261 if (test == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
262 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
263 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
264
180
4cd3e70c4d60 nginx 0.3.37
Igor Sysoev <http://sysoev.ru>
parents: 168
diff changeset
265 bucket_size = hinit->bucket_size - sizeof(void *);
4cd3e70c4d60 nginx 0.3.37
Igor Sysoev <http://sysoev.ru>
parents: 168
diff changeset
266
242
ff906029dd40 nginx 0.4.6
Igor Sysoev <http://sysoev.ru>
parents: 198
diff changeset
267 start = nelts / (bucket_size / (2 * sizeof(void *)));
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
268 start = start ? start : 1;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
269
180
4cd3e70c4d60 nginx 0.3.37
Igor Sysoev <http://sysoev.ru>
parents: 168
diff changeset
270 if (hinit->max_size > 10000 && hinit->max_size / nelts < 100) {
4cd3e70c4d60 nginx 0.3.37
Igor Sysoev <http://sysoev.ru>
parents: 168
diff changeset
271 start = hinit->max_size - 1000;
4cd3e70c4d60 nginx 0.3.37
Igor Sysoev <http://sysoev.ru>
parents: 168
diff changeset
272 }
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
273
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
274 for (size = start; size < hinit->max_size; size++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
275
144
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
276 ngx_memzero(test, size * sizeof(u_short));
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
277
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
278 for (n = 0; n < nelts; n++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
279 if (names[n].key.data == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
280 continue;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
281 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
282
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
283 key = names[n].key_hash % size;
144
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
284 test[key] = (u_short) (test[key] + NGX_HASH_ELT_SIZE(&names[n]));
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
285
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
286 #if 0
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
287 ngx_log_error(NGX_LOG_ALERT, hinit->pool->log, 0,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
288 "%ui: %ui %ui \"%V\"",
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
289 size, key, test[key], &names[n].key);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
290 #endif
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
291
144
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
292 if (test[key] > (u_short) bucket_size) {
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
293 goto next;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
294 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
295 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
296
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
297 goto found;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
298
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
299 next:
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
300
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
301 continue;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
302 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
303
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
304 ngx_log_error(NGX_LOG_EMERG, hinit->pool->log, 0,
144
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
305 "could not build the %s, you should increase "
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
306 "either %s_max_size: %i or %s_bucket_size: %i",
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
307 hinit->name, hinit->name, hinit->max_size,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
308 hinit->name, hinit->bucket_size);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
309
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
310 ngx_free(test);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
311
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
312 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
313
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
314 found:
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
315
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
316 for (i = 0; i < size; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
317 test[i] = sizeof(void *);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
318 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
319
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
320 for (n = 0; n < nelts; n++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
321 if (names[n].key.data == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
322 continue;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
323 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
324
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
325 key = names[n].key_hash % size;
144
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
326 test[key] = (u_short) (test[key] + NGX_HASH_ELT_SIZE(&names[n]));
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
327 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
328
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
329 len = 0;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
330
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
331 for (i = 0; i < size; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
332 if (test[i] == sizeof(void *)) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
333 continue;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
334 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
335
144
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
336 test[i] = (u_short) (ngx_align(test[i], ngx_cacheline_size));
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
337
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
338 len += test[i];
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
339 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
340
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
341 if (hinit->hash == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
342 hinit->hash = ngx_pcalloc(hinit->pool, sizeof(ngx_hash_wildcard_t)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
343 + size * sizeof(ngx_hash_elt_t *));
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
344 if (hinit->hash == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
345 ngx_free(test);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
346 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
347 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
348
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
349 buckets = (ngx_hash_elt_t **)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
350 ((u_char *) hinit->hash + sizeof(ngx_hash_wildcard_t));
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
351
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
352 } else {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
353 buckets = ngx_pcalloc(hinit->pool, size * sizeof(ngx_hash_elt_t *));
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
354 if (buckets == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
355 ngx_free(test);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
356 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
357 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
358 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
359
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
360 elts = ngx_palloc(hinit->pool, len + ngx_cacheline_size);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
361 if (elts == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
362 ngx_free(test);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
363 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
364 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
365
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
366 elts = ngx_align_ptr(elts, ngx_cacheline_size);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
367
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
368 for (i = 0; i < size; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
369 if (test[i] == sizeof(void *)) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
370 continue;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
371 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
372
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
373 buckets[i] = (ngx_hash_elt_t *) elts;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
374 elts += test[i];
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
375
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
376 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
377
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
378 for (i = 0; i < size; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
379 test[i] = 0;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
380 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
381
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
382 for (n = 0; n < nelts; n++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
383 if (names[n].key.data == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
384 continue;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
385 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
386
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
387 key = names[n].key_hash % size;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
388 elt = (ngx_hash_elt_t *) ((u_char *) buckets[key] + test[key]);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
389
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
390 elt->value = names[n].value;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
391 elt->len = (u_char) names[n].key.len;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
392
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
393 for (i = 0; i < names[n].key.len; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
394 elt->name[i] = ngx_tolower(names[n].key.data[i]);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
395 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
396
144
e1c6ac408b68 nginx 0.3.19
Igor Sysoev <http://sysoev.ru>
parents: 142
diff changeset
397 test[key] = (u_short) (test[key] + NGX_HASH_ELT_SIZE(&names[n]));
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
398 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
399
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
400 for (i = 0; i < size; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
401 if (buckets[i] == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
402 continue;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
403 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
404
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
405 elt = (ngx_hash_elt_t *) ((u_char *) buckets[i] + test[i]);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
406
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
407 elt->value = NULL;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
408 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
409
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
410 ngx_free(test);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
411
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
412 hinit->hash->buckets = buckets;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
413 hinit->hash->size = size;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
414
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
415 #if 0
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
416
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
417 for (i = 0; i < size; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
418 ngx_str_t val;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
419 ngx_uint_t key;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
420
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
421 elt = buckets[i];
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
422
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
423 if (elt == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
424 ngx_log_error(NGX_LOG_ALERT, hinit->pool->log, 0,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
425 "%ui: NULL", i);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
426 continue;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
427 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
428
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
429 while (elt->value) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
430 val.len = elt->len;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
431 val.data = &elt->name[0];
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
432
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
433 key = hinit->key(val.data, val.len);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
434
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
435 ngx_log_error(NGX_LOG_ALERT, hinit->pool->log, 0,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
436 "%ui: %p \"%V\" %ui", i, elt, &val, key);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
437
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
438 elt = (ngx_hash_elt_t *) ngx_align_ptr(&elt->name[0] + elt->len,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
439 sizeof(void *));
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
440 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
441 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
442
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
443 #endif
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
444
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
445 return NGX_OK;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
446 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
447
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
448
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
449 ngx_int_t
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
450 ngx_hash_wildcard_init(ngx_hash_init_t *hinit, ngx_hash_key_t *names,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
451 ngx_uint_t nelts)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
452 {
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
453 size_t len, dot_len;
140
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
454 ngx_uint_t i, n, dot;
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
455 ngx_array_t curr_names, next_names;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
456 ngx_hash_key_t *name, *next_name;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
457 ngx_hash_init_t h;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
458 ngx_hash_wildcard_t *wdc;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
459
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
460 if (ngx_array_init(&curr_names, hinit->temp_pool, nelts,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
461 sizeof(ngx_hash_key_t))
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
462 != NGX_OK)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
463 {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
464 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
465 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
466
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
467 if (ngx_array_init(&next_names, hinit->temp_pool, nelts,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
468 sizeof(ngx_hash_key_t))
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
469 != NGX_OK)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
470 {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
471 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
472 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
473
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
474 for (n = 0; n < nelts; n = i) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
475
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
476 #if 0
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
477 ngx_log_error(NGX_LOG_ALERT, hinit->pool->log, 0,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
478 "wc0: \"%V\"", &names[n].key);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
479 #endif
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
480
140
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
481 dot = 0;
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
482
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
483 for (len = 0; len < names[n].key.len; len++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
484 if (names[n].key.data[len] == '.') {
140
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
485 dot = 1;
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
486 break;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
487 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
488 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
489
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
490 name = ngx_array_push(&curr_names);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
491 if (name == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
492 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
493 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
494
140
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
495 name->key.len = len;
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
496 name->key.data = names[n].key.data;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
497 name->key_hash = hinit->key(name->key.data, name->key.len);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
498 name->value = names[n].value;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
499
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
500 #if 0
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
501 ngx_log_error(NGX_LOG_ALERT, hinit->pool->log, 0,
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
502 "wc1: \"%V\" %ui", &name->key, dot);
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
503 #endif
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
504
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
505 dot_len = len + 1;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
506
140
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
507 if (dot) {
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
508 len++;
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
509 }
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
510
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
511 next_names.nelts = 0;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
512
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
513 if (names[n].key.len != len) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
514 next_name = ngx_array_push(&next_names);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
515 if (next_name == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
516 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
517 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
518
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
519 next_name->key.len = names[n].key.len - len;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
520 next_name->key.data = names[n].key.data + len;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
521 next_name->key_hash= 0;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
522 next_name->value = names[n].value;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
523
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
524 #if 0
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
525 ngx_log_error(NGX_LOG_ALERT, hinit->pool->log, 0,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
526 "wc2: \"%V\"", &next_name->key);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
527 #endif
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
528 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
529
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
530 for (i = n + 1; i < nelts; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
531 if (ngx_strncmp(names[n].key.data, names[i].key.data, len) != 0) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
532 break;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
533 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
534
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
535 if (!dot
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
536 && names[i].key.len > len
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
537 && names[i].key.data[len] != '.')
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
538 {
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
539 break;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
540 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
541
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
542 next_name = ngx_array_push(&next_names);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
543 if (next_name == NULL) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
544 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
545 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
546
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
547 next_name->key.len = names[i].key.len - dot_len;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
548 next_name->key.data = names[i].key.data + dot_len;
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
549 next_name->key_hash= 0;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
550 next_name->value = names[i].value;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
551
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
552 #if 0
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
553 ngx_log_error(NGX_LOG_ALERT, hinit->pool->log, 0,
140
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
554 "wc3: \"%V\"", &next_name->key);
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
555 #endif
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
556 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
557
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
558 if (next_names.nelts) {
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
559
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
560 h = *hinit;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
561 h.hash = NULL;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
562
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
563 if (ngx_hash_wildcard_init(&h, (ngx_hash_key_t *) next_names.elts,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
564 next_names.nelts)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
565 != NGX_OK)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
566 {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
567 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
568 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
569
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
570 wdc = (ngx_hash_wildcard_t *) h.hash;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
571
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
572 if (names[n].key.len == len) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
573 wdc->value = names[n].value;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
574 #if 0
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
575 ngx_log_error(NGX_LOG_ALERT, hinit->pool->log, 0,
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
576 "wdc: \"%V\"", wdc->value);
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
577 #endif
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
578 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
579
140
55a211e5eeb7 nginx 0.3.17
Igor Sysoev <http://sysoev.ru>
parents: 138
diff changeset
580 name->value = (void *) ((uintptr_t) wdc | (dot ? 1 : 3));
138
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
581 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
582 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
583
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
584 if (ngx_hash_init(hinit, (ngx_hash_key_t *) curr_names.elts,
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
585 curr_names.nelts)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
586 != NGX_OK)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
587 {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
588 return NGX_ERROR;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
589 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
590
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
591 return NGX_OK;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
592 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
593
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
594
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
595 ngx_uint_t
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
596 ngx_hash_key(u_char *data, size_t len)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
597 {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
598 ngx_uint_t i, key;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
599
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
600 key = 0;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
601
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
602 for (i = 0; i < len; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
603 key = ngx_hash(key, data[i]);
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
604 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
605
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
606 return key;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
607 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
608
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
609
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
610 ngx_uint_t
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
611 ngx_hash_key_lc(u_char *data, size_t len)
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
612 {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
613 ngx_uint_t i, key;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
614
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
615 key = 0;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
616
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
617 for (i = 0; i < len; i++) {
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
618 key = ngx_hash(key, ngx_tolower(data[i]));
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
619 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
620
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
621 return key;
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
622 }
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
623
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
624
8e6d4d96ec4c nginx 0.3.16
Igor Sysoev <http://sysoev.ru>
parents: 132
diff changeset
625 ngx_int_t
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
626 ngx_hash_keys_array_init(ngx_hash_keys_arrays_t *ha, ngx_uint_t type)
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
627 {
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
628 ngx_uint_t asize;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
629
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
630 if (type == NGX_HASH_SMALL) {
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
631 asize = 4;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
632 ha->hsize = 107;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
633
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
634 } else {
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
635 asize = NGX_HASH_LARGE_ASIZE;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
636 ha->hsize = NGX_HASH_LARGE_HSIZE;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
637 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
638
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
639 if (ngx_array_init(&ha->keys, ha->temp_pool, asize, sizeof(ngx_hash_key_t))
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
640 != NGX_OK)
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
641 {
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
642 return NGX_ERROR;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
643 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
644
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
645 if (ngx_array_init(&ha->dns_wc_head, ha->temp_pool, asize,
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
646 sizeof(ngx_hash_key_t))
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
647 != NGX_OK)
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
648 {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
649 return NGX_ERROR;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
650 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
651
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
652 if (ngx_array_init(&ha->dns_wc_tail, ha->temp_pool, asize,
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
653 sizeof(ngx_hash_key_t))
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
654 != NGX_OK)
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
655 {
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
656 return NGX_ERROR;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
657 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
658
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
659 ha->keys_hash = ngx_pcalloc(ha->temp_pool, sizeof(ngx_array_t) * ha->hsize);
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
660 if (ha->keys_hash == NULL) {
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
661 return NGX_ERROR;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
662 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
663
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
664 ha->dns_wc_head_hash = ngx_pcalloc(ha->temp_pool,
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
665 sizeof(ngx_array_t) * ha->hsize);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
666 if (ha->dns_wc_head_hash == NULL) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
667 return NGX_ERROR;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
668 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
669
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
670 ha->dns_wc_tail_hash = ngx_pcalloc(ha->temp_pool,
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
671 sizeof(ngx_array_t) * ha->hsize);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
672 if (ha->dns_wc_tail_hash == NULL) {
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
673 return NGX_ERROR;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
674 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
675
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
676 return NGX_OK;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
677 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
678
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
679
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
680 ngx_int_t
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
681 ngx_hash_add_key(ngx_hash_keys_arrays_t *ha, ngx_str_t *key, void *value,
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
682 ngx_uint_t flags)
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
683 {
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
684 size_t len;
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
685 u_char *p;
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
686 ngx_str_t *name;
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
687 ngx_uint_t i, k, n, skip, last;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
688 ngx_array_t *keys, *hwc;
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
689 ngx_hash_key_t *hk;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
690
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
691 last = key->len;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
692
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
693 if (flags & NGX_HASH_WILDCARD_KEY) {
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
694
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
695 /*
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
696 * supported wildcards:
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
697 * "*.example.com", ".example.com", and "www.example.*"
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
698 */
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
699
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
700 n = 0;
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
701
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
702 for (i = 0; i < key->len; i++) {
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
703
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
704 if (key->data[i] == '*') {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
705 if (++n > 1) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
706 return NGX_DECLINED;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
707 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
708 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
709
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
710 if (key->data[i] == '.' && key->data[i + 1] == '.') {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
711 return NGX_DECLINED;
146
36af50a5582d nginx 0.3.20
Igor Sysoev <http://sysoev.ru>
parents: 144
diff changeset
712 }
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
713 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
714
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
715 if (key->len > 1 && key->data[0] == '.') {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
716 skip = 1;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
717 goto wildcard;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
718 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
719
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
720 if (key->len > 2) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
721
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
722 if (key->data[0] == '*' && key->data[1] == '.') {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
723 skip = 2;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
724 goto wildcard;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
725 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
726
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
727 if (key->data[i - 2] == '.' && key->data[i - 1] == '*') {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
728 skip = 0;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
729 last -= 2;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
730 goto wildcard;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
731 }
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
732 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
733
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
734 if (n) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
735 return NGX_DECLINED;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
736 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
737 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
738
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
739 /* exact hash */
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
740
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
741 k = 0;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
742
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
743 for (i = 0; i < last; i++) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
744 if (!(flags & NGX_HASH_READONLY_KEY)) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
745 key->data[i] = ngx_tolower(key->data[i]);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
746 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
747 k = ngx_hash(k, key->data[i]);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
748 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
749
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
750 k %= ha->hsize;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
751
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
752 /* check conflicts in exact hash */
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
753
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
754 name = ha->keys_hash[k].elts;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
755
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
756 if (name) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
757 for (i = 0; i < ha->keys_hash[k].nelts; i++) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
758 if (last != name[i].len) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
759 continue;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
760 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
761
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
762 if (ngx_strncmp(key->data, name[i].data, last) == 0) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
763 return NGX_BUSY;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
764 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
765 }
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
766
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
767 } else {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
768 if (ngx_array_init(&ha->keys_hash[k], ha->temp_pool, 4,
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
769 sizeof(ngx_str_t))
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
770 != NGX_OK)
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
771 {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
772 return NGX_ERROR;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
773 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
774 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
775
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
776 name = ngx_array_push(&ha->keys_hash[k]);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
777 if (name == NULL) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
778 return NGX_ERROR;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
779 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
780
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
781 *name = *key;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
782
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
783 hk = ngx_array_push(&ha->keys);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
784 if (hk == NULL) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
785 return NGX_ERROR;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
786 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
787
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
788 hk->key = *key;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
789 hk->key_hash = ngx_hash_key(key->data, last);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
790 hk->value = value;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
791
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
792 return NGX_OK;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
793
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
794
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
795 wildcard:
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
796
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
797 /* wildcard hash */
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
798
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
799 k = 0;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
800
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
801 for (i = skip; i < last; i++) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
802 key->data[i] = ngx_tolower(key->data[i]);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
803 k = ngx_hash(k, key->data[i]);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
804 }
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
805
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
806 k %= ha->hsize;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
807
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
808 if (skip == 1) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
809
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
810 /* check conflicts in exact hash for ".example.com" */
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
811
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
812 name = ha->keys_hash[k].elts;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
813
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
814 if (name) {
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
815 len = last - skip;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
816
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
817 for (i = 0; i < ha->keys_hash[k].nelts; i++) {
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
818 if (len != name[i].len) {
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
819 continue;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
820 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
821
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
822 if (ngx_strncmp(&key->data[1], name[i].data, len) == 0) {
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
823 return NGX_BUSY;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
824 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
825 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
826
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
827 } else {
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
828 if (ngx_array_init(&ha->keys_hash[k], ha->temp_pool, 4,
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
829 sizeof(ngx_str_t))
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
830 != NGX_OK)
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
831 {
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
832 return NGX_ERROR;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
833 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
834 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
835
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
836 name = ngx_array_push(&ha->keys_hash[k]);
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
837 if (name == NULL) {
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
838 return NGX_ERROR;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
839 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
840
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
841 name->len = last - 1;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
842 name->data = ngx_palloc(ha->temp_pool, name->len);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
843 if (name->data == NULL) {
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
844 return NGX_ERROR;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
845 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
846
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
847 ngx_memcpy(name->data, &key->data[1], name->len);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
848 }
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
849
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
850
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
851 if (skip) {
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
852
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
853 /*
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
854 * convert "*.example.com" to "com.example.\0"
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
855 * and ".example.com" to "com.example\0"
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
856 */
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
857
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
858 p = ngx_palloc(ha->temp_pool, last);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
859 if (p == NULL) {
168
3314be145cb9 nginx 0.3.31
Igor Sysoev <http://sysoev.ru>
parents: 146
diff changeset
860 return NGX_ERROR;
3314be145cb9 nginx 0.3.31
Igor Sysoev <http://sysoev.ru>
parents: 146
diff changeset
861 }
3314be145cb9 nginx 0.3.31
Igor Sysoev <http://sysoev.ru>
parents: 146
diff changeset
862
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
863 len = 0;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
864 n = 0;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
865
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
866 for (i = last - 1; i; i--) {
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
867 if (key->data[i] == '.') {
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
868 ngx_memcpy(&p[n], &key->data[i + 1], len);
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
869 n += len;
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
870 p[n++] = '.';
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
871 len = 0;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
872 continue;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
873 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
874
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
875 len++;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
876 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
877
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
878 if (len) {
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
879 ngx_memcpy(&p[n], &key->data[1], len);
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
880 n += len;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
881 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
882
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
883 p[n] = '\0';
168
3314be145cb9 nginx 0.3.31
Igor Sysoev <http://sysoev.ru>
parents: 146
diff changeset
884
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
885 hwc = &ha->dns_wc_head;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
886 keys = &ha->dns_wc_head_hash[k];
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
887
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
888 } else {
168
3314be145cb9 nginx 0.3.31
Igor Sysoev <http://sysoev.ru>
parents: 146
diff changeset
889
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
890 /* convert "www.example.*" to "www.example\0" */
168
3314be145cb9 nginx 0.3.31
Igor Sysoev <http://sysoev.ru>
parents: 146
diff changeset
891
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
892 p = key->data;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
893 key->data[last] = '\0';
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
894 last++;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
895
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
896 hwc = &ha->dns_wc_tail;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
897 keys = &ha->dns_wc_tail_hash[k];
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
898 }
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
899
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
900
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
901 hk = ngx_array_push(hwc);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
902 if (hk == NULL) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
903 return NGX_ERROR;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
904 }
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
905
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
906 hk->key.len = last - 1;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
907 hk->key.data = p;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
908 hk->key_hash = 0;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
909 hk->value = value;
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
910
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
911
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
912 /* check conflicts in wildcard hash */
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
913
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
914 name = keys->elts;
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
915
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
916 if (name) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
917 len = last - skip;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
918
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
919 for (i = 0; i < keys->nelts; i++) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
920 if (len != name[i].len) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
921 continue;
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
922 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
923
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
924 if (ngx_strncmp(key->data + skip, name[i].data, len) == 0) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
925 return NGX_BUSY;
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
926 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
927 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
928
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
929 } else {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
930 if (ngx_array_init(keys, ha->temp_pool, 4, sizeof(ngx_str_t)) != NGX_OK)
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
931 {
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
932 return NGX_ERROR;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
933 }
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
934 }
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
935
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
936 name = ngx_array_push(keys);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
937 if (name == NULL) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
938 return NGX_ERROR;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
939 }
168
3314be145cb9 nginx 0.3.31
Igor Sysoev <http://sysoev.ru>
parents: 146
diff changeset
940
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
941 name->len = last - skip;
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
942 name->data = ngx_palloc(ha->temp_pool, name->len);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
943 if (name->data == NULL) {
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
944 return NGX_ERROR;
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
945 }
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
946
312
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
947 ngx_memcpy(name->data, key->data + skip, name->len);
429900ca25ee nginx 0.6.0
Igor Sysoev <http://sysoev.ru>
parents: 242
diff changeset
948
142
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
949 return NGX_OK;
84910468f6de nginx 0.3.18
Igor Sysoev <http://sysoev.ru>
parents: 140
diff changeset
950 }