mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-14 20:45:36 +00:00
53 lines
1.1 KiB
Go
53 lines
1.1 KiB
Go
package yqlib
|
|
|
|
import (
|
|
"fmt"
|
|
)
|
|
|
|
type flattenPreferences struct {
|
|
depth int
|
|
}
|
|
|
|
func flatten(node *CandidateNode, depth int) {
|
|
if depth == 0 {
|
|
return
|
|
}
|
|
if node.Kind != SequenceNode {
|
|
return
|
|
}
|
|
content := node.Content
|
|
newSeq := make([]*CandidateNode, 0)
|
|
|
|
for i := 0; i < len(content); i++ {
|
|
if content[i].Kind == SequenceNode {
|
|
flatten(content[i], depth-1)
|
|
for j := 0; j < len(content[i].Content); j++ {
|
|
newSeq = append(newSeq, content[i].Content[j])
|
|
}
|
|
} else {
|
|
newSeq = append(newSeq, content[i])
|
|
}
|
|
}
|
|
node.Content = newSeq
|
|
}
|
|
|
|
func flattenOp(d *dataTreeNavigator, context Context, expressionNode *ExpressionNode) (Context, error) {
|
|
|
|
log.Debugf("-- flatten Operator")
|
|
depth := expressionNode.Operation.Preferences.(flattenPreferences).depth
|
|
|
|
for el := context.MatchingNodes.Front(); el != nil; el = el.Next() {
|
|
candidate := el.Value.(*CandidateNode)
|
|
candidateNode := candidate.unwrapDocument()
|
|
if candidateNode.Kind != SequenceNode {
|
|
return Context{}, fmt.Errorf("Only arrays are supported for flatten")
|
|
}
|
|
|
|
flatten(candidateNode, depth)
|
|
|
|
}
|
|
|
|
return context, nil
|
|
|
|
}
|