1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- #ifndef _LINUX_RBTREE_H
- #define _LINUX_RBTREE_H
- #if defined (__GNUC__)
- #elif defined (MSVC)
- #define __inline__ __inline
- #define inline __inline
- #else
- #endif
- struct rb_node {
- struct rb_node *rb_left; /* left element */
- struct rb_node *rb_right; /* right element */
- struct rb_node *rb_parent; /* parent element */
- int rb_color; /* node color */
- };
- struct rb_root {
- struct rb_node *rb_node; /* root of the tree */
- };
- #ifndef NULL
- #define NULL ((void *)0)
- #endif
- #if defined (__GNUC__)
- #define RB_ROOT ((struct rb_root){NULL})
- #elif defined (MSVC)
- #define RB_ROOT {NULL}//{struct rb_root _x = {NULL};}
- #else
- #endif
- #define rb_entry(p, container, field) \
- ((container *) ((char *)p - ((char *)&(((container *)0)->field))))
- #define RB_BLACK 0
- #define RB_RED 1
- extern void rb_insert_color(struct rb_node *, struct rb_root *);
- extern void rb_erase(struct rb_node *, struct rb_root *);
- /* Find logical next and previous nodes in a tree */
- extern struct rb_node *rb_next(struct rb_node *);
- extern struct rb_node *rb_prev(struct rb_node *);
- extern struct rb_node *rb_first(struct rb_root *);
- /* Fast replacement of a single node without remove/rebalance/add/rebalance */
- extern void rb_replace_node(struct rb_node *victim, struct rb_node *new,
- struct rb_root *root);
- static inline void rb_link_node(struct rb_node * node, struct rb_node * parent,
- struct rb_node ** rb_link)
- {
- node->rb_parent = parent;
- node->rb_color = RB_RED;
- node->rb_left = node->rb_right = NULL;
- *rb_link = node;
- }
- #endif /* _LINUX_RBTREE_H */
|