jdk-24/test/langtools/tools/javac/switchexpr/ExpressionSwitch.java
Jan Lahoda 6ddb0f2b2c 8240964: Compilation error thrown when long literal used with yield
Ensuring yield followed by a long literal is recognized as a yield statement.

Reviewed-by: mcimadamore
2020-03-16 13:06:35 +01:00

166 lines
4.3 KiB
Java

/*
* @test /nodynamiccopyright/
* @bug 8206986 8222169 8224031 8240964
* @summary Check expression switch works.
* @compile/fail/ref=ExpressionSwitch-old.out -source 9 -Xlint:-options -XDrawDiagnostics ExpressionSwitch.java
* @compile ExpressionSwitch.java
* @run main ExpressionSwitch
*/
import java.util.Objects;
import java.util.function.Supplier;
public class ExpressionSwitch {
public static void main(String... args) {
new ExpressionSwitch().run();
}
private void run() {
check(T.A, "A");
check(T.B, "B");
check(T.C, "other");
assertEquals(exhaustive1(T.C), "C");
assertEquals(scopesIsolated(T.B), "B");
assertEquals(lambdas1(T.B).get(), "B");
assertEquals(lambdas2(T.B).get(), "B");
assertEquals(convert1("A"), 0);
assertEquals(convert1("B"), 0);
assertEquals(convert1("C"), 1);
assertEquals(convert1(""), -1);
assertEquals(convert1(null), -2);
assertEquals(convert2("A"), 0);
assertEquals(convert2("B"), 0);
assertEquals(convert2("C"), 1);
assertEquals(convert2(""), -1);
localClass(T.A);
assertEquals(castSwitchExpressions(T.A), "A");
}
private String print(T t) {
return switch (t) {
case A -> "A";
case B -> { yield "B"; }
default -> { yield "other"; }
};
}
private String exhaustive1(T t) {
return switch (t) {
case A -> "A";
case B -> { yield "B"; }
case C -> "C";
case D -> "D";
};
}
private String exhaustive2(T t) {
return switch (t) {
case A -> "A";
case B -> "B";
case C -> "C";
case D -> "D";
};
}
private String scopesIsolated(T t) {
return switch (t) {
case A -> { String res = "A"; yield res;}
case B -> { String res = "B"; yield res;}
default -> { String res = "default"; yield res;}
};
}
private Supplier<String> lambdas1(T t) {
return switch (t) {
case A -> () -> "A";
case B -> { yield () -> "B"; }
default -> () -> "default";
};
}
private Supplier<String> lambdas2(T t) {
return switch (t) {
case A: yield () -> "A";
case B: { yield () -> "B"; }
default: yield () -> "default";
};
}
private int convert1(String s) {
return s == null
? -2
: switch (s) {
case "A", "B" -> 0;
case "C" -> { yield 1; }
default -> -1;
};
}
private int convert2(String s) {
return switch (s) {
case "A", "B": yield 0;
case "C": yield 1;
default: yield -1;
};
}
private Object yieldDisambiguationLiterals(String s) {
return switch (s) {
case "a": yield 0;
case "b": yield 0L;
case "c": yield 0.0f;
case "d": yield 0.0d;
case "e": yield true;
case "f": yield false;
case "g": yield '0';
case "h": yield "";
case "i": yield null;
default: yield 0;
};
}
private void localClass(T t) {
String good = "good";
class L {
public String c() {
STOP: switch (t) {
default: break STOP;
}
return switch (t) {
default: yield good;
};
}
}
String result = new L().c();
if (!Objects.equals(result, good)) {
throw new AssertionError("Unexpected result: " + result);
}
}
private String castSwitchExpressions(T t) {
return (String) switch (t) {
case A -> "A";
default -> 1;
};
}
private void check(T t, String expected) {
String result = print(t);
assertEquals(result, expected);
}
private void assertEquals(Object result, Object expected) {
if (!Objects.equals(result, expected)) {
throw new AssertionError("Unexpected result: " + result);
}
}
enum T {
A, B, C, D;
}
void t() {
Runnable r = () -> {};
r.run();
}
}