mirror of
https://github.com/mikefarah/yq.git
synced 2025-01-24 23:35:40 +00:00
49 lines
1.6 KiB
Go
49 lines
1.6 KiB
Go
package yqlib
|
|
|
|
func equalsOperator(d *dataTreeNavigator, context Context, expressionNode *ExpressionNode) (Context, error) {
|
|
log.Debugf("equalsOperation")
|
|
return crossFunction(d, context, expressionNode, isEquals(false), true)
|
|
}
|
|
|
|
func isEquals(flip bool) func(d *dataTreeNavigator, context Context, lhs *CandidateNode, rhs *CandidateNode) (*CandidateNode, error) {
|
|
return func(_ *dataTreeNavigator, _ Context, lhs *CandidateNode, rhs *CandidateNode) (*CandidateNode, error) {
|
|
value := false
|
|
log.Debugf("isEquals cross function")
|
|
if lhs == nil && rhs == nil {
|
|
log.Debugf("both are nil")
|
|
owner := &CandidateNode{}
|
|
return createBooleanCandidate(owner, !flip), nil
|
|
} else if lhs == nil {
|
|
log.Debugf("lhs nil, but rhs is not")
|
|
value := rhs.Tag == "!!null"
|
|
if flip {
|
|
value = !value
|
|
}
|
|
return createBooleanCandidate(rhs, value), nil
|
|
} else if rhs == nil {
|
|
log.Debugf("lhs not nil, but rhs is")
|
|
value := lhs.Tag == "!!null"
|
|
if flip {
|
|
value = !value
|
|
}
|
|
return createBooleanCandidate(lhs, value), nil
|
|
}
|
|
|
|
if lhs.Tag == "!!null" {
|
|
value = (rhs.Tag == "!!null")
|
|
} else if lhs.Kind == ScalarNode && rhs.Kind == ScalarNode {
|
|
value = matchKey(lhs.Value, rhs.Value)
|
|
}
|
|
log.Debugf("%v == %v ? %v", NodeToString(lhs), NodeToString(rhs), value)
|
|
if flip {
|
|
value = !value
|
|
}
|
|
return createBooleanCandidate(lhs, value), nil
|
|
}
|
|
}
|
|
|
|
func notEqualsOperator(d *dataTreeNavigator, context Context, expressionNode *ExpressionNode) (Context, error) {
|
|
log.Debugf("notEqualsOperator")
|
|
return crossFunction(d, context.ReadOnlyClone(), expressionNode, isEquals(true), true)
|
|
}
|