43#define WEIGHT(n) ((n) ? (n)->weight : 1)
95static pr_node* node_new(
void* key);
121 dct->
_vtable = &pr_tree_vtable;
164 unsigned rotations = 0;
167 if (lweight < rweight) {
171 rot_left(
tree, node);
173 rotations += fixup(
tree, node);
176 rotations += fixup(
tree, r);
187 if ((node->
rlink = a) != NULL)
193 if ((r->
llink = b) != NULL)
204 rotations += fixup(
tree, r);
205 rotations += fixup(
tree, node);
207 }
else if (lweight > rweight) {
211 rot_right(
tree, node);
213 rotations += fixup(
tree, node);
216 rotations += fixup(
tree, l);
227 if ((l->
rlink = a) != NULL)
233 if ((node->
llink = b) != NULL)
244 rotations += fixup(
tree, l);
245 rotations += fixup(
tree, node);
260 parent = node; node = node->
llink;
261 }
else if (cmp > 0) {
262 parent = node; node = node->
rlink;
270 if (!(add->
parent = parent)) {
280 unsigned rotations = 0;
281 while ((node = parent) != NULL) {
284 rotations += fixup(
tree, node);
317 unsigned rotations = 0;
321 rotations += fixup(
tree, parent);
334 remove_node(
tree, node);
364 *datum = node->
datum;
454 if (parent->
llink == node) {
463 if (!node_verify(
tree, node, l) ||
464 !node_verify(
tree, node, r))
466 unsigned lweight =
WEIGHT(l);
467 unsigned rweight =
WEIGHT(r);
469 if (r && rweight > lweight) {
472 }
else if (l && lweight > rweight) {
511 itor->
_vtable = &pr_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)
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)
pr_tree * pr_tree_new(dict_compare_func cmp_func)
size_t pr_tree_max_path_length(const pr_tree *tree)
dict * pr_dict_new(dict_compare_func cmp_func)
void ** pr_tree_search_gt(pr_tree *tree, const void *key)
void ** pr_tree_search_lt(pr_tree *tree, const void *key)
const void * pr_itor_key(const pr_itor *itor)
bool pr_itor_next(pr_itor *itor)
dict_itor * pr_dict_itor_new(pr_tree *tree)
dict_insert_result pr_tree_insert(pr_tree *tree, void *key)
size_t pr_tree_traverse(pr_tree *tree, dict_visit_func visit, void *user_data)
bool pr_itor_prevn(pr_itor *itor, size_t count)
bool pr_itor_remove(pr_itor *it)
bool pr_itor_nextn(pr_itor *itor, size_t count)
dict_remove_result pr_tree_remove(pr_tree *tree, const void *key)
void pr_itor_free(pr_itor *itor)
bool pr_itor_valid(const pr_itor *itor)
void ** pr_tree_search_ge(pr_tree *tree, const void *key)
int pr_itor_compare(const pr_itor *i1, const pr_itor *i2)
bool pr_itor_prev(pr_itor *itor)
bool pr_tree_select(pr_tree *tree, size_t n, const void **key, void **datum)
size_t pr_tree_min_path_length(const pr_tree *tree)
bool pr_itor_last(pr_itor *itor)
size_t pr_tree_clear(pr_tree *tree, dict_delete_func delete_func)
bool pr_itor_search_le(pr_itor *itor, const void *key)
bool pr_itor_search_ge(pr_itor *itor, const void *key)
size_t pr_tree_free(pr_tree *tree, dict_delete_func delete_func)
bool pr_itor_search(pr_itor *itor, const void *key)
bool pr_itor_first(pr_itor *itor)
void ** pr_tree_search_le(pr_tree *tree, const void *key)
void ** pr_itor_datum(pr_itor *itor)
size_t pr_tree_total_path_length(const pr_tree *tree)
size_t pr_tree_count(const pr_tree *tree)
bool pr_tree_verify(const pr_tree *tree)
pr_itor * pr_itor_new(pr_tree *tree)
void pr_itor_invalidate(pr_itor *itor)
void ** pr_tree_search(pr_tree *tree, const void *key)
bool pr_itor_search_gt(pr_itor *itor, const void *key)
bool pr_itor_search_lt(pr_itor *itor, const void *key)
const itor_vtable * _vtable
const dict_vtable * _vtable
dict_compare_func cmp_func
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_node_max(void *Node)
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_node_min(void *Node)
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)
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)