From 23b83c518da21f814d7ca22297496509dfbc8b9f Mon Sep 17 00:00:00 2001 From: Vicente Romero Date: Thu, 24 Dec 2020 01:24:32 +0000 Subject: [PATCH] 8253954: javac crash when compiling code with enhanced switch expressions with option -Xjcov Reviewed-by: jjg --- .../com/sun/tools/javac/jvm/CRTable.java | 1 + .../langtools/tools/javac/switchexpr/CRT.java | 44 +++++++++++++++++++ 2 files changed, 45 insertions(+) diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/CRTable.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/CRTable.java index 34e741e326e..1e9fa5218c3 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/CRTable.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/CRTable.java @@ -379,6 +379,7 @@ implements CRTFlags { public void visitYield(JCYield tree) { SourceRange sr = new SourceRange(startPos(tree), endPos(tree)); + sr.mergeWith(csp(tree.value)); result = sr; } diff --git a/test/langtools/tools/javac/switchexpr/CRT.java b/test/langtools/tools/javac/switchexpr/CRT.java index b6040cb5e25..d3ad6794060 100644 --- a/test/langtools/tools/javac/switchexpr/CRT.java +++ b/test/langtools/tools/javac/switchexpr/CRT.java @@ -143,6 +143,50 @@ public class CRT { " 35, 63, 180d, 240a, 10 // 35, 63, 6:13, 9:10, flow-target\n" + " 0, 64, c09, 240b, 1 // 0, 64, 3:09, 9:11, statement\n" + " 0, 64, 824, 2806, 2 // 0, 64, 2:36, 10:06, block\n"); + doTest( + """ + private boolean convert(int i) { + return switch (i) { + default -> (i < 256) ? true : false; + }; + } + """, + """ + CharacterRangeTable: + 0, 0, c14, c15, 8 // 0, 0, 3:20, 3:21, flow-controller + 12, 15, 1014, 101d, 8 // 12, 15, 4:20, 4:29, flow-controller + 16, 18, 1014, 101d, 100 // 16, 18, 4:20, 4:29, branch-false + 19, 19, 1020, 1024, 10 // 19, 19, 4:32, 4:36, flow-target + 23, 23, 1027, 102c, 10 // 23, 23, 4:39, 4:44, flow-target + 12, 26, 1014, 102d, 11 // 12, 26, 4:20, 4:45, statement, flow-target + 0, 27, c05, 1407, 1 // 0, 27, 3:05, 5:07, statement + 0, 27, 820, 1802, 2 // 0, 27, 2:32, 6:02, block + """ + ); + doTest( + """ + private boolean convert(int i) { + return switch (i) { + case 1 -> switch (Integer.toString(i)) { + case "1" -> true; + default -> throw new IllegalStateException("failure"); + }; + default -> throw new IllegalStateException("failure"); + }; + } + """, + """ + CharacterRangeTable: + 0, 0, c14, c15, 8 // 0, 0, 3:20, 3:21, flow-controller + 20, 24, 1013, 102f, 1 // 20, 24, 4:19, 4:47, statement + 80, 83, 1419, 141e, 11 // 80, 83, 5:25, 5:30, statement, flow-target + 84, 93, 1818, 1843, 11 // 84, 93, 6:24, 6:67, statement, flow-target + 20, 96, 1013, 1c0b, 11 // 20, 96, 4:19, 7:11, statement, flow-target + 97, 106, 2014, 203f, 11 // 97, 106, 8:20, 8:63, statement, flow-target + 0, 107, c05, 2407, 1 // 0, 107, 3:05, 9:07, statement + 0, 107, 820, 2802, 2 // 0, 107, 2:32, 10:02, block + """ + ); } private void doTest(String code, String expected) throws Exception {