From 1de40db76d5ece6bc713cb32e680e17c53675288 Mon Sep 17 00:00:00 2001 From: Maurizio Cimadamore Date: Tue, 1 Sep 2009 14:53:39 +0100 Subject: [PATCH] 6650759: Inference of formal type parameter (unused in formal parameters) is not performed Propagate inference constraints from 15.12.2.7 to 15.12.2.8 Reviewed-by: jjg --- .../com/sun/tools/javac/code/Type.java | 38 +++++++++++- .../com/sun/tools/javac/comp/Infer.java | 49 +++++++++++---- .../generics/inference/6302954/T6476073.java | 1 - .../generics/inference/6638712/T6638712b.out | 2 +- .../generics/inference/6638712/T6638712e.out | 2 +- .../generics/inference/6650759/T6650759a.java | 45 ++++++++++++++ .../generics/inference/6650759/T6650759b.java | 52 ++++++++++++++++ .../generics/inference/6650759/T6650759c.java | 49 +++++++++++++++ .../generics/inference/6650759/T6650759d.java | 51 ++++++++++++++++ .../generics/inference/6650759/T6650759e.java | 52 ++++++++++++++++ .../generics/inference/6650759/T6650759f.java | 50 ++++++++++++++++ .../generics/inference/6650759/T6650759g.java | 59 +++++++++++++++++++ .../generics/inference/6650759/T6650759h.java | 39 ++++++++++++ .../generics/inference/6650759/T6650759i.java | 54 +++++++++++++++++ .../generics/inference/6650759/T6650759j.java | 54 +++++++++++++++++ .../generics/inference/6650759/T6650759k.java | 44 ++++++++++++++ .../generics/inference/6650759/T6650759l.java | 46 +++++++++++++++ .../generics/inference/6650759/T6650759m.java | 47 +++++++++++++++ .../generics/inference/6650759/T6650759m.out | 2 + 19 files changed, 721 insertions(+), 15 deletions(-) create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759a.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759b.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759c.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759d.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759e.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759f.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759g.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759h.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759i.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759j.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759k.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759l.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759m.java create mode 100644 langtools/test/tools/javac/generics/inference/6650759/T6650759m.out diff --git a/langtools/src/share/classes/com/sun/tools/javac/code/Type.java b/langtools/src/share/classes/com/sun/tools/javac/code/Type.java index 402a36e065e..02057b48f9d 100644 --- a/langtools/src/share/classes/com/sun/tools/javac/code/Type.java +++ b/langtools/src/share/classes/com/sun/tools/javac/code/Type.java @@ -1068,7 +1068,7 @@ public class Type implements PrimitiveType { /** * Replaces this ForAll's typevars with a set of concrete Java types - * and returns the instantiated generic type. Subclasses might override + * and returns the instantiated generic type. Subclasses should override * in order to check that the list of types is a valid instantiation * of the ForAll's typevars. * @@ -1081,6 +1081,42 @@ public class Type implements PrimitiveType { return types.subst(qtype, tvars, actuals); } + /** + * Kind of type-constraint derived during type inference + */ + public enum ConstraintKind { + /** + * upper bound constraint (a type variable must be instantiated + * with a type T, where T is a subtype of all the types specified by + * its EXTENDS constraints). + */ + EXTENDS, + /** + * lower bound constraint (a type variable must be instantiated + * with a type T, where T is a supertype of all the types specified by + * its SUPER constraints). + */ + SUPER, + /** + * equality constraint (a type variable must be instantiated to the type + * specified by its EQUAL constraint. + */ + EQUAL; + } + + /** + * Get the type-constraints of a given kind for a given type-variable of + * this ForAll type. Subclasses should override in order to return more + * accurate sets of constraints. + * + * @param tv the type-variable for which the constraint is to be retrieved + * @param ck the constraint kind to be retrieved + * @return the list of types specified by the selected constraint + */ + public List getConstraints(TypeVar tv, ConstraintKind ck) { + return List.nil(); + } + public Type map(Mapping f) { return f.apply(qtype); } diff --git a/langtools/src/share/classes/com/sun/tools/javac/comp/Infer.java b/langtools/src/share/classes/com/sun/tools/javac/comp/Infer.java index 0a4f9cd25ff..840a97de5ce 100644 --- a/langtools/src/share/classes/com/sun/tools/javac/comp/Infer.java +++ b/langtools/src/share/classes/com/sun/tools/javac/comp/Infer.java @@ -29,6 +29,7 @@ import com.sun.tools.javac.util.*; import com.sun.tools.javac.util.List; import com.sun.tools.javac.code.*; import com.sun.tools.javac.code.Type.*; +import com.sun.tools.javac.code.Type.ForAll.ConstraintKind; import com.sun.tools.javac.code.Symbol.*; import com.sun.tools.javac.util.JCDiagnostic; @@ -50,6 +51,7 @@ public class Infer { Symtab syms; Types types; + Check chk; Resolve rs; JCDiagnostic.Factory diags; @@ -65,6 +67,7 @@ public class Infer { syms = Symtab.instance(context); types = Types.instance(context); rs = Resolve.instance(context); + chk = Check.instance(context); diags = JCDiagnostic.Factory.instance(context); ambiguousNoInstanceException = new NoInstanceException(true, diags); @@ -250,14 +253,19 @@ public class Infer { Warner warn) throws InferenceException { List undetvars = Type.map(that.tvars, fromTypeVarFun); for (List l = undetvars; l.nonEmpty(); l = l.tail) { - UndetVar v = (UndetVar) l.head; + UndetVar uv = (UndetVar) l.head; + TypeVar tv = (TypeVar)uv.qtype; ListBuffer hibounds = new ListBuffer(); - for (List l1 = types.getBounds((TypeVar) v.qtype); l1.nonEmpty(); l1 = l1.tail) { - if (!l1.head.containsSome(that.tvars)) { - hibounds.append(l1.head); + for (Type t : that.getConstraints(tv, ConstraintKind.EXTENDS).prependList(types.getBounds(tv))) { + if (!t.containsSome(that.tvars) && t.tag != BOT) { + hibounds.append(t); } } - v.hibounds = hibounds.toList(); + List inst = that.getConstraints(tv, ConstraintKind.EQUAL); + if (inst.nonEmpty() && inst.head.tag != BOT) { + uv.inst = inst.head; + } + uv.hibounds = hibounds.toList(); } Type qtype1 = types.subst(that.qtype, that.tvars, undetvars); if (!types.isSubtype(qtype1, to)) { @@ -273,7 +281,7 @@ public class Infer { List targs = Type.map(undetvars, getInstFun); targs = types.subst(targs, that.tvars, targs); checkWithinBounds(that.tvars, targs, warn); - return that.inst(targs, types); + return chk.checkType(warn.pos(), that.inst(targs, types), to); } /** Instantiate method type `mt' by finding instantiations of @@ -349,6 +357,9 @@ public class Infer { /** Type variables instantiated to bottom */ ListBuffer restvars = new ListBuffer(); + /** Undet vars instantiated to bottom */ + final ListBuffer restundet = new ListBuffer(); + /** Instantiated types or TypeVars if under-constrained */ ListBuffer insttypes = new ListBuffer(); @@ -359,6 +370,7 @@ public class Infer { UndetVar uv = (UndetVar)t; if (uv.inst.tag == BOT) { restvars.append(uv.qtype); + restundet.append(uv); insttypes.append(uv.qtype); undettypes.append(uv); uv.inst = null; @@ -378,18 +390,33 @@ public class Infer { final List all_tvars = tvars; //this is the wrong tvars final MethodType mt2 = new MethodType(mt.argtypes, null, mt.thrown, syms.methodClass); mt2.restype = new ForAll(restvars.toList(), mt.restype) { + @Override + public List getConstraints(TypeVar tv, ConstraintKind ck) { + for (Type t : restundet.toList()) { + UndetVar uv = (UndetVar)t; + if (uv.qtype == tv) { + switch (ck) { + case EXTENDS: return uv.hibounds; + case SUPER: return uv.lobounds; + case EQUAL: return uv.inst != null ? List.of(uv.inst) : List.nil(); + } + } + } + return List.nil(); + } + @Override public Type inst(List inferred, Types types) throws NoInstanceException { List formals = types.subst(mt2.argtypes, tvars, inferred); - if (!rs.argumentsAcceptable(capturedArgs, formals, + if (!rs.argumentsAcceptable(capturedArgs, formals, allowBoxing, useVarargs, warn)) { // inferred method is not applicable throw invalidInstanceException.setMessage("inferred.do.not.conform.to.params", formals, argtypes); - } - // check that inferred bounds conform to their bounds - checkWithinBounds(all_tvars, + } + // check that inferred bounds conform to their bounds + checkWithinBounds(all_tvars, types.subst(inferredTypes, tvars, inferred), warn); - return super.inst(inferred, types); + return super.inst(inferred, types); }}; return mt2; } diff --git a/langtools/test/tools/javac/generics/inference/6302954/T6476073.java b/langtools/test/tools/javac/generics/inference/6302954/T6476073.java index 8a5534b750c..cd3adbed499 100644 --- a/langtools/test/tools/javac/generics/inference/6302954/T6476073.java +++ b/langtools/test/tools/javac/generics/inference/6302954/T6476073.java @@ -25,7 +25,6 @@ * @test * @bug 6476073 * @summary Capture using super wildcard of type variables doesn't work - * @ignore awaiting for 6650759 (see bug report for a detailed evaluation) * @compile T6476073.java */ diff --git a/langtools/test/tools/javac/generics/inference/6638712/T6638712b.out b/langtools/test/tools/javac/generics/inference/6638712/T6638712b.out index 7fcf899ade9..ed77740a425 100644 --- a/langtools/test/tools/javac/generics/inference/6638712/T6638712b.out +++ b/langtools/test/tools/javac/generics/inference/6638712/T6638712b.out @@ -1,2 +1,2 @@ -T6638712b.java:14:21: compiler.err.invalid.inferred.types: T, (compiler.misc.inferred.do.not.conform.to.bounds: T6638712b, T6638712b) +T6638712b.java:14:21: compiler.err.prob.found.req: (compiler.misc.incompatible.types.1: (compiler.misc.no.conforming.instance.exists: T, T, java.lang.String)), T, java.lang.String 1 error diff --git a/langtools/test/tools/javac/generics/inference/6638712/T6638712e.out b/langtools/test/tools/javac/generics/inference/6638712/T6638712e.out index d17f38d1a0b..1ca268b830b 100644 --- a/langtools/test/tools/javac/generics/inference/6638712/T6638712e.out +++ b/langtools/test/tools/javac/generics/inference/6638712/T6638712e.out @@ -1,2 +1,2 @@ -T6638712e.java:17:27: compiler.err.invalid.inferred.types: X, (compiler.misc.inferred.do.not.conform.to.params: T6638712e.Foo, T6638712e.Foo) +T6638712e.java:17:27: compiler.err.prob.found.req: (compiler.misc.incompatible.types.1: (compiler.misc.no.conforming.instance.exists: X, T6638712e.Foo, T6638712e.Foo)), T6638712e.Foo, T6638712e.Foo 1 error diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759a.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759a.java new file mode 100644 index 00000000000..9e65330940a --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759a.java @@ -0,0 +1,45 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @author mcimadamore + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759a.java + */ + +class T6650759a { + + public static interface Interface { } + public static class IntegerInterface implements Interface { } + + , T> T getGenericValue(I test) { return null; } + + void testSet(Integer test) { } + + void test() { + Integer test = getGenericValue(new IntegerInterface()); + testSet(getGenericValue(new IntegerInterface())); + } +} \ No newline at end of file diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759b.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759b.java new file mode 100644 index 00000000000..b9d53bbd5e6 --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759b.java @@ -0,0 +1,52 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @author mcimadamore + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759b.java + */ + +public class T6650759b { + + interface A, Y extends B> {} + + static class B> {} + + interface C, Y extends B> {} + + interface D, Y extends B> {} + + static class E, Y extends B, W extends C> implements D { + + static , Y extends B, W extends C> D of(W w) { + return null; + } + } + + , Y extends B, W extends C, Z extends D> Z test(W w) { + return (Z) E.of(w); + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759c.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759c.java new file mode 100644 index 00000000000..e02918c6dc0 --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759c.java @@ -0,0 +1,49 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759c.java + */ + +import java.util.Collection; +import java.util.Collections; + +public class T6650759c { + + static interface A {} + + static interface B {} + + static interface C> {} + + public static > Collection> get(U u) { + return null; + } + + public > Collection> test(U u) { + return Collections.unmodifiableCollection(get(u)); + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759d.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759d.java new file mode 100644 index 00000000000..73b65339b35 --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759d.java @@ -0,0 +1,51 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759d.java + */ + +public class T6650759d { + + static abstract class A { + + static A m(Iterable elements) { + return null; + } + } + + static abstract class B {} + + static abstract class C {} + + , V extends B> Iterable get(U u) { + return null; + } + + , V extends B> void m(U u) { + A a = A.m(get(u)); + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759e.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759e.java new file mode 100644 index 00000000000..9fdc2b6d8ce --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759e.java @@ -0,0 +1,52 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759e.java + */ + +import java.util.List; + +public class T6650759e { + + static abstract class A {} + + interface B extends D {} + + static abstract class C {} + + interface D {} + + static abstract class E>> {} + + , V extends B, W extends A> W m1(E e) { + return m2(e); + } + + , V extends B, W extends A> W m2(E e) { + return null; + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759f.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759f.java new file mode 100644 index 00000000000..6393f81394a --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759f.java @@ -0,0 +1,50 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759f.java + */ + +import java.util.Collections; + +public class T6650759f { + + interface A {} + + static abstract class B implements A {} + + static abstract class C extends B {} + + static class D extends C {} + + > Iterable m(Y node) { + return null; + } + + public void test(D d) { + Iterable ops = (true) ? Collections.singletonList(d) : m(d); + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759g.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759g.java new file mode 100644 index 00000000000..a31fd10d08a --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759g.java @@ -0,0 +1,59 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759g.java + */ + +public class T6650759g { + + static abstract class A> {} + + static abstract class B> {} + + interface C {} + + static abstract class D, Y extends B> implements C {} + + static class E extends A {} + + static class F extends B {} + + static void test(Iterable data) { + m3(m2(data, m1(F.class))); + } + + static , Y extends B> D m1(Class c) { + return null; + } + + static Iterable m2(Iterable x1, C x2) { + return null; + } + + static void m3(Iterable data) { + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759h.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759h.java new file mode 100644 index 00000000000..a19cd369d5d --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759h.java @@ -0,0 +1,39 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759h.java + */ +class T6650759h { + + Object m(A a, T6650759h t) { + return null; + } + + void test(T6650759h t) { + m(null, t); + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759i.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759i.java new file mode 100644 index 00000000000..d186d3d5625 --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759i.java @@ -0,0 +1,54 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759i.java + */ +public class T6650759i { + + static class A {} + + static class B {} + + static class C, Y extends B> {} + + static , V extends B> Class m1(U x) { + return null; + } + + static , V extends B> U m2(Class c) { + return null; + } + + static , V extends B> W m3(Class c1, C c2) { + return null; + } + + static , V extends B> void test(U u, C c) { + m2(m1(u)); + U res = m3(m1(u), c); + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759j.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759j.java new file mode 100644 index 00000000000..1c78f8830e3 --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759j.java @@ -0,0 +1,54 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759j.java + */ + +public class T6650759j { + + static abstract class A> {} + + static abstract class B, Y> extends A {} + + static abstract class C, Y> extends B {} + + interface D {} + + static class E extends C {} + + static abstract class F, Y extends A> extends A {} + + static class G extends F {} + + static , Y extends A> X m(Iterable it) { + return null; + } + + static G test(Iterable c) { + return m(c); + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759k.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759k.java new file mode 100644 index 00000000000..a2a323f254f --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759k.java @@ -0,0 +1,44 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759k.java + */ + +public class T6650759k { + + static class A {} + + static class B {} + + , V extends B> Object m(Class c) { + return null; + } + + , V extends B> void test(Class c) { + m(c); + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759l.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759l.java new file mode 100644 index 00000000000..66d7bda9e5a --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759l.java @@ -0,0 +1,46 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile T6650759l.java + */ + +public class T6650759l { + + public static interface A {} + + public static class B implements A {} + + public static , Y> Y m1(X x) { + return null; + } + + public static void m2(Integer i) {} + + public static void test(B b) { + m2(m1(b)); + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759m.java b/langtools/test/tools/javac/generics/inference/6650759/T6650759m.java new file mode 100644 index 00000000000..f123e32962b --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759m.java @@ -0,0 +1,47 @@ +/* + * Copyright 2009 Sun Microsystems, Inc. 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 Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, + * CA 95054 USA or visit www.sun.com if you need additional information or + * have any questions. + */ + +/* + * @test + * @bug 6650759 + * @summary Inference of formal type parameter (unused in formal parameters) is not performed + * @compile/fail/ref=T6650759m.out T6650759m.java -XDrawDiagnostics + */ + +import java.util.*; + +class T6650759m { + List m(List> ls) { + return ls.get(0); + } + + void test() { + ArrayList> lli = new ArrayList>(); + ArrayList li = new ArrayList(); + li.add(2); + lli.add(li); + List ls = m(lli); //here + ls.add("crash"); + Integer i = li.get(1); + } +} diff --git a/langtools/test/tools/javac/generics/inference/6650759/T6650759m.out b/langtools/test/tools/javac/generics/inference/6650759/T6650759m.out new file mode 100644 index 00000000000..474d8db2e0f --- /dev/null +++ b/langtools/test/tools/javac/generics/inference/6650759/T6650759m.out @@ -0,0 +1,2 @@ +T6650759m.java:43:36: compiler.err.prob.found.req: (compiler.misc.incompatible.types), java.util.List, java.util.List +1 error