annotate src/core/ngx_queue.h @ 553:63dde5a94756

Added tag NGINX_0_8_28 for changeset 43e02819c5cf
author Igor Sysoev <http://sysoev.ru>
date Mon, 23 Nov 2009 00:00:00 +0300
parents 820f6378fc00
children d0f7a625f27c
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
348
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
1
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
2 /*
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
3 * Copyright (C) Igor Sysoev
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
4 */
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
5
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
6
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
7 #include <ngx_config.h>
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
8 #include <ngx_core.h>
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
9
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
10
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
11 #ifndef _NGX_QUEUE_H_INCLUDED_
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
12 #define _NGX_QUEUE_H_INCLUDED_
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
13
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
14
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
15 typedef struct ngx_queue_s ngx_queue_t;
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
16
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
17 struct ngx_queue_s {
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
18 ngx_queue_t *prev;
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
19 ngx_queue_t *next;
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
20 };
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
21
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
22
354
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents: 348
diff changeset
23 #define ngx_queue_init(q) \
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents: 348
diff changeset
24 (q)->prev = q; \
358
9121a0a91f47 nginx 0.6.23
Igor Sysoev <http://sysoev.ru>
parents: 354
diff changeset
25 (q)->next = q
354
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents: 348
diff changeset
26
583decdb82a4 nginx 0.6.21
Igor Sysoev <http://sysoev.ru>
parents: 348
diff changeset
27
348
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
28 #define ngx_queue_empty(h) \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
29 (h == (h)->prev)
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
30
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
31
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
32 #define ngx_queue_insert_head(h, x) \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
33 (x)->next = (h)->next; \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
34 (x)->next->prev = x; \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
35 (x)->prev = h; \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
36 (h)->next = x
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
37
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
38
378
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
39 #define ngx_queue_insert_after ngx_queue_insert_head
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
40
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
41
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
42 #define ngx_queue_insert_tail(h, x) \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
43 (x)->prev = (h)->prev; \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
44 (x)->prev->next = x; \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
45 (x)->next = h; \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
46 (h)->prev = x
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
47
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
48
348
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
49 #define ngx_queue_head(h) \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
50 (h)->next
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
51
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
52
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
53 #define ngx_queue_last(h) \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
54 (h)->prev
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
55
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
56
378
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
57 #define ngx_queue_sentinel(h) \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
58 (h)
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
59
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
60
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
61 #define ngx_queue_next(q) \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
62 (q)->next
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
63
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
64
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
65 #define ngx_queue_prev(q) \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
66 (q)->prev
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
67
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
68
348
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
69 #if (NGX_DEBUG)
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
70
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
71 #define ngx_queue_remove(x) \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
72 (x)->next->prev = (x)->prev; \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
73 (x)->prev->next = (x)->next; \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
74 (x)->prev = NULL; \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
75 (x)->next = NULL
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
76
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
77 #else
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
78
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
79 #define ngx_queue_remove(x) \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
80 (x)->next->prev = (x)->prev; \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
81 (x)->prev->next = (x)->next
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
82
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
83 #endif
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
84
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
85
378
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
86 #define ngx_queue_split(h, q, n) \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
87 (n)->prev = (h)->prev; \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
88 (n)->prev->next = n; \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
89 (n)->next = q; \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
90 (h)->prev = (q)->prev; \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
91 (h)->prev->next = h; \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
92 (q)->prev = n;
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
93
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
94
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
95 #define ngx_queue_add(h, n) \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
96 (h)->prev->next = (n)->next; \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
97 (n)->next->prev = (h)->prev; \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
98 (h)->prev = (n)->prev; \
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
99 (h)->prev->next = h;
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
100
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
101
348
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
102 #define ngx_queue_data(q, type, link) \
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
103 (type *) ((u_char *) q - offsetof(type, link))
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
104
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
105
378
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
106 ngx_queue_t *ngx_queue_middle(ngx_queue_t *queue);
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
107 void ngx_queue_sort(ngx_queue_t *queue,
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
108 ngx_int_t (*cmp)(const ngx_queue_t *, const ngx_queue_t *));
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
109
820f6378fc00 nginx 0.7.1
Igor Sysoev <http://sysoev.ru>
parents: 358
diff changeset
110
348
e10168d6e371 nginx 0.6.18
Igor Sysoev <http://sysoev.ru>
parents:
diff changeset
111 #endif /* _NGX_QUEUE_H_INCLUDED_ */