Changeset 80bcaed in mainline for kernel/generic/include/adt/btree.h
- Timestamp:
- 2007-02-03T13:22:24Z (18 years ago)
- Branches:
- lfn, master, serial, ticket/834-toolchain-update, topic/msim-upgrade, topic/simplify-dev-export
- Children:
- f619ec11
- Parents:
- fa8e7d2
- File:
-
- 1 edited
Legend:
- Unmodified
- Added
- Removed
-
kernel/generic/include/adt/btree.h
rfa8e7d2 r80bcaed 49 49 count_t keys; 50 50 51 /** Keys. We currently support only single keys. Additional room for one extra key is provided. */ 51 /** 52 * Keys. We currently support only single keys. Additional room for one 53 * extra key is provided. 54 */ 52 55 btree_key_t key[BTREE_MAX_KEYS + 1]; 53 56 54 57 /** 55 * Pointers to values. Sorted according to the key array. Defined only in leaf-level.56 * There is room for storing value for the extra key.58 * Pointers to values. Sorted according to the key array. Defined only in 59 * leaf-level. There is room for storing value for the extra key. 57 60 */ 58 61 void *value[BTREE_MAX_KEYS + 1]; 59 62 60 63 /** 61 * Pointers to descendants of this node sorted according to the key array. 64 * Pointers to descendants of this node sorted according to the key 65 * array. 66 * 62 67 * subtree[0] points to subtree with keys lesser than to key[0]. 63 * subtree[1] points to subtree with keys greater than or equal to key[0] and lesser than key[1]. 68 * subtree[1] points to subtree with keys greater than or equal to 69 * key[0] and lesser than key[1]. 64 70 * ... 65 71 * There is room for storing a subtree pointer for the extra key. … … 70 76 struct btree_node *parent; 71 77 72 /** Link connecting leaf-level nodes. Defined only when this node is a leaf. */ 78 /** 79 * Link connecting leaf-level nodes. Defined only when this node is a 80 * leaf. */ 73 81 link_t leaf_link; 74 82 75 /* *Variables needed by btree_print(). */83 /* Variables needed by btree_print(). */ 76 84 link_t bfs_link; 77 85 int depth; … … 89 97 extern void btree_destroy(btree_t *t); 90 98 91 extern void btree_insert(btree_t *t, btree_key_t key, void *value, btree_node_t *leaf_node); 99 extern void btree_insert(btree_t *t, btree_key_t key, void *value, 100 btree_node_t *leaf_node); 92 101 extern void btree_remove(btree_t *t, btree_key_t key, btree_node_t *leaf_node); 93 102 extern void *btree_search(btree_t *t, btree_key_t key, btree_node_t **leaf_node); 94 103 95 extern btree_node_t *btree_leaf_node_left_neighbour(btree_t *t, btree_node_t *node); 96 extern btree_node_t *btree_leaf_node_right_neighbour(btree_t *t, btree_node_t *node); 104 extern btree_node_t *btree_leaf_node_left_neighbour(btree_t *t, 105 btree_node_t *node); 106 extern btree_node_t *btree_leaf_node_right_neighbour(btree_t *t, 107 btree_node_t *node); 97 108 98 109 extern void btree_print(btree_t *t);
Note:
See TracChangeset
for help on using the changeset viewer.