package core:container/rbtree

⌘K
Ctrl+K
or
/

    Overview

    A red-black tree with the same API as our AVL tree.

    Index

    Constants (0)

    This section is empty.

    Variables (0)

    This section is empty.

    Procedure Groups (2)

    Types

    Color ¶

    Color :: enum uintptr {
    	Black = 0, 
    	Red   = 1, 
    }
     

    Might store this in the node pointer in the future, but that'll require a decent amount of rework to pass ^^N instead of ^N

    Related Procedures With Returns

    Direction ¶

    Direction :: enum i8 {
    	// Backward is the in-order backwards direction.
    	Backward = -1, 
    	// Forward is the in-order forwards direction.
    	Forward  = 1, 
    }
     

    Direction specifies the traversal direction for a tree iterator.

    Related Procedures With Parameters

    Iterator ¶

    Iterator :: struct($Key: typeid, $Value: typeid) where intrinsics.type_is_valid_map_key(Key) {
    	… // See source for fields
    }
     

    Iterator is a tree iterator.

    WARNING: It is unsafe to modify the tree while iterating, except via the iterator_remove method.

    Related Procedures With Parameters
    Related Procedures With Returns

    Node ¶

    Node :: struct($Key: typeid, $Value: typeid) where intrinsics.type_is_valid_map_key(Key) {
    	… // See source for fields
    }
     

    Node is a red-black tree node.

    WARNING: It is unsafe to mutate value if the node is part of a tree if doing so will alter the Node's sort position relative to other elements in the tree.

    Related Procedures With Parameters
    Related Procedures With Returns

    Ordering ¶

    Ordering :: slice.Ordering

    Tree ¶

    Tree :: struct($Key: typeid, $Value: typeid) where intrinsics.type_is_valid_map_key(Key) {
    	… // See source for fields
    }
     

    Tree is a red-black tree

    Related Procedures With Parameters

    Constants

    This section is empty.

    Variables

    This section is empty.

    Procedures

    destroy ¶

    destroy :: proc(t: ^$T/Tree($Key, $Value), call_on_remove: bool = true) {…}
     

    destroy de-initializes a tree.

    find ¶

    find :: proc(t: ^$T/Tree($Key, $Value), key: $Key) -> (node: ^Node($Key, $Value)) {…}
     

    find finds the key in the tree, and returns the corresponding node, or nil iff the value is not present.

    find_or_insert ¶

    find_or_insert :: proc(t: ^$T/Tree($Key, $Value), key: $Key, value: $Value) -> (n: ^Node($Key, $Value), inserted: bool, err: runtime.Allocator_Error) {…}
     

    find_or_insert attempts to insert the key-value pair into the tree, and returns the node, a boolean indicating if a new node was inserted, and the node allocator error if relevant. If the key is already present, the existing node is updated and returned.

    find_value ¶

    find_value :: proc(t: ^$T/Tree($Key, $Value), key: $Key) -> (value: $Value, ok: bool) #optional_ok {…}
     

    find_value finds the key in the tree, and returns the corresponding value, or nil iff the value is not present.

    first ¶

    first :: proc "contextless" (t: ^$T/Tree($Key, $Value)) -> ^Node($Key, $Value) {…}
     

    first returns the first node in the tree (in-order) or nil iff the tree is empty.

    init_cmp ¶

    init_cmp :: proc(t: ^$T/Tree($Key, $Value), cmp_fn: proc(a, b: $Key) -> slice.Ordering, node_allocator := context.allocator) {…}
     

    init_cmp initializes a tree.

    Related Procedure Groups

    init_ordered ¶

    init_ordered :: proc(t: ^$T/Tree($Key, $Value), node_allocator := context.allocator) {…}
     

    init_ordered initializes a tree containing ordered keys, with a comparison function that results in an ascending order sort.

    Related Procedure Groups

    iterator ¶

    iterator :: proc "contextless" (t: ^$T/Tree($Key, $Value), direction: Direction) -> Iterator($Key, $Value) {…}
     

    iterator returns a tree iterator in the specified direction.

    iterator_from_pos ¶

    iterator_from_pos :: proc "contextless" (t: ^$T/Tree($Key, $Value), pos: ^Node($Key, $Value), direction: Direction) -> Iterator($Key, $Value) {…}
     

    iterator_from_pos returns a tree iterator in the specified direction, spanning the range [pos, last] (inclusive).

    iterator_get ¶

    iterator_get :: proc "contextless" (it: ^Iterator($Key, $Value)) -> ^Node($Key, $Value) {…}
     

    iterator_get returns the node currently pointed to by the iterator, or nil iff the node has been removed, the tree is empty, or the end of the tree has been reached.

    iterator_next ¶

    iterator_next :: proc "contextless" (it: ^Iterator($Key, $Value)) -> (^Node($Key, $Value), bool) {…}
     

    iterator_next advances the iterator and returns the (node, true) or or (nil, false) iff the end of the tree has been reached.

    Note: The first call to iterator_next will return the first node instead of advancing the iterator.

    iterator_remove ¶

    iterator_remove :: proc(it: ^Iterator($Key, $Value), call_on_remove: bool = true) -> bool {…}
     

    iterator_remove removes the node currently pointed to by the iterator, and returns true iff the removal was successful. Semantics are the same as the Tree remove.

    last ¶

    last :: proc "contextless" (t: ^$T/Tree($Key, $Value)) -> ^Node($Key, $Value) {…}
     

    last returns the last element in the tree (in-order) or nil iff the tree is empty.

    len ¶

    len :: proc "contextless" (t: ^$T/Tree($Key, $Value)) -> (node_count: int) {…}

    node_color ¶

    node_color :: proc(n: ^Node($Key, $Value)) -> (c: Color) {…}

    remove_key ¶

    remove_key :: proc(t: ^$T/Tree($Key, $Value), key: $Key, call_on_remove: bool = true) -> bool {…}
     

    remove_value removes a value from the tree, and returns true iff the removal was successful. While the node's key + value will be left intact, the node itself will be freed via the tree's node allocator.

    Related Procedure Groups

    remove_node ¶

    remove_node :: proc(t: ^$T/Tree($Key, $Value), node: ^Node($Key, $Value), call_on_remove: bool = true) -> (found: bool) {…}
     

    remove_node removes a node from the tree, and returns true iff the removal was successful. While the node's key + value will be left intact, the node itself will be freed via the tree's node allocator.

    Related Procedure Groups

    Procedure Groups

    init ¶

    init :: proc{
    	init_ordered,
    	init_cmp,
    }
    
     

    init initializes a tree.

    remove ¶

    remove :: proc{
    	remove_key,
    	remove_node,
    }
    
     

    remove removes a node or value from the tree, and returns true iff the removal was successful. While the node's value will be left intact, the node itself will be freed via the tree's node allocator.

    Source Files

    Generation Information

    Generated with odin version dev-2025-10 (vendor "odin") Windows_amd64 @ 2025-10-26 21:11:49.925978200 +0000 UTC