X-Git-Url: http://git.ozlabs.org/?p=ccan;a=blobdiff_plain;f=ccan%2Fbtree%2Fbtree.c;h=4e7782fdd9e66a91517eba89bfc479830d264dce;hp=31982ec80efc6669aed259cef9c0c80202cad78e;hb=7b877620c687786bb5b2b4bb3daffc61ca4322cf;hpb=455572f3e5a66e8a02f38458524fad651eb46489 diff --git a/ccan/btree/btree.c b/ccan/btree/btree.c index 31982ec8..4e7782fd 100644 --- a/ccan/btree/btree.c +++ b/ccan/btree/btree.c @@ -77,6 +77,7 @@ struct btree *btree_new(btree_search_t search) node->depth = 0; btree->root = node; btree->search = search; + btree->multi = false; return btree; } @@ -86,6 +87,43 @@ void btree_delete(struct btree *btree) free(btree); } +bool btree_insert(struct btree *btree, const void *item) +{ + btree_iterator iter; + + if (btree_find_last(btree, item, iter) && !btree->multi) + return false; + + btree_insert_at(iter, item); + return true; +} + +bool btree_remove(struct btree *btree, const void *key) +{ + btree_iterator iter; + bool success = false; + bool multi = btree->multi; + + do { + if (btree_find_first(btree, key, iter)) { + btree_remove_at(iter); + success = true; + } + } while (multi); + + return success; +} + +void *btree_lookup(struct btree *btree, const void *key) +{ + btree_iterator iter; + + if (btree_find_first(btree, key, iter)) + return iter->item; + + return NULL; +} + int btree_begin_end_lr(const struct btree *btree, btree_iterator iter, int lr) { struct btree_node *node; @@ -374,6 +412,17 @@ int btree_cmp_iters(const btree_iterator iter_a, const btree_iterator iter_b) return 0; } +/********************* Built-in ordering functions *******************/ + +btree_search_implement +( + btree_strcmp, + char*, + int c = strcmp(a, b), + c == 0, + c < 0 +) + /************************* Private functions *************************/