mirror of
https://github.com/mikefarah/yq.git
synced 2024-12-19 20:19:04 +00:00
44 lines
1.3 KiB
Go
44 lines
1.3 KiB
Go
package treeops
|
|
|
|
import (
|
|
"container/list"
|
|
|
|
"gopkg.in/yaml.v3"
|
|
)
|
|
|
|
func CreateMapOperator(d *dataTreeNavigator, matchingNodes *list.List, pathNode *PathTreeNode) (*list.List, error) {
|
|
log.Debugf("-- createMapOperation")
|
|
var path []interface{} = nil
|
|
var document uint = 0
|
|
if matchingNodes.Front() != nil {
|
|
sample := matchingNodes.Front().Value.(*CandidateNode)
|
|
path = sample.Path
|
|
document = sample.Document
|
|
}
|
|
|
|
mapPairs, err := crossFunction(d, matchingNodes, pathNode,
|
|
func(d *dataTreeNavigator, lhs *CandidateNode, rhs *CandidateNode) (*CandidateNode, error) {
|
|
node := yaml.Node{Kind: yaml.MappingNode, Tag: "!!map"}
|
|
log.Debugf("LHS:", NodeToString(lhs))
|
|
log.Debugf("RHS:", NodeToString(rhs))
|
|
node.Content = []*yaml.Node{
|
|
UnwrapDoc(lhs.Node),
|
|
UnwrapDoc(rhs.Node),
|
|
}
|
|
|
|
return &CandidateNode{Node: &node, Document: document, Path: path}, nil
|
|
})
|
|
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
//wrap up all the pairs into an array
|
|
node := yaml.Node{Kind: yaml.SequenceNode, Tag: "!!seq"}
|
|
for mapPair := mapPairs.Front(); mapPair != nil; mapPair = mapPair.Next() {
|
|
mapPairCandidate := mapPair.Value.(*CandidateNode)
|
|
log.Debugf("Collecting %v into sequence", NodeToString(mapPairCandidate))
|
|
node.Content = append(node.Content, mapPairCandidate.Node)
|
|
}
|
|
return nodeToMap(&CandidateNode{Node: &node, Document: document, Path: path}), nil
|
|
}
|