From f2ee4e4240f422123af12cf8ed3fc99f3c859249 Mon Sep 17 00:00:00 2001 From: Srikanth Adayapalam Date: Sat, 25 Apr 2015 15:59:54 +0530 Subject: [PATCH] 8078592: Compiler fails to reject erroneous use of diamond with anonymous classes involving "fresh" type variables Reviewed-by: mcimadamore --- .../com/sun/tools/javac/comp/Check.java | 9 +++++ .../javac/generics/diamond/neg/Neg20.java | 36 +++++++++++++++++++ .../javac/generics/diamond/neg/Neg20.out | 2 ++ 3 files changed, 47 insertions(+) create mode 100644 langtools/test/tools/javac/generics/diamond/neg/Neg20.java create mode 100644 langtools/test/tools/javac/generics/diamond/neg/Neg20.out diff --git a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Check.java b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Check.java index de5f429d25b..afefb5b3c94 100644 --- a/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Check.java +++ b/langtools/src/jdk.compiler/share/classes/com/sun/tools/javac/comp/Check.java @@ -841,6 +841,15 @@ public class Check { } return true; } + + @Override + public Boolean visitTypeVar(TypeVar t, Void s) { + /* Any type variable mentioned in the inferred type must have been declared as a type parameter + (i.e cannot have been produced by capture conversion (5.1.10) or by inference (18.4) + */ + return t.tsym.owner.type.getTypeArguments().contains(t); + } + @Override public Boolean visitCapturedType(CapturedType t, Void s) { return false; diff --git a/langtools/test/tools/javac/generics/diamond/neg/Neg20.java b/langtools/test/tools/javac/generics/diamond/neg/Neg20.java new file mode 100644 index 00000000000..80fa234660b --- /dev/null +++ b/langtools/test/tools/javac/generics/diamond/neg/Neg20.java @@ -0,0 +1,36 @@ +/* + * @test /nodynamiccopyright/ + * @bug 8078592 + * @summary Compiler fails to reject erroneous use of diamond with anonymous classes involving "fresh" type variables. + * @compile/fail/ref=Neg20.out Neg20.java -XDrawDiagnostics + */ +import java.lang.annotation.ElementType; +import java.lang.annotation.Target; + +public class Neg20 { + static class Foo> { + public Foo complexMethod(E a) { + return this; + } + } + + static class Goo<@T E> { + public Goo complexMethod(E a) { + return this; + } + } + + static class B { + } + + @Target(ElementType.TYPE_USE) + static @interface T { + } + + public static void check() { + Foo t4 = new Foo<>() { + }; + Goo g4 = new Goo<>() { + }; + } +} diff --git a/langtools/test/tools/javac/generics/diamond/neg/Neg20.out b/langtools/test/tools/javac/generics/diamond/neg/Neg20.out new file mode 100644 index 00000000000..cbffb053ec1 --- /dev/null +++ b/langtools/test/tools/javac/generics/diamond/neg/Neg20.out @@ -0,0 +1,2 @@ +Neg20.java:31:28: compiler.err.cant.apply.diamond.1: (compiler.misc.diamond: Neg20.Foo), (compiler.misc.diamond.invalid.arg: E, (compiler.misc.diamond: Neg20.Foo)) +1 error