Documentation ¶
Overview ¶
Trie is a prefix index package for golang.
Terminology used ¶
Trie - Contains the Root of the Index - which is a Branch ¶
Branch - A Branch might have a LeafValue or not and might have other Branches splitting off. It has a flag `End` that marks the end of a term that has been inserted.
Entry - an entry refers to a _complete_ term that is inserted, removed from, or matched in the index. It requires `End` on the Branch to be set to `true`, which makes it different from a
Prefix - which does not require the Branch to have End set to `true` to match.
Index ¶
- Constants
- type Branch
- type MemberInfo
- type Trie
- func (t *Trie) Add(entry string) *Branch
- func (t *Trie) Delete(entry string) bool
- func (t *Trie) Dump() string
- func (t *Trie) DumpToFile(fname string) error
- func (t *Trie) GetBranch(entry string) *Branch
- func (t *Trie) Has(entry string) bool
- func (t *Trie) HasCount(entry string) (exists bool, count int64)
- func (t *Trie) HasPrefix(prefix string) bool
- func (t *Trie) HasPrefixCount(prefix string) (exists bool, count int64)
- func (t *Trie) Members() []*MemberInfo
- func (t *Trie) MembersList() (members []string)
- func (t *Trie) MergeFromFile(fname string) error
- func (t *Trie) PrefixMembers(prefix string) []*MemberInfo
- func (t *Trie) PrefixMembersList(prefix string) (members []string)
- func (t *Trie) PrintDump()
Constants ¶
const PADDING_CHAR = "-"
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type MemberInfo ¶
func (*MemberInfo) String ¶
func (m *MemberInfo) String() string
type Trie ¶
type Trie struct {
Root *Branch
}
func LoadFromFile ¶
LoadFromFile loads a gib encoded wordlist from a file and creates a new Trie by Add()ing all of them.
func NewTrie ¶
func NewTrie() *Trie
NewTrie returns the pointer to a new Trie with an initialized root Branch
func (*Trie) Add ¶
Add adds an entry to the trie and returns the branch node that the insertion was made at - or rather where the end of the entry was marked.
func (*Trie) Delete ¶
Delete decrements the count of an existing entry by one. If the count equals zero it removes an the entry from the trie. Returns true if the entry existed, false otherwise. Note that the return value says something about the previous existence of the entry - not whether it has been completely removed or just its count decremented.
func (*Trie) DumpToFile ¶
DumpToFile dumps all values into a slice of strings and writes that to a file using encoding/gob.
The Trie itself can currently not be encoded directly because gob does not directly support structs with a sync.Mutex on them.
func (*Trie) HasCount ¶
HasCount returns true if the `entry` exists in the `Trie`. The second returned value is the count how often the entry has been set.
func (*Trie) HasPrefix ¶
HasPrefix returns true if the the `Trie` contains entries with the given prefix
func (*Trie) HasPrefixCount ¶
HasPrefixCount returns true if the the `Trie` contains entries with the given prefix. The second returned value is the count how often the entry has been set.
func (*Trie) Members ¶
func (t *Trie) Members() []*MemberInfo
Members returns all entries of the Trie with their counts as MemberInfo
func (*Trie) MembersList ¶
Members returns a Slice of all entries of the Trie
func (*Trie) MergeFromFile ¶
MergeFromFile loads a gib encoded wordlist from a file and Add() them to the `Trie`.
TODO: write tests for merge
func (*Trie) PrefixMembers ¶
func (t *Trie) PrefixMembers(prefix string) []*MemberInfo
PrefixMembers returns all entries of the Trie that have the given prefix with their counts as MemberInfo
func (*Trie) PrefixMembersList ¶
PrefixMembers returns a List of all entries of the Trie that have the given prefix