From 8aa9bf5cc67d654ff909cfe68a2b5e96daa546ac Mon Sep 17 00:00:00 2001 From: Maurizio Cimadamore Date: Thu, 28 Jan 2016 14:06:27 +0000 Subject: [PATCH] 8148213: Regression: nested unchecked call does not trigger erasure of return type FreeTypeListener was deferred too much and caused loss of unchecked warning while in the middle of overload Reviewed-by: vromero --- .../com/sun/tools/javac/comp/Attr.java | 2 +- .../generics/inference/8148213/T8148213.java | 30 +++++++++++++++++++ .../generics/inference/8148213/T8148213.out | 5 ++++ 3 files changed, 36 insertions(+), 1 deletion(-) create mode 100644 langtools/test/tools/javac/generics/inference/8148213/T8148213.java create mode 100644 langtools/test/tools/javac/generics/inference/8148213/T8148213.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 d5bc1cdedef..f62d866bacb 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 @@ -239,7 +239,7 @@ public class Attr extends JCTree.Visitor { //this means we are dealing with a partially inferred poly expression owntype = shouldCheck ? resultInfo.pt : found; if (resultInfo.checkMode.installPostInferenceHook()) { - inferenceContext.addFreeTypeListener(List.of(found, resultInfo.pt), + inferenceContext.addFreeTypeListener(List.of(found), instantiatedContext -> { ResultInfo pendingResult = resultInfo.dup(inferenceContext.asInstType(resultInfo.pt)); diff --git a/langtools/test/tools/javac/generics/inference/8148213/T8148213.java b/langtools/test/tools/javac/generics/inference/8148213/T8148213.java new file mode 100644 index 00000000000..b7837687638 --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/8148213/T8148213.java @@ -0,0 +1,30 @@ +/* + * @test /nodynamiccopyright/ + * @bug 8148213 + * @summary Regression: nested unchecked call does not trigger erasure of return type + * + * @compile/fail/ref=T8148213.out -Werror -Xlint:unchecked -XDrawDiagnostics T8148213.java + */ + +abstract class T8148213 { + + interface R { } + + interface Q { } + + interface T { + Q n(R r); + } + + abstract T isA(Class t); + + abstract S w(T t); + + interface S { + S t(T value); + } + + void f(T t, Q q) { + w(t.n(isA(R.class))).t(q); + } +} diff --git a/langtools/test/tools/javac/generics/inference/8148213/T8148213.out b/langtools/test/tools/javac/generics/inference/8148213/T8148213.out new file mode 100644 index 00000000000..0da4f8cb68e --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/8148213/T8148213.out @@ -0,0 +1,5 @@ +T8148213.java:28:14: compiler.warn.unchecked.meth.invocation.applied: kindname.method, n, T8148213.R, T8148213.R, kindname.interface, T8148213.T +T8148213.java:28:18: compiler.warn.prob.found.req: (compiler.misc.unchecked.assign), T8148213.R, T8148213.R +- compiler.err.warnings.and.werror +1 error +2 warnings