X-Git-Url: http://git.tuebingen.mpg.de/?p=paraslash.git;a=blobdiff_plain;f=buffer_tree.h;h=2c102eeca465805c7ea7f1c68904596435bc879e;hp=53b24fe3eb3be403cf8fb27e412936adf9b0320e;hb=7e57898039560a94313e04ca61716ae00719b150;hpb=ff63e4b709e037fda044beae858f494e2868e7d7 diff --git a/buffer_tree.h b/buffer_tree.h index 53b24fe3..2c102eec 100644 --- a/buffer_tree.h +++ b/buffer_tree.h @@ -11,11 +11,15 @@ enum btr_node_type { BTR_NT_LEAF, }; -struct btr_pool *btr_pool_new(size_t area_size); +size_t btr_pool_size(struct btr_pool *btrp); +struct btr_pool *btr_pool_new(const char *name, size_t area_size); void btr_pool_free(struct btr_pool *btrp); size_t btr_pool_get_buffer(struct btr_pool *btrp, char **result); void btr_pool_allocate(struct btr_pool *btrp, size_t size); -void btr_add_output_pool(struct btr_pool *btrp, char *buf, size_t size, +void btr_add_output_pool(struct btr_pool *btrp, size_t size, + struct btr_node *btrn); +size_t btr_pool_unused(struct btr_pool *btrp); +void btr_copy(const void *src, size_t n, struct btr_pool *btrp, struct btr_node *btrn); struct btr_node *btr_new_node(const char *name, struct btr_node *parent, @@ -42,3 +46,4 @@ bool btr_inplace_ok(struct btr_node *btrn); int btr_node_status(struct btr_node *btrn, size_t min_iqs, enum btr_node_type type); void btr_get_node_start(struct btr_node *btrn, struct timeval *tv); +struct btr_node *btr_search_node(const char *name, struct btr_node *root);