mirror of
https://github.com/mikefarah/yq.git
synced 2024-11-12 05:38:04 +00:00
13d1bbb45f
Remove dependency on yaml.Node for internal AST representation. Yaml decoder is now just another decoder.
76 lines
2.4 KiB
Go
76 lines
2.4 KiB
Go
package yqlib
|
|
|
|
import (
|
|
"container/list"
|
|
)
|
|
|
|
func collectTogether(d *dataTreeNavigator, context Context, expressionNode *ExpressionNode) (*CandidateNode, error) {
|
|
collectedNode := &CandidateNode{Kind: SequenceNode, Tag: "!!seq"}
|
|
for el := context.MatchingNodes.Front(); el != nil; el = el.Next() {
|
|
candidate := el.Value.(*CandidateNode)
|
|
collectExpResults, err := d.GetMatchingNodes(context.SingleReadonlyChildContext(candidate), expressionNode)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
for result := collectExpResults.MatchingNodes.Front(); result != nil; result = result.Next() {
|
|
resultC := result.Value.(*CandidateNode)
|
|
log.Debugf("found this: %v", NodeToString(resultC))
|
|
collectedNode.AddChild(resultC)
|
|
}
|
|
}
|
|
return collectedNode, nil
|
|
}
|
|
|
|
func collectOperator(d *dataTreeNavigator, context Context, expressionNode *ExpressionNode) (Context, error) {
|
|
log.Debugf("-- collectOperation")
|
|
|
|
if context.MatchingNodes.Len() == 0 {
|
|
log.Debugf("nothing to collect")
|
|
node := &CandidateNode{Kind: SequenceNode, Tag: "!!seq", Value: "[]"}
|
|
return context.SingleChildContext(node), nil
|
|
}
|
|
|
|
var evaluateAllTogether = true
|
|
for matchEl := context.MatchingNodes.Front(); matchEl != nil; matchEl = matchEl.Next() {
|
|
evaluateAllTogether = evaluateAllTogether && matchEl.Value.(*CandidateNode).EvaluateTogether
|
|
if !evaluateAllTogether {
|
|
break
|
|
}
|
|
}
|
|
|
|
if evaluateAllTogether {
|
|
log.Debugf("collect together")
|
|
collectedNode, err := collectTogether(d, context, expressionNode.RHS)
|
|
if err != nil {
|
|
return Context{}, err
|
|
}
|
|
return context.SingleChildContext(collectedNode), nil
|
|
|
|
}
|
|
|
|
var results = list.New()
|
|
for el := context.MatchingNodes.Front(); el != nil; el = el.Next() {
|
|
candidate := el.Value.(*CandidateNode)
|
|
|
|
collectCandidate := candidate.CreateReplacement(SequenceNode, "!!seq", "")
|
|
|
|
log.Debugf("collect rhs: %v", expressionNode.RHS.Operation.toString())
|
|
|
|
collectExpResults, err := d.GetMatchingNodes(context.SingleChildContext(candidate), expressionNode.RHS)
|
|
if err != nil {
|
|
return Context{}, err
|
|
}
|
|
|
|
for result := collectExpResults.MatchingNodes.Front(); result != nil; result = result.Next() {
|
|
resultC := result.Value.(*CandidateNode)
|
|
log.Debugf("found this: %v", NodeToString(resultC))
|
|
collectCandidate.AddChild(resultC)
|
|
}
|
|
log.Debugf("done collect rhs: %v", expressionNode.RHS.Operation.toString())
|
|
|
|
results.PushBack(collectCandidate)
|
|
}
|
|
|
|
return context.ChildContext(results), nil
|
|
}
|