forked from TrueCloudLab/restic
tree: Add convenience functions
This commit is contained in:
parent
cc847a3d6d
commit
6a7c23d2ae
1 changed files with 18 additions and 8 deletions
|
@ -21,12 +21,12 @@ func NewTree() *Tree {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t Tree) String() string {
|
func (t *Tree) String() string {
|
||||||
return fmt.Sprintf("Tree<%d nodes>", len(t.Nodes))
|
return fmt.Sprintf("Tree<%d nodes>", len(t.Nodes))
|
||||||
}
|
}
|
||||||
|
|
||||||
// Equals returns true if t and other have exactly the same nodes.
|
// Equals returns true if t and other have exactly the same nodes.
|
||||||
func (t Tree) Equals(other *Tree) bool {
|
func (t *Tree) Equals(other *Tree) bool {
|
||||||
if len(t.Nodes) != len(other.Nodes) {
|
if len(t.Nodes) != len(other.Nodes) {
|
||||||
debug.Log("tree.Equals(): trees have different number of nodes")
|
debug.Log("tree.Equals(): trees have different number of nodes")
|
||||||
return false
|
return false
|
||||||
|
@ -46,8 +46,8 @@ func (t Tree) Equals(other *Tree) bool {
|
||||||
|
|
||||||
// Insert adds a new node at the correct place in the tree.
|
// Insert adds a new node at the correct place in the tree.
|
||||||
func (t *Tree) Insert(node *Node) error {
|
func (t *Tree) Insert(node *Node) error {
|
||||||
pos, _, err := t.binarySearch(node.Name)
|
pos, found := t.find(node.Name)
|
||||||
if err == nil {
|
if found != nil {
|
||||||
return errors.Errorf("node %q already present", node.Name)
|
return errors.Errorf("node %q already present", node.Name)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,16 +59,26 @@ func (t *Tree) Insert(node *Node) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t Tree) binarySearch(name string) (int, *Node, error) {
|
func (t *Tree) find(name string) (int, *Node) {
|
||||||
pos := sort.Search(len(t.Nodes), func(i int) bool {
|
pos := sort.Search(len(t.Nodes), func(i int) bool {
|
||||||
return t.Nodes[i].Name >= name
|
return t.Nodes[i].Name >= name
|
||||||
})
|
})
|
||||||
|
|
||||||
if pos < len(t.Nodes) && t.Nodes[pos].Name == name {
|
if pos < len(t.Nodes) && t.Nodes[pos].Name == name {
|
||||||
return pos, t.Nodes[pos], nil
|
return pos, t.Nodes[pos]
|
||||||
}
|
}
|
||||||
|
|
||||||
return pos, nil, errors.New("named node not found")
|
return pos, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
// Find returns a node with the given name, or nil if none could be found.
|
||||||
|
func (t *Tree) Find(name string) *Node {
|
||||||
|
if t == nil {
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|
||||||
|
_, node := t.find(name)
|
||||||
|
return node
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sort sorts the nodes by name.
|
// Sort sorts the nodes by name.
|
||||||
|
@ -79,7 +89,7 @@ func (t *Tree) Sort() {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Subtrees returns a slice of all subtree IDs of the tree.
|
// Subtrees returns a slice of all subtree IDs of the tree.
|
||||||
func (t Tree) Subtrees() (trees IDs) {
|
func (t *Tree) Subtrees() (trees IDs) {
|
||||||
for _, node := range t.Nodes {
|
for _, node := range t.Nodes {
|
||||||
if node.Type == "dir" && node.Subtree != nil {
|
if node.Type == "dir" && node.Subtree != nil {
|
||||||
trees = append(trees, *node.Subtree)
|
trees = append(trees, *node.Subtree)
|
||||||
|
|
Loading…
Reference in a new issue