|
@ -1,6 +1,8 @@ |
|
|
package bounded_tree |
|
|
package bounded_tree |
|
|
|
|
|
|
|
|
import ( |
|
|
import ( |
|
|
|
|
|
"fmt" |
|
|
|
|
|
|
|
|
"github.com/chrislusf/seaweedfs/weed/glog" |
|
|
"github.com/chrislusf/seaweedfs/weed/glog" |
|
|
"github.com/chrislusf/seaweedfs/weed/util" |
|
|
"github.com/chrislusf/seaweedfs/weed/util" |
|
|
) |
|
|
) |
|
@ -133,7 +135,7 @@ func (t *BoundedTree) HasVisited(p util.FullPath) bool { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
components := p.Split() |
|
|
components := p.Split() |
|
|
// fmt.Printf("components %v %d\n", components, len(components))
|
|
|
|
|
|
|
|
|
fmt.Printf("components %v %d\n", components, len(components)) |
|
|
return t.hasVisited(t.root, util.FullPath("/"), components, 0) |
|
|
return t.hasVisited(t.root, util.FullPath("/"), components, 0) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -147,15 +149,15 @@ func (t *BoundedTree) hasVisited(n *Node, currentPath util.FullPath, components |
|
|
return false |
|
|
return false |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
// fmt.Printf(" hasVisited child %v %v\n", currentPath, components[i])
|
|
|
|
|
|
|
|
|
fmt.Printf(" hasVisited child %v %+v %d\n", currentPath, components, i) |
|
|
|
|
|
|
|
|
toVisitNode, found := n.Children[components[i]] |
|
|
|
|
|
if !found { |
|
|
|
|
|
|
|
|
if i >= len(components) { |
|
|
return true |
|
|
return true |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if i+1 >= len(components) { |
|
|
|
|
|
return false |
|
|
|
|
|
|
|
|
toVisitNode, found := n.Children[components[i]] |
|
|
|
|
|
if !found { |
|
|
|
|
|
return true |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
return t.hasVisited(toVisitNode, currentPath.Child(components[i]), components, i+1) |
|
|
return t.hasVisited(toVisitNode, currentPath.Child(components[i]), components, i+1) |
|
|