From e8bb2c186fbd3e521fb43f2e0ce4e11bf5805f4f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20Fournier?= Date: Sun, 23 Aug 2020 21:31:32 +0200 Subject: [PATCH] Fix parse error with synchronized stmt --- pmd-java/etc/grammar/Java.jjt | 6 +++--- .../pmd/lang/java/ast/ParserCornersTest.java | 5 +++++ .../pmd/lang/java/ast/SynchronizedStmts.java | 9 +++++++++ .../pmd/lang/java/ast/SynchronizedStmts.txt | 13 +++++++++++++ 4 files changed, 30 insertions(+), 3 deletions(-) create mode 100644 pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/ast/SynchronizedStmts.java create mode 100644 pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/ast/SynchronizedStmts.txt diff --git a/pmd-java/etc/grammar/Java.jjt b/pmd-java/etc/grammar/Java.jjt index 46c177afda..d855fc0e22 100644 --- a/pmd-java/etc/grammar/Java.jjt +++ b/pmd-java/etc/grammar/Java.jjt @@ -2225,9 +2225,9 @@ void BlockStatement() #void: private void LocalTypeStartNoIdent() #void: // A lookahead {} -{ // notice: not default - "public" | "static" | "protected" | "private" | "final" - | "abstract" | "synchronized" | "native" | "transient" +{ // notice: not default, not synchronized, not final + "public" | "static" | "protected" | "private" + | "abstract" | "native" | "transient" | "volatile" | "strictfp" | "class" | "interface" diff --git a/pmd-java/src/test/java/net/sourceforge/pmd/lang/java/ast/ParserCornersTest.java b/pmd-java/src/test/java/net/sourceforge/pmd/lang/java/ast/ParserCornersTest.java index ada51709ee..2c4faf85f9 100644 --- a/pmd-java/src/test/java/net/sourceforge/pmd/lang/java/ast/ParserCornersTest.java +++ b/pmd-java/src/test/java/net/sourceforge/pmd/lang/java/ast/ParserCornersTest.java @@ -222,6 +222,11 @@ public class ParserCornersTest extends BaseJavaTreeDumpTest { doTest("SwitchStatements"); } + @Test + public void testSynchronizedStatements() { + doTest("SynchronizedStmts"); + } + private static final String GENERICS_PROBLEM = "public class Test {\n public void test() {\n String o = super. doStuff(\"\");\n }\n}"; diff --git a/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/ast/SynchronizedStmts.java b/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/ast/SynchronizedStmts.java new file mode 100644 index 0000000000..2782f54288 --- /dev/null +++ b/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/ast/SynchronizedStmts.java @@ -0,0 +1,9 @@ + +class Sync { + public static void getInstance() { + synchronized (0) { // note that synchronized is also a modifier + return; + } + } + +} diff --git a/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/ast/SynchronizedStmts.txt b/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/ast/SynchronizedStmts.txt new file mode 100644 index 0000000000..8ee7e54976 --- /dev/null +++ b/pmd-java/src/test/resources/net/sourceforge/pmd/lang/java/ast/SynchronizedStmts.txt @@ -0,0 +1,13 @@ ++- CompilationUnit[@PackageName = ""] + +- ClassOrInterfaceDeclaration[@Abstract = "false", @Annotation = "false", @Anonymous = "false", @BinaryName = "Sync", @CanonicalName = "Sync", @Enum = "false", @Interface = "false", @Local = "false", @Nested = "false", @PackageName = "", @PackagePrivate = "true", @Record = "false", @RegularClass = "true", @SimpleName = "Sync", @TopLevel = "true", @Visibility = "package"] + +- ModifierList[@EffectiveModifiers = "{}", @ExplicitModifiers = "{}"] + +- ClassOrInterfaceBody[@Size = "1"] + +- MethodDeclaration[@Abstract = "false", @Arity = "0", @Image = "getInstance", @Name = "getInstance", @Varargs = "false", @Visibility = "public", @Void = "true"] + +- ModifierList[@EffectiveModifiers = "{public, static}", @ExplicitModifiers = "{public, static}"] + +- VoidType[] + +- FormalParameters[@Size = "0"] + +- Block[@Size = "1", @containsComment = "false"] + +- SynchronizedStatement[] + +- NumericLiteral[@Base = "10", @CompileTimeConstant = "true", @DoubleLiteral = "false", @FloatLiteral = "false", @Image = "0", @IntLiteral = "true", @Integral = "true", @LongLiteral = "false", @ParenthesisDepth = "0", @Parenthesized = "false", @PrimitiveType = "int", @ValueAsDouble = "0.0", @ValueAsFloat = "0.0", @ValueAsInt = "0", @ValueAsLong = "0"] + +- Block[@Size = "1", @containsComment = "false"] + +- ReturnStatement[]