refactor pluck
This commit is contained in:
parent
fc06b09df6
commit
dbf4a86134
1 changed files with 3 additions and 8 deletions
|
|
@ -60,7 +60,7 @@ func (g *Graph) ExtractAsNestedGraph(obj *Object) *Graph {
|
||||||
func pluckObjAndEdges(g *Graph, obj *Object) (descendantsObjects []*Object, edges []*Edge) {
|
func pluckObjAndEdges(g *Graph, obj *Object) (descendantsObjects []*Object, edges []*Edge) {
|
||||||
for i := 0; i < len(g.Edges); i++ {
|
for i := 0; i < len(g.Edges); i++ {
|
||||||
edge := g.Edges[i]
|
edge := g.Edges[i]
|
||||||
if edge.Src == obj || edge.Dst == obj {
|
if edge.Src.IsDescendantOf(obj) || edge.Dst.IsDescendantOf(obj) {
|
||||||
edges = append(edges, edge)
|
edges = append(edges, edge)
|
||||||
g.Edges = append(g.Edges[:i], g.Edges[i+1:]...)
|
g.Edges = append(g.Edges[:i], g.Edges[i+1:]...)
|
||||||
i--
|
i--
|
||||||
|
|
@ -69,15 +69,10 @@ func pluckObjAndEdges(g *Graph, obj *Object) (descendantsObjects []*Object, edge
|
||||||
|
|
||||||
for i := 0; i < len(g.Objects); i++ {
|
for i := 0; i < len(g.Objects); i++ {
|
||||||
temp := g.Objects[i]
|
temp := g.Objects[i]
|
||||||
if temp.AbsID() == obj.AbsID() {
|
if temp.IsDescendantOf(obj) {
|
||||||
descendantsObjects = append(descendantsObjects, obj)
|
descendantsObjects = append(descendantsObjects, obj)
|
||||||
g.Objects = append(g.Objects[:i], g.Objects[i+1:]...)
|
g.Objects = append(g.Objects[:i], g.Objects[i+1:]...)
|
||||||
for _, child := range obj.ChildrenArray {
|
i--
|
||||||
subObjects, subEdges := pluckObjAndEdges(g, child)
|
|
||||||
descendantsObjects = append(descendantsObjects, subObjects...)
|
|
||||||
edges = append(edges, subEdges...)
|
|
||||||
}
|
|
||||||
break
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue