From 64288e1e762aef8e8e9a22bdbd2c3d8aa14a095a Mon Sep 17 00:00:00 2001 From: Vicente Romero Date: Mon, 27 Jan 2020 18:50:19 -0500 Subject: [PATCH] 8235149: javac parser is too aggressive on ambiguous expressions using identifier: record Reviewed-by: mcimadamore --- .../com/sun/tools/javac/parser/JavacParser.java | 2 +- .../javac/records/RecordCompilationTests.java | 15 +++++++++++++-- 2 files changed, 14 insertions(+), 3 deletions(-) diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/JavacParser.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/JavacParser.java index 1a603a010e5..cf7fd7d7cb5 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/JavacParser.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/parser/JavacParser.java @@ -4023,7 +4023,7 @@ public class JavacParser implements Parser { int pos = token.pos; JCModifiers mods = modifiersOpt(); if (token.kind == CLASS || - isRecordStart() || + allowRecords && isRecordStart() || token.kind == INTERFACE || token.kind == ENUM) { return List.of(classOrRecordOrInterfaceOrEnumDeclaration(mods, dc)); diff --git a/test/langtools/tools/javac/records/RecordCompilationTests.java b/test/langtools/tools/javac/records/RecordCompilationTests.java index f358c078ce1..360f181d413 100644 --- a/test/langtools/tools/javac/records/RecordCompilationTests.java +++ b/test/langtools/tools/javac/records/RecordCompilationTests.java @@ -625,6 +625,19 @@ public class RecordCompilationTests extends CompilationTestCase { Assert.check(numberOfFieldRefs == 1); } + public void testAcceptRecordId() { + String[] testOptions = {/* no options */}; + setCompileOptions(testOptions); + assertOKWithWarning("compiler.warn.restricted.type.not.allowed.preview", + "class R {\n" + + " record RR(int i) {\n" + + " return null;\n" + + " }\n" + + " class record {}\n" + + "}"); + setCompileOptions(PREVIEW_OPTIONS); + } + public void testAnnos() throws Exception { String srcTemplate = """ @@ -861,14 +874,12 @@ public class RecordCompilationTests extends CompilationTestCase { @Override public boolean process(Set annotations, RoundEnvironment roundEnv) { targets = processingEnv.getOptions().get("targets"); - System.out.println("targets------------------------------------------------- " + targets); for (TypeElement te : annotations) { if (te.toString().equals("Anno")) { checkElements(te, roundEnv, targets); if (targets.contains("TYPE_USE")) { Element element = processingEnv.getElementUtils().getTypeElement("R"); numberOfTypeAnnotations = 0; - System.out.println("element found --------------------------------- " + element); checkTypeAnnotations(element); Assert.check(numberOfTypeAnnotations == 4); }