iradix

package module
v0.0.0-...-4ccc31c Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jun 2, 2016 License: MPL-2.0 Imports: 3 Imported by: 0

README

go-immutable-radix Build Status

Provides the iradix package that implements an immutable radix tree. The package only provides a single Tree implementation, optimized for sparse nodes.

As a radix tree, it provides the following:

  • O(k) operations. In many cases, this can be faster than a hash table since the hash function is an O(k) operation, and hash tables have very poor cache locality.
  • Minimum / Maximum value lookups
  • Ordered iteration

A tree supports using a transaction to batch multiple updates (insert, delete) in a more efficient manner than performing each operation one at a time.

For a mutable variant, see go-radix.

Documentation

The full documentation is available on Godoc.

Example

Below is a simple example of usage

// Create a tree
r := iradix.New()
r, _, _ = r.Insert([]byte("foo"), 1)
r, _, _ = r.Insert([]byte("bar"), 2)
r, _, _ = r.Insert([]byte("foobar"), 2)

// Find the longest prefix match
m, _, _ := r.Root().LongestPrefix([]byte("foozip"))
if string(m) != "foo" {
    panic("should be foo")
}

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Iterator

type Iterator struct {
	// contains filtered or unexported fields
}

Iterator is used to iterate over a set of nodes in pre-order

func (*Iterator) Next

func (i *Iterator) Next() ([]byte, interface{}, bool)

Next returns the next node in order

func (*Iterator) SeekPrefix

func (i *Iterator) SeekPrefix(prefix []byte)

SeekPrefix is used to seek the iterator to a given prefix

type Node

type Node struct {
	// contains filtered or unexported fields
}

Node is an immutable node in the radix tree

func (*Node) Get

func (n *Node) Get(k []byte) (interface{}, bool)

func (*Node) Iterator

func (n *Node) Iterator() *Iterator

Iterator is used to return an iterator at the given node to walk the tree

func (*Node) LongestPrefix

func (n *Node) LongestPrefix(k []byte) ([]byte, interface{}, bool)

LongestPrefix is like Get, but instead of an exact match, it will return the longest prefix match.

func (*Node) Maximum

func (n *Node) Maximum() ([]byte, interface{}, bool)

Maximum is used to return the maximum value in the tree

func (*Node) Minimum

func (n *Node) Minimum() ([]byte, interface{}, bool)

Minimum is used to return the minimum value in the tree

func (*Node) Walk

func (n *Node) Walk(fn WalkFn)

Walk is used to walk the tree

func (*Node) WalkPath

func (n *Node) WalkPath(path []byte, fn WalkFn)

WalkPath is used to walk the tree, but only visiting nodes from the root down to a given leaf. Where WalkPrefix walks all the entries *under* the given prefix, this walks the entries *above* the given prefix.

func (*Node) WalkPrefix

func (n *Node) WalkPrefix(prefix []byte, fn WalkFn)

WalkPrefix is used to walk the tree under a prefix

type Tree

type Tree struct {
	// contains filtered or unexported fields
}

Tree implements an immutable radix tree. This can be treated as a Dictionary abstract data type. The main advantage over a standard hash map is prefix-based lookups and ordered iteration. The immutability means that it is safe to concurrently read from a Tree without any coordination.

func New

func New() *Tree

New returns an empty Tree

func (*Tree) Delete

func (t *Tree) Delete(k []byte) (*Tree, interface{}, bool)

Delete is used to delete a given key. Returns the new tree, old value if any, and a bool indicating if the key was set.

func (*Tree) Get

func (t *Tree) Get(k []byte) (interface{}, bool)

Get is used to lookup a specific key, returning the value and if it was found

func (*Tree) Insert

func (t *Tree) Insert(k []byte, v interface{}) (*Tree, interface{}, bool)

Insert is used to add or update a given key. The return provides the new tree, previous value and a bool indicating if any was set.

func (*Tree) Len

func (t *Tree) Len() int

Len is used to return the number of elements in the tree

func (*Tree) Root

func (t *Tree) Root() *Node

Root returns the root node of the tree which can be used for richer query operations.

func (*Tree) Txn

func (t *Tree) Txn() *Txn

Txn starts a new transaction that can be used to mutate the tree

type Txn

type Txn struct {
	// contains filtered or unexported fields
}

Txn is a transaction on the tree. This transaction is applied atomically and returns a new tree when committed. A transaction is not thread safe, and should only be used by a single goroutine.

func (*Txn) Commit

func (t *Txn) Commit() *Tree

Commit is used to finalize the transaction and return a new tree

func (*Txn) Delete

func (t *Txn) Delete(k []byte) (interface{}, bool)

Delete is used to delete a given key. Returns the old value if any, and a bool indicating if the key was set.

func (*Txn) Get

func (t *Txn) Get(k []byte) (interface{}, bool)

Get is used to lookup a specific key, returning the value and if it was found

func (*Txn) Insert

func (t *Txn) Insert(k []byte, v interface{}) (interface{}, bool)

Insert is used to add or update a given key. The return provides the previous value and a bool indicating if any was set.

func (*Txn) Root

func (t *Txn) Root() *Node

Root returns the current root of the radix tree within this transaction. The root is not safe across insert and delete operations, but can be used to read the current state during a transaction.

type WalkFn

type WalkFn func(k []byte, v interface{}) bool

WalkFn is used when walking the tree. Takes a key and value, returning if iteration should be terminated.

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL