Use switch expression to dispatch operators 12/100512/5
authorRobert Varga <robert.varga@pantheon.tech>
Sat, 9 Apr 2022 23:01:09 +0000 (01:01 +0200)
committerRobert Varga <nite@hq.sk>
Mon, 25 Apr 2022 12:08:38 +0000 (12:08 +0000)
We are switching on an enum, hence we can ditch the default case
when we have an exhaustive expression.

Change-Id: I6df494319383d8ae39a8a42152e94c190b2f1186
Signed-off-by: Robert Varga <robert.varga@pantheon.tech>
xpath/yang-xpath-api/src/main/java/org/opendaylight/yangtools/yang/xpath/api/BigDecimalXPathMathSupport.java
xpath/yang-xpath-api/src/main/java/org/opendaylight/yangtools/yang/xpath/api/DoubleXPathMathSupport.java

index 437ff0dc50add0f1dc3d7285d8af33cf7555068a..9044c1d178731606adef80abb554d7b6e374efe5 100644 (file)
@@ -60,40 +60,19 @@ final class BigDecimalXPathMathSupport extends AbstractYangXPathMathSupport<BigD
         final BigDecimal l = left.getNumber();
         final BigDecimal r = right.getNumber();
 
-        final BigDecimal result;
-        switch (operator) {
-            case DIV:
-                result = l.divide(r);
-                break;
-            case EQUALS:
-                return YangBooleanConstantExpr.of(l.equals(r));
-            case GT:
-                return YangBooleanConstantExpr.of(l.compareTo(r) > 0);
-            case GTE:
-                return YangBooleanConstantExpr.of(l.compareTo(r) >= 0);
-            case LT:
-                return YangBooleanConstantExpr.of(l.compareTo(r) < 0);
-            case LTE:
-                return YangBooleanConstantExpr.of(l.compareTo(r) <= 0);
-            case MINUS:
-                result = l.subtract(r);
-                break;
-            case MOD:
-                result = l.remainder(r);
-                break;
-            case MUL:
-                result = l.multiply(r);
-                break;
-            case NOT_EQUALS:
-                return YangBooleanConstantExpr.of(!l.equals(r));
-            case PLUS:
-                result = l.add(r);
-                break;
-            default:
-                throw new IllegalStateException("Unhandled operator " + operator);
-        }
-
-        return BigDecimalNumberExpr.of(result);
+        return switch (operator) {
+            case DIV -> BigDecimalNumberExpr.of(l.divide(r));
+            case EQUALS -> YangBooleanConstantExpr.of(l.equals(r));
+            case GT -> YangBooleanConstantExpr.of(l.compareTo(r) > 0);
+            case GTE -> YangBooleanConstantExpr.of(l.compareTo(r) >= 0);
+            case LT -> YangBooleanConstantExpr.of(l.compareTo(r) < 0);
+            case LTE -> YangBooleanConstantExpr.of(l.compareTo(r) <= 0);
+            case MINUS -> BigDecimalNumberExpr.of(l.subtract(r));
+            case MOD -> BigDecimalNumberExpr.of(l.remainder(r));
+            case MUL -> BigDecimalNumberExpr.of(l.multiply(r));
+            case NOT_EQUALS -> YangBooleanConstantExpr.of(!l.equals(r));
+            case PLUS -> BigDecimalNumberExpr.of(l.add(r));
+        };
     }
 
     @Override
index 4662b725017b52acc3773a4e41cc272c86525803..7aaf4c7ac56162292e10f5a36d6d237f0141248f 100644 (file)
@@ -37,40 +37,19 @@ final class DoubleXPathMathSupport extends AbstractYangXPathMathSupport<DoubleNu
         final double l = left.getValue();
         final double r = right.getValue();
 
-        final double result;
-        switch (operator) {
-            case DIV:
-                result = l / r;
-                break;
-            case EQUALS:
-                return YangBooleanConstantExpr.of(left.equals(right));
-            case GT:
-                return YangBooleanConstantExpr.of(l > r);
-            case GTE:
-                return YangBooleanConstantExpr.of(l >= r);
-            case LT:
-                return YangBooleanConstantExpr.of(l < r);
-            case LTE:
-                return YangBooleanConstantExpr.of(l <= r);
-            case MINUS:
-                result = l - r;
-                break;
-            case MOD:
-                result = l % r;
-                break;
-            case MUL:
-                result = l * r;
-                break;
-            case NOT_EQUALS:
-                return YangBooleanConstantExpr.of(!left.equals(right));
-            case PLUS:
-                result = l + r;
-                break;
-            default:
-                throw new IllegalStateException("Unhandled operator " + operator);
-        }
-
-        return DoubleNumberExpr.of(result);
+        return switch (operator) {
+            case DIV -> DoubleNumberExpr.of(l / r);
+            case EQUALS -> YangBooleanConstantExpr.of(left.equals(right));
+            case GT -> YangBooleanConstantExpr.of(l > r);
+            case GTE -> YangBooleanConstantExpr.of(l >= r);
+            case LT -> YangBooleanConstantExpr.of(l < r);
+            case LTE -> YangBooleanConstantExpr.of(l <= r);
+            case MINUS -> DoubleNumberExpr.of(l - r);
+            case MOD -> DoubleNumberExpr.of(l % r);
+            case MUL -> DoubleNumberExpr.of(l * r);
+            case NOT_EQUALS -> YangBooleanConstantExpr.of(!left.equals(right));
+            case PLUS -> DoubleNumberExpr.of(l + r);
+        };
     }
 
     @Override