mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-13 20:15:57 +00:00
Refactoring traverse
This commit is contained in:
parent
98e8b3479f
commit
80f187f1a4
@ -60,8 +60,33 @@ func traverse(d *dataTreeNavigator, matchingNode *CandidateNode, operation *Oper
|
|||||||
switch value.Kind {
|
switch value.Kind {
|
||||||
case yaml.MappingNode:
|
case yaml.MappingNode:
|
||||||
log.Debug("its a map with %v entries", len(value.Content)/2)
|
log.Debug("its a map with %v entries", len(value.Content)/2)
|
||||||
|
return traverseMap(matchingNode, operation)
|
||||||
|
|
||||||
|
case yaml.SequenceNode:
|
||||||
|
log.Debug("its a sequence of %v things!", len(value.Content))
|
||||||
|
return traverseArray(matchingNode, operation)
|
||||||
|
|
||||||
|
case yaml.AliasNode:
|
||||||
|
log.Debug("its an alias!")
|
||||||
|
matchingNode.Node = matchingNode.Node.Alias
|
||||||
|
return traverse(d, matchingNode, operation)
|
||||||
|
case yaml.DocumentNode:
|
||||||
|
log.Debug("digging into doc node")
|
||||||
|
return traverse(d, &CandidateNode{
|
||||||
|
Node: matchingNode.Node.Content[0],
|
||||||
|
Document: matchingNode.Document}, operation)
|
||||||
|
default:
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func keyMatches(key *yaml.Node, pathNode *Operation) bool {
|
||||||
|
return pathNode.Value == "[]" || Match(key.Value, pathNode.StringValue)
|
||||||
|
}
|
||||||
|
|
||||||
|
func traverseMap(matchingNode *CandidateNode, operation *Operation) ([]*CandidateNode, error) {
|
||||||
var newMatches = orderedmap.NewOrderedMap()
|
var newMatches = orderedmap.NewOrderedMap()
|
||||||
err := traverseMap(newMatches, matchingNode, operation)
|
err := doTraverseMap(newMatches, matchingNode, operation)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -88,30 +113,9 @@ func traverse(d *dataTreeNavigator, matchingNode *CandidateNode, operation *Oper
|
|||||||
i++
|
i++
|
||||||
}
|
}
|
||||||
return arrayMatches, nil
|
return arrayMatches, nil
|
||||||
|
|
||||||
case yaml.SequenceNode:
|
|
||||||
log.Debug("its a sequence of %v things!", len(value.Content))
|
|
||||||
return traverseArray(matchingNode, operation)
|
|
||||||
|
|
||||||
case yaml.AliasNode:
|
|
||||||
log.Debug("its an alias!")
|
|
||||||
matchingNode.Node = matchingNode.Node.Alias
|
|
||||||
return traverse(d, matchingNode, operation)
|
|
||||||
case yaml.DocumentNode:
|
|
||||||
log.Debug("digging into doc node")
|
|
||||||
return traverse(d, &CandidateNode{
|
|
||||||
Node: matchingNode.Node.Content[0],
|
|
||||||
Document: matchingNode.Document}, operation)
|
|
||||||
default:
|
|
||||||
return nil, nil
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func keyMatches(key *yaml.Node, pathNode *Operation) bool {
|
func doTraverseMap(newMatches *orderedmap.OrderedMap, candidate *CandidateNode, operation *Operation) error {
|
||||||
return pathNode.Value == "[]" || Match(key.Value, pathNode.StringValue)
|
|
||||||
}
|
|
||||||
|
|
||||||
func traverseMap(newMatches *orderedmap.OrderedMap, candidate *CandidateNode, operation *Operation) error {
|
|
||||||
// value.Content is a concatenated array of key, value,
|
// value.Content is a concatenated array of key, value,
|
||||||
// so keys are in the even indexes, values in odd.
|
// so keys are in the even indexes, values in odd.
|
||||||
// merge aliases are defined first, but we only want to traverse them
|
// merge aliases are defined first, but we only want to traverse them
|
||||||
@ -161,7 +165,7 @@ func traverseMergeAnchor(newMatches *orderedmap.OrderedMap, originalCandidate *C
|
|||||||
Path: originalCandidate.Path,
|
Path: originalCandidate.Path,
|
||||||
Document: originalCandidate.Document,
|
Document: originalCandidate.Document,
|
||||||
}
|
}
|
||||||
return traverseMap(newMatches, candidateNode, operation)
|
return doTraverseMap(newMatches, candidateNode, operation)
|
||||||
case yaml.SequenceNode:
|
case yaml.SequenceNode:
|
||||||
for _, childValue := range value.Content {
|
for _, childValue := range value.Content {
|
||||||
err := traverseMergeAnchor(newMatches, originalCandidate, childValue, operation)
|
err := traverseMergeAnchor(newMatches, originalCandidate, childValue, operation)
|
||||||
|
Loading…
Reference in New Issue
Block a user