From 418c9789d6f4f8e757cd501878cc4299e66b6d0c Mon Sep 17 00:00:00 2001 From: Vicente Romero Date: Thu, 20 Nov 2014 09:43:13 -0800 Subject: [PATCH] 8059921: Missing compile error in Java 8 mode for Interface.super.field access Reviewed-by: mcimadamore, jlahoda --- .../com/sun/tools/javac/comp/Attr.java | 4 +++ .../ForbidAccessToFieldUsingSuperTest.java | 31 +++++++++++++++++++ .../ForbidAccessToFieldUsingSuperTest.out | 3 ++ 3 files changed, 38 insertions(+) create mode 100644 langtools/test/tools/javac/T8059921/ForbidAccessToFieldUsingSuperTest.java create mode 100644 langtools/test/tools/javac/T8059921/ForbidAccessToFieldUsingSuperTest.out diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java index 1fe0b48eb30..6101af3ba42 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Attr.java @@ -3233,6 +3233,10 @@ public class Attr extends JCTree.Visitor { // Determine the symbol represented by the selection. env.info.pendingResolutionPhase = null; Symbol sym = selectSym(tree, sitesym, site, env, resultInfo); + if (sym.kind == VAR && sym.name != names._super && env.info.defaultSuperCallSite != null) { + log.error(tree.selected.pos(), "not.encl.class", site.tsym); + sym = syms.errSymbol; + } if (sym.exists() && !isType(sym) && pkind().contains(KindSelector.TYP_PCK)) { site = capture(site); sym = selectSym(tree, sitesym, site, env, resultInfo); diff --git a/langtools/test/tools/javac/T8059921/ForbidAccessToFieldUsingSuperTest.java b/langtools/test/tools/javac/T8059921/ForbidAccessToFieldUsingSuperTest.java new file mode 100644 index 00000000000..5bd3171a193 --- /dev/null +++ b/langtools/test/tools/javac/T8059921/ForbidAccessToFieldUsingSuperTest.java @@ -0,0 +1,31 @@ +/* + * @test /nodynamiccopyright/ + * @bug 8059921 + * @summary Missing compile error in Java 8 mode for Interface.super.field access + * @compile/fail/ref=ForbidAccessToFieldUsingSuperTest.out -XDrawDiagnostics ForbidAccessToFieldUsingSuperTest.java + */ + +public class ForbidAccessToFieldUsingSuperTest { + class C { + int m() { return 0; } + } + + interface T { + int f = 0; + C c = null; + default int mm() { + return 0; + } + } + + interface T1 extends T {} + + class X implements T1 { + int i = T1.super.f; //fail + int j = T1.super.c.m(); //fail + + void foo(Runnable r) { + foo(T1.super::mm); //should'n fail + } + } +} diff --git a/langtools/test/tools/javac/T8059921/ForbidAccessToFieldUsingSuperTest.out b/langtools/test/tools/javac/T8059921/ForbidAccessToFieldUsingSuperTest.out new file mode 100644 index 00000000000..b4424f978cd --- /dev/null +++ b/langtools/test/tools/javac/T8059921/ForbidAccessToFieldUsingSuperTest.out @@ -0,0 +1,3 @@ +ForbidAccessToFieldUsingSuperTest.java:24:19: compiler.err.not.encl.class: ForbidAccessToFieldUsingSuperTest.T1 +ForbidAccessToFieldUsingSuperTest.java:25:19: compiler.err.not.encl.class: ForbidAccessToFieldUsingSuperTest.T1 +2 errors