mirror of https://github.com/mikefarah/yq.git
31 lines
796 B
Go
31 lines
796 B
Go
|
package yqlib
|
||
|
|
||
|
func ReadForMergeNavigationStrategy(deeplyTraverseArrays bool) NavigationStrategy {
|
||
|
return &NavigationStrategyImpl{
|
||
|
visitedNodes: []*NodeContext{},
|
||
|
pathParser: NewPathParser(),
|
||
|
followAlias: func(nodeContext NodeContext) bool {
|
||
|
return false
|
||
|
},
|
||
|
shouldOnlyDeeplyVisitLeaves: func(nodeContext NodeContext) bool {
|
||
|
return false
|
||
|
},
|
||
|
visit: func(nodeContext NodeContext) error {
|
||
|
return nil
|
||
|
},
|
||
|
shouldDeeplyTraverse: func(nodeContext NodeContext) bool {
|
||
|
var isInArray = false
|
||
|
if len(nodeContext.PathStack) > 0 {
|
||
|
var lastElement = nodeContext.PathStack[len(nodeContext.PathStack)-1]
|
||
|
switch lastElement.(type) {
|
||
|
case int:
|
||
|
isInArray = true
|
||
|
default:
|
||
|
isInArray = false
|
||
|
}
|
||
|
}
|
||
|
return deeplyTraverseArrays || !isInArray
|
||
|
},
|
||
|
}
|
||
|
}
|