RFR: 8337976: Insufficient error recovery in parser for switch inside class body
Vicente Romero
vromero at openjdk.org
Fri Aug 9 17:28:31 UTC 2024
On Fri, 9 Aug 2024 14:57:21 GMT, Jan Lahoda <jlahoda at openjdk.org> wrote:
> Consider this code:
>
> public class T9999999 {
> switch (0) { default: }
> }
>
>
> When trying to compile this, javac crashes:
>
>
> $ .../jdk-22/bin/javac -XDdev /tmp/T9999999.java
> /tmp/T9999999.java:2: error: switch expression does not have any result expressions
> switch (0) { default: } f;
> ^
> 1 error
> An exception has occurred in the compiler (22.0.1-internal). Please file a bug against the Java compiler via the Java bug reporting page (https://bugreport.java.com/) after checking the Bug Database (https://bugs.java.com/) for duplicates. Include your program, the following diagnostic, and the parameters passed to the Java compiler in your report. Thank you.
> java.lang.AssertionError: Unexpected tree: switch (0) {
> default:
>
> } with kind: SWITCH_EXPRESSION within: switch (0) {
> default:
>
> } with kind: SWITCH_EXPRESSION
> at jdk.compiler/com.sun.tools.javac.util.Assert.error(Assert.java:162)
> at jdk.compiler/com.sun.tools.javac.comp.Attr$TypeAnnotationsValidator.validateAnnotatedType(Attr.java:5881)
> at jdk.compiler/com.sun.tools.javac.comp.Attr$TypeAnnotationsValidator.visitVarDef(Attr.java:5727)
> at jdk.compiler/com.sun.tools.javac.tree.JCTree$JCVariableDecl.accept(JCTree.java:1022)
> at jdk.compiler/com.sun.tools.javac.tree.TreeScanner.scan(TreeScanner.java:50)
> at jdk.compiler/com.sun.tools.javac.comp.Attr$TypeAnnotationsValidator.visitClassDef(Attr.java:5780)
> at jdk.compiler/com.sun.tools.javac.tree.JCTree$JCClassDecl.accept(JCTree.java:814)
> at jdk.compiler/com.sun.tools.javac.comp.Attr.validateTypeAnnotations(Attr.java:5677)
> at jdk.compiler/com.sun.tools.javac.code.TypeAnnotations.lambda$validateTypeAnnotationsSignatures$1(TypeAnnotations.java:144)
> at jdk.compiler/com.sun.tools.javac.comp.Annotate.flush(Annotate.java:200)
> at jdk.compiler/com.sun.tools.javac.comp.Annotate.unblockAnnotations(Annotate.java:144)
> at jdk.compiler/com.sun.tools.javac.comp.Annotate.enterDone(Annotate.java:157)
> at jdk.compiler/com.sun.tools.javac.main.JavaCompiler.enterDone(JavaCompiler.java:1827)
> at jdk.compiler/com.sun.tools.javac.main.JavaCompiler.enterTrees(JavaCompiler.java:1081)
> at jdk.compiler/com.sun.tools.javac.main.JavaCompiler.compile(JavaCompiler.java:947)
> at jdk.compiler/com.sun.tools.javac.main.Main.compile(Main.java:319)
> at jdk.compiler/com.sun.tools.javac.main.Main.compile(Main.java:178)
> at jdk.compiler/com.sun.tools.javac.Main.compile(...
src/jdk.compiler/share/classes/com/sun/tools/javac/parser/JavacParser.java line 4923:
> 4921: private boolean isDefiniteStatementStartToken() {
> 4922: return switch (token.kind) {
> 4923: case IF, WHILE, DO, SWITCH, RETURN, TRY, FOR, ASSERT, BREAK,
should `yield`, `synchronized` be included?
-------------
PR Review Comment: https://git.openjdk.org/jdk/pull/20526#discussion_r1711849240
More information about the compiler-dev
mailing list