Skip to content

Commit 726c9c9

Browse files
committedSep 7, 2023
8315735: VerifyError when switch statement used with synchronized block
Reviewed-by: vromero
1 parent fd6442c commit 726c9c9

File tree

2 files changed

+74
-5
lines changed

2 files changed

+74
-5
lines changed
 

‎src/jdk.compiler/share/classes/com/sun/tools/javac/jvm/Gen.java

+15-5
Original file line numberDiff line numberDiff line change
@@ -1278,11 +1278,17 @@ private void doHandleSwitchExpression(JCSwitchExpression tree) {
12781278
}
12791279
//where:
12801280
private boolean hasTry(JCSwitchExpression tree) {
1281-
boolean[] hasTry = new boolean[1];
1282-
new TreeScanner() {
1281+
class HasTryScanner extends TreeScanner {
1282+
private boolean hasTry;
1283+
12831284
@Override
12841285
public void visitTry(JCTry tree) {
1285-
hasTry[0] = true;
1286+
hasTry = true;
1287+
}
1288+
1289+
@Override
1290+
public void visitSynchronized(JCSynchronized tree) {
1291+
hasTry = true;
12861292
}
12871293

12881294
@Override
@@ -1292,8 +1298,12 @@ public void visitClassDef(JCClassDecl tree) {
12921298
@Override
12931299
public void visitLambda(JCLambda tree) {
12941300
}
1295-
}.scan(tree);
1296-
return hasTry[0];
1301+
};
1302+
1303+
HasTryScanner hasTryScanner = new HasTryScanner();
1304+
1305+
hasTryScanner.scan(tree);
1306+
return hasTryScanner.hasTry;
12971307
}
12981308

12991309
private void handleSwitch(JCTree swtch, JCExpression selector, List<JCCase> cases,
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,59 @@
1+
/*
2+
* Copyright (c) 2023, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* This code is free software; you can redistribute it and/or modify it
6+
* under the terms of the GNU General Public License version 2 only, as
7+
* published by the Free Software Foundation.
8+
*
9+
* This code is distributed in the hope that it will be useful, but WITHOUT
10+
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
11+
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
12+
* version 2 for more details (a copy is included in the LICENSE file that
13+
* accompanied this code).
14+
*
15+
* You should have received a copy of the GNU General Public License version
16+
* 2 along with this work; if not, write to the Free Software Foundation,
17+
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
18+
*
19+
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
20+
* or visit www.oracle.com if you need additional information or have any
21+
* questions.
22+
*/
23+
24+
/**
25+
* @test
26+
* @bug 8315735
27+
* @summary Verify valid classfile is produced when synchronized block is used
28+
* inside a switch expression.
29+
* @compile ExpressionSwitchSynchronized.java
30+
* @run main ExpressionSwitchSynchronized
31+
*/
32+
public class ExpressionSwitchSynchronized {
33+
34+
public static void main(String... args) {
35+
int i1 = 2 + switch (args.length) {
36+
default -> {
37+
synchronized (args) {
38+
yield 1;
39+
}
40+
}
41+
};
42+
if (i1 != 3) {
43+
throw new AssertionError("Incorrect value, got: " + i1 +
44+
", expected: " + 3);
45+
}
46+
int i2 = 2 + switch (args) {
47+
case String[] a -> {
48+
synchronized (args) {
49+
yield a.length + 1;
50+
}
51+
}
52+
};
53+
if (i2 != 3) {
54+
throw new AssertionError("Incorrect value, got: " + i2 +
55+
", expected: " + 3);
56+
}
57+
}
58+
59+
}

0 commit comments

Comments
 (0)
Please sign in to comment.