diff options
author | Igor Sysoev <igor@sysoev.ru> | 2017-01-17 20:00:00 +0300 |
---|---|---|
committer | Igor Sysoev <igor@sysoev.ru> | 2017-01-17 20:00:00 +0300 |
commit | 16cbf3c076a0aca6d47adaf3f719493674cf2363 (patch) | |
tree | e6530480020f62a2bdbf249988ec3e2a751d3927 /test/nxt_rbtree1.h | |
download | unit-16cbf3c076a0aca6d47adaf3f719493674cf2363.tar.gz unit-16cbf3c076a0aca6d47adaf3f719493674cf2363.tar.bz2 |
Initial version.
Diffstat (limited to '')
-rw-r--r-- | test/nxt_rbtree1.h | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/test/nxt_rbtree1.h b/test/nxt_rbtree1.h new file mode 100644 index 00000000..60048dad --- /dev/null +++ b/test/nxt_rbtree1.h @@ -0,0 +1,73 @@ + +/* + * Copyright (C) Igor Sysoev + * Copyright (C) Nginx, Inc. + */ + + +typedef nxt_uint_t nxt_rbtree1_key_t; +typedef nxt_int_t nxt_rbtree1_key_int_t; + + +typedef struct nxt_rbtree1_node_s nxt_rbtree1_node_t; + +struct nxt_rbtree1_node_s { + nxt_rbtree1_key_t key; + nxt_rbtree1_node_t *left; + nxt_rbtree1_node_t *right; + nxt_rbtree1_node_t *parent; + u_char color; + u_char data; +}; + + +typedef struct nxt_rbtree1_s nxt_rbtree1_t; + +typedef void (*nxt_rbtree1_insert_pt) (nxt_rbtree1_node_t *root, + nxt_rbtree1_node_t *node, nxt_rbtree1_node_t *sentinel); + +struct nxt_rbtree1_s { + nxt_rbtree1_node_t *root; + nxt_rbtree1_node_t *sentinel; + nxt_rbtree1_insert_pt insert; +}; + + +#define nxt_rbtree1_init(tree, s, i) \ + nxt_rbtree1_sentinel_init(s); \ + (tree)->root = s; \ + (tree)->sentinel = s; \ + (tree)->insert = i + + +NXT_EXPORT void nxt_rbtree1_insert(nxt_rbtree1_t *tree, + nxt_rbtree1_node_t *node); +NXT_EXPORT void nxt_rbtree1_delete(nxt_rbtree1_t *tree, + nxt_rbtree1_node_t *node); +NXT_EXPORT void nxt_rbtree1_insert_value(nxt_rbtree1_node_t *root, + nxt_rbtree1_node_t *node, nxt_rbtree1_node_t *sentinel); +NXT_EXPORT void nxt_rbtree1_insert_timer_value(nxt_rbtree1_node_t *root, + nxt_rbtree1_node_t *node, nxt_rbtree1_node_t *sentinel); + + +#define nxt_rbtree1_red(node) ((node)->color = 1) +#define nxt_rbtree1_black(node) ((node)->color = 0) +#define nxt_rbtree1_is_red(node) ((node)->color) +#define nxt_rbtree1_is_black(node) (!nxt_rbtree1_is_red(node)) +#define nxt_rbtree1_copy_color(n1, n2) (n1->color = n2->color) + + +/* a sentinel must be black */ + +#define nxt_rbtree1_sentinel_init(node) nxt_rbtree1_black(node) + + +nxt_inline nxt_rbtree1_node_t * +nxt_rbtree1_min(nxt_rbtree1_node_t *node, nxt_rbtree1_node_t *sentinel) +{ + while (node->left != sentinel) { + node = node->left; + } + + return node; +} |