treerack/node.go
2025-08-19 00:56:08 +02:00

39 lines
601 B
Go

package treerack
import "code.squareroundforest.org/arpio/treerack/self"
func mapNodes(m func(n *Node) *Node, n []*Node) []*Node {
var nn []*Node
for i := range n {
nn = append(nn, m(n[i]))
}
return nn
}
func filterNodes(f func(n *Node) bool, n []*Node) []*Node {
var nn []*Node
for i := range n {
if f(n[i]) {
nn = append(nn, n[i])
}
}
return nn
}
func mapSelfNode(n *self.Node) *Node {
nn := Node{
Name: n.Name,
From: n.From,
To: n.To,
tokens: n.Tokens(),
}
for i := range n.Nodes {
nn.Nodes = append(nn.Nodes, mapSelfNode(n.Nodes[i]))
}
return &nn
}