103static tr_node* node_new(
void* key);
116 tree->prio_func = prio_func;
130 dct->
_vtable = &tr_tree_vtable;
147 parent = node; node = node->
llink;
148 }
else if (cmp > 0) {
149 parent = node; node = node->
rlink;
154 if (!(node = node_new(key)))
156 node->
prio =
tree->prio_func ?
tree->prio_func(key) : dict_rand();
158 if (!(node->
parent = parent)) {
164 parent->
llink = node;
166 parent->
rlink = node;
168 unsigned rotations = 0;
171 if (parent->
llink == node)
175 if (!(parent = node->
parent))
187 unsigned rotations = 0;
214 remove_node(
tree, node);
256 if (parent->
llink == node) {
263 if (!node_verify(
tree, node, node->
llink) ||
301 itor->
_vtable = &tr_tree_itor_vtable;
dict_remove_result(* dict_remove_func)(void *obj, const void *key)
int(* dict_compare_func)(const void *, const void *)
bool(* dict_select_func)(void *obj, size_t n, const void **key, void **datum)
void(* dict_invalidate_func)(void *itor)
size_t(* dict_traverse_func)(void *obj, dict_visit_func visit, void *user_data)
dict_insert_result(* dict_insert_func)(void *obj, void *key)
void(* dict_delete_func)(void *, void *)
int(* dict_icompare_func)(void *itor1, void *itor2)
bool(* dict_nextn_func)(void *itor, size_t count)
bool(* dict_valid_func)(const void *itor)
size_t(* dict_count_func)(const void *obj)
bool(* dict_first_func)(void *itor)
bool(* dict_next_func)(void *itor)
void *(* dict_key_func)(void *itor)
size_t(* dict_dfree_func)(void *obj, dict_delete_func delete_func)
void **(* dict_datum_func)(void *itor)
bool(* dict_prevn_func)(void *itor, size_t count)
void **(* dict_search_func)(void *obj, const void *key)
bool(* dict_isearch_func)(void *itor, const void *key)
unsigned(* dict_prio_func)(const void *)
bool(* dict_iremove_func)(void *itor)
bool(* dict_prev_func)(void *itor)
dict_itor *(* dict_inew_func)(void *obj)
bool(* dict_last_func)(void *itor)
bool(* dict_verify_func)(const void *obj)
bool(* dict_visit_func)(const void *, void *, void *)
size_t(* dict_clear_func)(void *obj, dict_delete_func delete_func)
void(* dict_ifree_func)(void *itor)
const itor_vtable * _vtable
const dict_vtable * _vtable
dict_compare_func cmp_func
void ** tr_itor_datum(tr_itor *itor)
bool tr_itor_search_le(tr_itor *itor, const void *key)
dict_itor * tr_dict_itor_new(tr_tree *tree)
dict_remove_result tr_tree_remove(tr_tree *tree, const void *key)
bool tr_itor_remove(tr_itor *it)
size_t tr_tree_total_path_length(const tr_tree *tree)
void tr_itor_invalidate(tr_itor *itor)
tr_tree * tr_tree_new(dict_compare_func cmp_func, dict_prio_func prio_func)
bool tr_tree_select(tr_tree *tree, size_t n, const void **key, void **datum)
bool tr_itor_last(tr_itor *itor)
bool tr_itor_search_lt(tr_itor *itor, const void *key)
void ** tr_tree_search_le(tr_tree *tree, const void *key)
bool tr_itor_nextn(tr_itor *itor, size_t count)
size_t tr_tree_clear(tr_tree *tree, dict_delete_func delete_func)
bool tr_itor_next(tr_itor *itor)
size_t tr_tree_traverse(tr_tree *tree, dict_visit_func visit, void *user_data)
size_t tr_tree_free(tr_tree *tree, dict_delete_func delete_func)
bool tr_itor_first(tr_itor *itor)
tr_itor * tr_itor_new(tr_tree *tree)
bool tr_itor_prev(tr_itor *itor)
bool tr_itor_search_ge(tr_itor *itor, const void *key)
size_t tr_tree_min_path_length(const tr_tree *tree)
bool tr_itor_search_gt(tr_itor *itor, const void *key)
const void * tr_itor_key(const tr_itor *itor)
bool tr_itor_valid(const tr_itor *itor)
bool tr_tree_verify(const tr_tree *tree)
bool tr_itor_prevn(tr_itor *itor, size_t count)
void tr_itor_free(tr_itor *itor)
dict * tr_dict_new(dict_compare_func cmp_func, dict_prio_func prio_func)
size_t tr_tree_count(const tr_tree *tree)
int tr_itor_compare(const tr_itor *i1, const tr_itor *i2)
void ** tr_tree_search_lt(tr_tree *tree, const void *key)
void ** tr_tree_search_ge(tr_tree *tree, const void *key)
void ** tr_tree_search_gt(tr_tree *tree, const void *key)
dict_insert_result tr_tree_insert(tr_tree *tree, void *key)
bool tr_itor_search(tr_itor *itor, const void *key)
size_t tr_tree_max_path_length(const tr_tree *tree)
void ** tr_tree_search(tr_tree *tree, const void *key)
bool tree_iterator_last(void *Iterator)
size_t tree_free(void *Tree, dict_delete_func delete_func)
void ** tree_iterator_datum(void *Iterator)
bool tree_iterator_next(void *Iterator)
void tree_iterator_invalidate(void *Iterator)
void ** tree_search_gt(void *Tree, const void *key)
int tree_iterator_compare(const void *Iterator1, const void *Iterator2)
void tree_node_rot_left(void *Tree, void *Node)
void * tree_search_node(void *Tree, const void *key)
bool tree_iterator_search_le(void *Iterator, const void *key)
bool tree_iterator_valid(const void *Iterator)
size_t tree_count(const void *Tree)
void ** tree_search_lt(void *Tree, const void *key)
size_t tree_clear(void *Tree, dict_delete_func delete_func)
const void * tree_iterator_key(const void *Iterator)
size_t tree_min_path_length(const void *Tree)
void ** tree_search(void *Tree, const void *key)
bool tree_iterator_nextn(void *Iterator, size_t count)
size_t tree_traverse(void *Tree, dict_visit_func visit, void *user_data)
size_t tree_total_path_length(const void *Tree)
bool tree_iterator_first(void *Iterator)
bool tree_select(void *Tree, size_t n, const void **key, void **datum)
void tree_iterator_free(void *Iterator)
bool tree_iterator_prevn(void *Iterator, size_t count)
bool tree_iterator_search_lt(void *Iterator, const void *key)
bool tree_iterator_search_ge(void *Iterator, const void *key)
size_t tree_max_path_length(const void *Tree)
bool tree_iterator_search_gt(void *Iterator, const void *key)
void ** tree_search_ge(void *Tree, const void *key)
void tree_node_rot_right(void *Tree, void *Node)
void ** tree_search_le(void *Tree, const void *key)
bool tree_iterator_search(void *Iterator, const void *key)
bool tree_iterator_prev(void *Iterator)
#define TREE_NODE_FIELDS(node_type)
#define TREE_ITERATOR_FIELDS(tree_type, node_type)
#define TREE_FIELDS(node_type)