From c2e69df562a9de07aff8036c74ef4b3f755c7121 Mon Sep 17 00:00:00 2001 From: Vicente Romero Date: Mon, 27 Jan 2020 23:06:46 -0500 Subject: [PATCH] 8235778: No compilation error reported when a record is declared in a local class Reviewed-by: mcimadamore --- .../com/sun/tools/javac/comp/Check.java | 3 ++ .../javac/records/RecordCompilationTests.java | 37 +++++++++++++++++++ 2 files changed, 40 insertions(+) diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Check.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Check.java index f19d9f62514..59f22a0cf3c 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Check.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Check.java @@ -1207,6 +1207,9 @@ public class Check { mask = (flags & RECORD) != 0 ? LocalRecordFlags : LocalClassFlags; if ((flags & RECORD) != 0) { implicit = STATIC; + if (sym.owner.kind == TYP) { + log.error(pos, Errors.RecordDeclarationNotAllowedInInnerClasses); + } } if ((sym.owner.flags_field & STATIC) == 0 && (flags & ENUM) != 0) { diff --git a/test/langtools/tools/javac/records/RecordCompilationTests.java b/test/langtools/tools/javac/records/RecordCompilationTests.java index 33c443d184d..bc204ab3ede 100644 --- a/test/langtools/tools/javac/records/RecordCompilationTests.java +++ b/test/langtools/tools/javac/records/RecordCompilationTests.java @@ -417,6 +417,14 @@ public class RecordCompilationTests extends CompilationTestCase { " record RR(int x) { public int x() { return z; }};\n" + " }\n" + "}"); + // can be contained inside a lambda + assertOK(""" + class Outer { + Runnable run = () -> { + record TestRecord(int i) {} + }; + } + """); // Can't self-shadow assertFail("compiler.err.already.defined", @@ -488,6 +496,35 @@ public class RecordCompilationTests extends CompilationTestCase { " record R(int a) {}\n" + " }\n" + "}"); + assertFail("compiler.err.record.declaration.not.allowed.in.inner.classes", + """ + class Outer { + public void test() { + class Inner extends Outer { + record R(int i) {} + } + } + } + """); + assertFail("compiler.err.record.declaration.not.allowed.in.inner.classes", + """ + class Outer { + Runnable run = new Runnable() { + record TestRecord(int i) {} + public void run() {} + }; + } + """); + assertFail("compiler.err.record.declaration.not.allowed.in.inner.classes", + """ + class Outer { + void m() { + record A() { + record B() { } + } + } + } + """); } public void testReceiverParameter() {