summaryrefslogtreecommitdiffstats
path: root/indexinglanguage
diff options
context:
space:
mode:
authorArnstein Ressem <aressem@gmail.com>2022-09-20 22:54:04 +0200
committerGitHub <noreply@github.com>2022-09-20 22:54:04 +0200
commit530593d97fa55ec3044f5b6baff3e40e8b37342a (patch)
treefa20ede0378f568ad48a4053e9875d289f83d233 /indexinglanguage
parent5f308520b4030c1670c394a62bcb4cd1284476ef (diff)
Revert "Short circuit boolean expressions"
Diffstat (limited to 'indexinglanguage')
-rw-r--r--indexinglanguage/src/main/java/com/yahoo/vespa/indexinglanguage/expressions/ArithmeticExpression.java20
1 files changed, 13 insertions, 7 deletions
diff --git a/indexinglanguage/src/main/java/com/yahoo/vespa/indexinglanguage/expressions/ArithmeticExpression.java b/indexinglanguage/src/main/java/com/yahoo/vespa/indexinglanguage/expressions/ArithmeticExpression.java
index e4bc2dae965..fa82c4d88ee 100644
--- a/indexinglanguage/src/main/java/com/yahoo/vespa/indexinglanguage/expressions/ArithmeticExpression.java
+++ b/indexinglanguage/src/main/java/com/yahoo/vespa/indexinglanguage/expressions/ArithmeticExpression.java
@@ -166,13 +166,19 @@ public final class ArithmeticExpression extends CompositeExpression {
}
BigDecimal lhsVal = asBigDecimal((NumericFieldValue)lhs);
BigDecimal rhsVal = asBigDecimal((NumericFieldValue)rhs);
- return switch (op) {
- case ADD -> createFieldValue(lhs, rhs, lhsVal.add(rhsVal));
- case SUB -> createFieldValue(lhs, rhs, lhsVal.subtract(rhsVal));
- case MUL -> createFieldValue(lhs, rhs, lhsVal.multiply(rhsVal));
- case DIV -> createFieldValue(lhs, rhs, lhsVal.divide(rhsVal, MathContext.DECIMAL64));
- case MOD -> createFieldValue(lhs, rhs, lhsVal.remainder(rhsVal));
- };
+ switch (op) {
+ case ADD:
+ return createFieldValue(lhs, rhs, lhsVal.add(rhsVal));
+ case SUB:
+ return createFieldValue(lhs, rhs, lhsVal.subtract(rhsVal));
+ case MUL:
+ return createFieldValue(lhs, rhs, lhsVal.multiply(rhsVal));
+ case DIV:
+ return createFieldValue(lhs, rhs, lhsVal.divide(rhsVal, MathContext.DECIMAL64));
+ case MOD:
+ return createFieldValue(lhs, rhs, lhsVal.remainder(rhsVal));
+ }
+ throw new IllegalStateException("Unsupported operation: " + op);
}
private FieldValue createFieldValue(FieldValue lhs, FieldValue rhs, BigDecimal val) {