# HG changeset patch # User mcimadamore # Date 1366031765 -3600 # Node ID 6dacab0876521bbe14b031d5d59757a6878e77e1 # Parent 083c6b199e2ff8a55dbde79e3f3a27378a780a1e 8011028: lang/INFR/infr001/infr00101md/infr00101md.java fails to compile after switch to JDK8-b82 Summary: Fix bug in Types.removeWildcards Reviewed-by: jjg diff -r 083c6b199e2f -r 6dacab087652 src/share/classes/com/sun/tools/javac/code/Types.java --- a/src/share/classes/com/sun/tools/javac/code/Types.java Mon Apr 15 14:15:07 2013 +0100 +++ b/src/share/classes/com/sun/tools/javac/code/Types.java Mon Apr 15 14:16:05 2013 +0100 @@ -589,7 +589,7 @@ CapturedType capVar = (CapturedType)capturedTypeargs.head; //use declared bound if it doesn't depend on formal type-args bound = capVar.bound.containsAny(capturedSite.getTypeArguments()) ? - syms.objectType : capVar.bound; + wt.type : capVar.bound; break; default: bound = wt.type; diff -r 083c6b199e2f -r 6dacab087652 test/tools/javac/lambda/TargetType69.java --- a/test/tools/javac/lambda/TargetType69.java Mon Apr 15 14:15:07 2013 +0100 +++ b/test/tools/javac/lambda/TargetType69.java Mon Apr 15 14:16:05 2013 +0100 @@ -25,11 +25,11 @@ * @test * @bug 8010303 * @summary Graph inference: missing incorporation step causes spurious inference error - * @compile TargetType68.java + * @compile TargetType69.java */ import java.util.*; -class TargetType68 { +class TargetType69 { interface Function { Y m(X x); diff -r 083c6b199e2f -r 6dacab087652 test/tools/javac/lambda/TargetType70.java --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/test/tools/javac/lambda/TargetType70.java Mon Apr 15 14:16:05 2013 +0100 @@ -0,0 +1,52 @@ +/* + * Copyright (c) 2013, Oracle and/or its affiliates. All rights reserved. + * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. + * + * This code is free software; you can redistribute it and/or modify it + * under the terms of the GNU General Public License version 2 only, as + * published by the Free Software Foundation. + * + * This code is distributed in the hope that it will be useful, but WITHOUT + * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or + * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License + * version 2 for more details (a copy is included in the LICENSE file that + * accompanied this code). + * + * You should have received a copy of the GNU General Public License version + * 2 along with this work; if not, write to the Free Software Foundation, + * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. + * + * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA + * or visit www.oracle.com if you need additional information or have any + * questions. + */ + +/* + * @test + * @bug 8011028 + * @summary lang/INFR/infr001/infr00101md/infr00101md.java fails to compile after switch to JDK8-b82 + * @compile TargetType70.java + */ +class TargetType70 { + + static class Sup {} + static class Sub extends Sup {} + + interface I, U> { + T m(U o); + } + + static class GenSup { + GenSup(T f) { } + } + + static class GenSub extends GenSup { + GenSub(T f) { super(f); } + } + + void m(I, T> o1, T o2) { } + + void test(Sub sub) { + m(GenSub::new, sub); + } +}