mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-12 19:25:37 +00:00
36 lines
789 B
Go
36 lines
789 B
Go
package yqlib
|
|
|
|
import (
|
|
"container/list"
|
|
"fmt"
|
|
)
|
|
|
|
func lengthOperator(_ *dataTreeNavigator, context Context, _ *ExpressionNode) (Context, error) {
|
|
log.Debugf("lengthOperation")
|
|
var results = list.New()
|
|
|
|
for el := context.MatchingNodes.Front(); el != nil; el = el.Next() {
|
|
candidate := el.Value.(*CandidateNode)
|
|
var length int
|
|
switch candidate.Kind {
|
|
case ScalarNode:
|
|
if candidate.Tag == "!!null" {
|
|
length = 0
|
|
} else {
|
|
length = len(candidate.Value)
|
|
}
|
|
case MappingNode:
|
|
length = len(candidate.Content) / 2
|
|
case SequenceNode:
|
|
length = len(candidate.Content)
|
|
default:
|
|
length = 0
|
|
}
|
|
|
|
result := candidate.CreateReplacement(ScalarNode, "!!int", fmt.Sprintf("%v", length))
|
|
results.PushBack(result)
|
|
}
|
|
|
|
return context.ChildContext(results), nil
|
|
}
|