]> git.tuebingen.mpg.de Git - paraslash.git/blobdiff - buffer_tree.h
[btr]: Add btr_merge_to().
[paraslash.git] / buffer_tree.h
index 18b9e8a29576ce7bd25dae68a2640add87bb14b0..4d3502d52ffd0e3493fbe7c9afa746c3a603d61b 100644 (file)
@@ -1,6 +1,23 @@
 
 struct btr_node;
 
-struct btr_node *btr_new_node(char *name, struct btr_node *parent);
+typedef int (*btr_command_handler)(struct btr_node *btrn,
+               const char *command, char **result);
+
+struct btr_node *btr_new_node(const char *name, struct btr_node *parent,
+               btr_command_handler handler, void *context);
+void btr_del_node(struct btr_node *btrn);
 void btr_add_output(char *buf, size_t size, struct btr_node *btrn);
-bool btr_is_leaf_node(struct btr_node *btrn);
+bool btr_no_children(struct btr_node *btrn);
+size_t btr_bytes_pending(struct btr_node *btrn);
+size_t btr_get_input_queue_size(struct btr_node *btrn);
+bool btr_no_parent(struct btr_node *btrn);
+size_t btr_next_buffer(struct btr_node *btrn, char **bufp);
+void btr_consume(struct btr_node *btrn, size_t numbytes);
+int btr_exec(struct btr_node *btrn, const char *command, char **value_result);
+int btr_exec_up(struct btr_node *btrn, const char *command, char **value_result);
+void btr_splice_out_node(struct btr_node *btrn);
+void btr_pushdown(struct btr_node *btrn);
+void *btr_context(struct btr_node *btrn);
+int btr_merge(struct btr_node *btrn);
+void btr_merge_to(struct btr_node *btrn, size_t dest_size);