-
Notifications
You must be signed in to change notification settings - Fork 389
/
Copy pathtree.gno
103 lines (89 loc) · 3.52 KB
/
tree.gno
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
package avl
type IterCbFn func(key string, value interface{}) bool
//----------------------------------------
// Tree
// The zero struct can be used as an empty tree.
type Tree struct {
node *Node
}
// NewTree creates a new empty AVL tree.
func NewTree() *Tree {
return &Tree{
node: nil,
}
}
// Size returns the number of key-value pair in the tree.
func (tree *Tree) Size() int {
return tree.node.Size()
}
// Has checks whether a key exists in the tree.
// It returns true if the key exists, otherwise false.
func (tree *Tree) Has(key string) (has bool) {
return tree.node.Has(key)
}
// Get retrieves the value associated with the given key.
// It returns the value and a boolean indicating whether the key exists.
func (tree *Tree) Get(key string) (value interface{}, exists bool) {
_, value, exists = tree.node.Get(key)
return
}
// GetByIndex retrieves the key-value pair at the specified index in the tree.
// It returns the key and value at the given index.
func (tree *Tree) GetByIndex(index int) (key string, value interface{}) {
return tree.node.GetByIndex(index)
}
// Set inserts a key-value pair into the tree.
// If the key already exists, the value will be updated.
// It returns a boolean indicating whether the key was newly inserted or updated.
func (tree *Tree) Set(key string, value interface{}) (updated bool) {
newnode, updated := tree.node.Set(key, value)
tree.node = newnode
return updated
}
// Remove removes a key-value pair from the tree.
// It returns the removed value and a boolean indicating whether the key was found and removed.
func (tree *Tree) Remove(key string) (value interface{}, removed bool) {
newnode, _, value, removed := tree.node.Remove(key)
tree.node = newnode
return value, removed
}
// Iterate performs an in-order traversal of the tree within the specified key range.
// It calls the provided callback function for each key-value pair encountered.
// If the callback returns true, the iteration is stopped.
func (tree *Tree) Iterate(start, end string, cb IterCbFn) bool {
return tree.node.TraverseInRange(start, end, true, true,
func(node *Node) bool {
return cb(node.Key(), node.Value())
},
)
}
// ReverseIterate performs a reverse in-order traversal of the tree within the specified key range.
// It calls the provided callback function for each key-value pair encountered.
// If the callback returns true, the iteration is stopped.
func (tree *Tree) ReverseIterate(start, end string, cb IterCbFn) bool {
return tree.node.TraverseInRange(start, end, false, true,
func(node *Node) bool {
return cb(node.Key(), node.Value())
},
)
}
// IterateByOffset performs an in-order traversal of the tree starting from the specified offset.
// It calls the provided callback function for each key-value pair encountered, up to the specified count.
// If the callback returns true, the iteration is stopped.
func (tree *Tree) IterateByOffset(offset int, count int, cb IterCbFn) bool {
return tree.node.TraverseByOffset(offset, count, true, true,
func(node *Node) bool {
return cb(node.Key(), node.Value())
},
)
}
// ReverseIterateByOffset performs a reverse in-order traversal of the tree starting from the specified offset.
// It calls the provided callback function for each key-value pair encountered, up to the specified count.
// If the callback returns true, the iteration is stopped.
func (tree *Tree) ReverseIterateByOffset(offset int, count int, cb IterCbFn) bool {
return tree.node.TraverseByOffset(offset, count, false, true,
func(node *Node) bool {
return cb(node.Key(), node.Value())
},
)
}