8235778: No compilation error reported when a record is declared in a local class

Reviewed-by: mcimadamore
This commit is contained in:
Vicente Romero 2019-12-16 15:33:03 -05:00
parent 1b4b652408
commit 89e0d29101
2 changed files with 40 additions and 0 deletions

View File

@ -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) {

View File

@ -383,6 +383,14 @@ public class RecordCompilationTests extends CompilationTestCase {
" record RR(int x) { public int x() { return y; }};\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",
@ -431,5 +439,34 @@ 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() { }
}
}
}
""");
}
}