Skip to content

Commit

Permalink
feat: Add p/demo/avlhelpers. See the PR.
Browse files Browse the repository at this point in the history
Signed-off-by: Jeff Thompson <[email protected]>
  • Loading branch information
jefft0 committed Mar 6, 2024
1 parent f14c100 commit cee52b3
Show file tree
Hide file tree
Showing 2 changed files with 126 additions and 0 deletions.
32 changes: 32 additions & 0 deletions examples/gno.land/p/demo/avlhelpers/avlhelpers.gno
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
package avlhelpers

import (
"gno.land/p/demo/avl"
)

// Get a list of keys starting from the given prefix. Limit the
// number of results to maxResults.
func ListKeysByPrefix(tree avl.Tree, prefix string, maxResults int) []string {
end := ""
n := len(prefix)
// To make the end of the search, increment the final character ASCII by one.
for n > 0 {
if ascii := int(prefix[n-1]); ascii < 0xff {
end = prefix[0:n-1] + string(ascii+1)
break
}

// The last character is 0xff. Try the previous character.
n--
}

result := []string{}
tree.Iterate(prefix, end, func(key string, value interface{}) bool {
result = append(result, key)
if len(result) >= maxResults {
return true
}
return false
})
return result
}
94 changes: 94 additions & 0 deletions examples/gno.land/p/demo/avlhelpers/z_0_filetest.gno
Original file line number Diff line number Diff line change
@@ -0,0 +1,94 @@
// PKGPATH: gno.land/r/test
package test

import (
"encoding/hex"

"gno.land/p/demo/avl"
"gno.land/p/demo/avlhelpers"
"gno.land/p/demo/ufmt"
)

func init() {
}

func main() {
tree := avl.Tree{}

{
// Empty tree.
matches := avlhelpers.ListKeysByPrefix(tree, "", 10)
println(ufmt.Sprintf("# matches: %d", len(matches)))
}

tree.Set("alice", "")
tree.Set("andy", "")
tree.Set("bob", "")

{
// Match only alice.
matches := avlhelpers.ListKeysByPrefix(tree, "al", 10)
println(ufmt.Sprintf("# matches: %d", len(matches)))
println("match: " + matches[0])
}

{
// Match alice and andy.
matches := avlhelpers.ListKeysByPrefix(tree, "a", 10)
println(ufmt.Sprintf("# matches: %d", len(matches)))
println("match: " + matches[0])
println("match: " + matches[1])
}

{
// Match alice and andy limited to 1.
matches := avlhelpers.ListKeysByPrefix(tree, "a", 1)
println(ufmt.Sprintf("# matches: %d", len(matches)))
println("match: " + matches[0])
}

tree = avl.Tree{}
tree.Set("a\xff", "")
tree.Set("a\xff\xff", "")
tree.Set("b", "")
tree.Set("\xff\xff\x00", "")

{
// Match only "a\xff\xff".
matches := avlhelpers.ListKeysByPrefix(tree, "a\xff\xff", 10)
println(ufmt.Sprintf("# matches: %d", len(matches)))
println(ufmt.Sprintf("match: %s", hex.EncodeToString([]byte(matches[0]))))
}

{
// Match "a\xff" and "a\xff\xff".
matches := avlhelpers.ListKeysByPrefix(tree, "a\xff", 10)
println(ufmt.Sprintf("# matches: %d", len(matches)))
println(ufmt.Sprintf("match: %s", hex.EncodeToString([]byte(matches[0]))))
println(ufmt.Sprintf("match: %s", hex.EncodeToString([]byte(matches[1]))))
}

{
// Edge case: Match only "\xff\xff\x00".
matches := avlhelpers.ListKeysByPrefix(tree, "\xff\xff", 10)
println(ufmt.Sprintf("# matches: %d", len(matches)))
println(ufmt.Sprintf("match: %s", hex.EncodeToString([]byte(matches[0]))))
}
}

// Output:
// # matches: 0
// # matches: 1
// match: alice
// # matches: 2
// match: alice
// match: andy
// # matches: 1
// match: alice
// # matches: 1
// match: 61ffff
// # matches: 2
// match: 61ff
// match: 61ffff
// # matches: 1
// match: ffff00

0 comments on commit cee52b3

Please sign in to comment.