Mercurial > hg > nginx-vendor-1-0
annotate src/core/ngx_radix_tree.h @ 622:8dc007eddbcf NGINX_1_0_1
nginx 1.0.1
*) Change: now the "split_clients" directive uses MurmurHash2 algorithm
because of better distribution.
Thanks to Oleg Mamontov.
*) Change: now long strings starting with zero are not considered as
false values.
Thanks to Maxim Dounin.
*) Change: now nginx uses a default listen backlog value 511 on Linux.
*) Feature: the $upstream_... variables may be used in the SSI and perl
modules.
*) Bugfix: now nginx limits better disk cache size.
Thanks to Oleg Mamontov.
*) Bugfix: a segmentation fault might occur while parsing incorrect
IPv4 address; the bug had appeared in 0.9.3.
Thanks to Maxim Dounin.
*) Bugfix: nginx could not be built by gcc 4.6 without --with-debug
option.
*) Bugfix: nginx could not be built on Solaris 9 and earlier; the bug
had appeared in 0.9.3.
Thanks to Dagobert Michelsen.
*) Bugfix: $request_time variable had invalid values if subrequests
were used; the bug had appeared in 0.8.47.
Thanks to Igor A. Valcov.
author | Igor Sysoev <http://sysoev.ru> |
---|---|
date | Tue, 03 May 2011 00:00:00 +0400 |
parents | 2879cd3a40cb |
children | ad25218fd14b |
rev | line source |
---|---|
34 | 1 |
2 /* | |
3 * Copyright (C) Igor Sysoev | |
4 */ | |
5 | |
6 | |
7 #ifndef _NGX_RADIX_TREE_H_INCLUDED_ | |
8 #define _NGX_RADIX_TREE_H_INCLUDED_ | |
9 | |
10 | |
11 #include <ngx_config.h> | |
12 #include <ngx_core.h> | |
13 | |
14 | |
15 #define NGX_RADIX_NO_VALUE (uintptr_t) -1 | |
16 | |
17 typedef struct ngx_radix_node_s ngx_radix_node_t; | |
18 | |
19 struct ngx_radix_node_s { | |
20 ngx_radix_node_t *right; | |
21 ngx_radix_node_t *left; | |
22 ngx_radix_node_t *parent; | |
23 uintptr_t value; | |
24 }; | |
25 | |
26 | |
27 typedef struct { | |
28 ngx_radix_node_t *root; | |
29 ngx_pool_t *pool; | |
30 ngx_radix_node_t *free; | |
31 char *start; | |
32 size_t size; | |
33 } ngx_radix_tree_t; | |
34 | |
35 | |
36 | 36 ngx_radix_tree_t *ngx_radix_tree_create(ngx_pool_t *pool, |
38 | 37 ngx_int_t preallocate); |
34 | 38 ngx_int_t ngx_radix32tree_insert(ngx_radix_tree_t *tree, |
36 | 39 uint32_t key, uint32_t mask, uintptr_t value); |
34 | 40 ngx_int_t ngx_radix32tree_delete(ngx_radix_tree_t *tree, |
36 | 41 uint32_t key, uint32_t mask); |
34 | 42 uintptr_t ngx_radix32tree_find(ngx_radix_tree_t *tree, uint32_t key); |
43 | |
44 | |
45 #endif /* _NGX_RADIX_TREE_H_INCLUDED_ */ |