105static sp_node* node_new(
void* key);
132 dct->
_vtable = &sp_tree_vtable;
143 unsigned rotations = 0;
173 if (pp->
llink == p) {
178 if ((pp->
llink = pr) != NULL)
184 if ((p->
llink = nr) != NULL)
191 if ((p->
llink = nr) != NULL)
197 if ((pp->
rlink = nl) != NULL)
201 if (pp->
rlink == p) {
206 if ((pp->
rlink = pl) != NULL)
212 if ((p->
rlink = nl) != NULL)
219 if ((p->
rlink = nl) != NULL)
225 if ((pp->
llink = nr) != NULL)
231 if (ppp->
llink == pp)
252 parent = node; node = node->
llink;
253 }
else if (cmp > 0) {
254 parent = node; node = node->
rlink;
259 if (!(node = node_new(key)))
262 if (!(node->
parent = parent)) {
269 parent->
llink = node;
271 parent->
rlink = node;
381 remove_node(
tree, node);
417 if (parent->
llink == node) {
424 if (!node_verify(
tree, node, node->
llink) ||
462 itor->
_vtable = &sp_tree_itor_vtable;
496 remove_node(itor->
tree, itor->
node);
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)
bool sp_itor_last(sp_itor *itor)
dict * sp_dict_new(dict_compare_func cmp_func)
dict_remove_result sp_tree_remove(sp_tree *tree, const void *key)
void ** sp_itor_datum(sp_itor *itor)
bool sp_itor_nextn(sp_itor *itor, size_t count)
bool sp_itor_search_ge(sp_itor *itor, const void *key)
bool sp_itor_prev(sp_itor *itor)
dict_insert_result sp_tree_insert(sp_tree *tree, void *key)
size_t sp_tree_clear(sp_tree *tree, dict_delete_func delete_func)
void sp_itor_free(sp_itor *itor)
bool sp_tree_select(sp_tree *tree, size_t n, const void **key, void **datum)
size_t sp_tree_min_path_length(const sp_tree *tree)
sp_itor * sp_itor_new(sp_tree *tree)
bool sp_itor_next(sp_itor *itor)
int sp_itor_compare(const sp_itor *i1, const sp_itor *i2)
bool sp_itor_remove(sp_itor *itor)
bool sp_itor_prevn(sp_itor *itor, size_t count)
size_t sp_tree_max_path_length(const sp_tree *tree)
void ** sp_tree_search_lt(sp_tree *tree, const void *key)
dict_itor * sp_dict_itor_new(sp_tree *tree)
size_t sp_tree_free(sp_tree *tree, dict_delete_func delete_func)
size_t sp_tree_traverse(sp_tree *tree, dict_visit_func visit, void *user_data)
void sp_itor_invalidate(sp_itor *itor)
size_t sp_tree_count(const sp_tree *tree)
void ** sp_tree_search_gt(sp_tree *tree, const void *key)
void ** sp_tree_search_le(sp_tree *tree, const void *key)
bool sp_itor_valid(const sp_itor *itor)
bool sp_itor_search_le(sp_itor *itor, const void *key)
bool sp_tree_verify(const sp_tree *tree)
bool sp_itor_first(sp_itor *itor)
size_t sp_tree_total_path_length(const sp_tree *tree)
bool sp_itor_search_lt(sp_itor *itor, const void *key)
const void * sp_itor_key(const sp_itor *itor)
bool sp_itor_search_gt(sp_itor *itor, const void *key)
sp_tree * sp_tree_new(dict_compare_func cmp_func)
void ** sp_tree_search_ge(sp_tree *tree, const void *key)
void ** sp_tree_search(sp_tree *tree, const void *key)
bool sp_itor_search(sp_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_search_gt_node(void *Tree, const void *key)
void ** tree_iterator_datum(void *Iterator)
bool tree_iterator_next(void *Iterator)
void * tree_search_le_node(void *Tree, const void *key)
void tree_iterator_invalidate(void *Iterator)
int tree_iterator_compare(const void *Iterator1, const void *Iterator2)
void * tree_search_node(void *Tree, const void *key)
bool tree_iterator_search_le(void *Iterator, const void *key)
void * tree_search_lt_node(void *Tree, const void *key)
bool tree_iterator_valid(const void *Iterator)
size_t tree_count(const void *Tree)
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)
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_node(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)