From 2c453c5844b04e8533977f46fd1a9aa04b9b2d36 Mon Sep 17 00:00:00 2001 From: Maurizio Cimadamore Date: Wed, 11 Jan 2012 18:23:24 +0000 Subject: [PATCH 1/5] 7126754: Generics compilation failure casting List to List Problems with Types.rewriteQuantifiers not preserving variance Reviewed-by: jjg --- .../com/sun/tools/javac/code/Types.java | 47 ++++++++++--------- .../tools/javac/cast/7126754/T7126754.java | 14 ++++++ .../tools/javac/cast/7126754/T7126754.out | 4 ++ 3 files changed, 44 insertions(+), 21 deletions(-) create mode 100644 langtools/test/tools/javac/cast/7126754/T7126754.java create mode 100644 langtools/test/tools/javac/cast/7126754/T7126754.out diff --git a/langtools/src/share/classes/com/sun/tools/javac/code/Types.java b/langtools/src/share/classes/com/sun/tools/javac/code/Types.java index 5fc9d4547ed..aac5c29f1a0 100644 --- a/langtools/src/share/classes/com/sun/tools/javac/code/Types.java +++ b/langtools/src/share/classes/com/sun/tools/javac/code/Types.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2012, 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 @@ -3600,39 +3600,44 @@ public class Types { @Override public Type visitCapturedType(CapturedType t, Void s) { - Type bound = visitWildcardType(t.wildcard, null); - return (bound.contains(t)) ? - erasure(bound) : - bound; + Type w_bound = t.wildcard.type; + Type bound = w_bound.contains(t) ? + erasure(w_bound) : + visit(w_bound); + return rewriteAsWildcardType(visit(bound), t.wildcard.bound, t.wildcard.kind); } @Override public Type visitTypeVar(TypeVar t, Void s) { if (rewriteTypeVars) { - Type bound = high ? - (t.bound.contains(t) ? + Type bound = t.bound.contains(t) ? erasure(t.bound) : - visit(t.bound)) : - syms.botType; - return rewriteAsWildcardType(bound, t); - } - else + visit(t.bound); + return rewriteAsWildcardType(bound, t, EXTENDS); + } else { return t; + } } @Override public Type visitWildcardType(WildcardType t, Void s) { - Type bound = high ? t.getExtendsBound() : - t.getSuperBound(); - if (bound == null) - bound = high ? syms.objectType : syms.botType; - return rewriteAsWildcardType(visit(bound), t.bound); + Type bound2 = visit(t.type); + return t.type == bound2 ? t : rewriteAsWildcardType(bound2, t.bound, t.kind); } - private Type rewriteAsWildcardType(Type bound, TypeVar formal) { - return high ? - makeExtendsWildcard(B(bound), formal) : - makeSuperWildcard(B(bound), formal); + private Type rewriteAsWildcardType(Type bound, TypeVar formal, BoundKind bk) { + switch (bk) { + case EXTENDS: return high ? + makeExtendsWildcard(B(bound), formal) : + makeExtendsWildcard(syms.objectType, formal); + case SUPER: return high ? + makeSuperWildcard(syms.botType, formal) : + makeSuperWildcard(B(bound), formal); + case UNBOUND: return makeExtendsWildcard(syms.objectType, formal); + default: + Assert.error("Invalid bound kind " + bk); + return null; + } } Type B(Type t) { diff --git a/langtools/test/tools/javac/cast/7126754/T7126754.java b/langtools/test/tools/javac/cast/7126754/T7126754.java new file mode 100644 index 00000000000..79e49ecf23a --- /dev/null +++ b/langtools/test/tools/javac/cast/7126754/T7126754.java @@ -0,0 +1,14 @@ +/* + * @test /nodynamiccopyright/ + * @author mcimadamore + * @bug 7005671 + * @summary Generics compilation failure casting List to List + * @compile/fail/ref=T7126754.out -Xlint:unchecked -Werror -XDrawDiagnostics T7126754.java + */ + +import java.util.List; + +class T7126754 { + List> c = null; + List> d = (List>)c; +} diff --git a/langtools/test/tools/javac/cast/7126754/T7126754.out b/langtools/test/tools/javac/cast/7126754/T7126754.out new file mode 100644 index 00000000000..73baf16fe12 --- /dev/null +++ b/langtools/test/tools/javac/cast/7126754/T7126754.out @@ -0,0 +1,4 @@ +T7126754.java:13:68: compiler.warn.prob.found.req: (compiler.misc.unchecked.cast.to.type), java.util.List>, java.util.List> +- compiler.err.warnings.and.werror +1 error +1 warning From 1b000de1866fbf19a2217b1148d548d920fd084e Mon Sep 17 00:00:00 2001 From: Maurizio Cimadamore Date: Thu, 12 Jan 2012 15:28:34 +0000 Subject: [PATCH 2/5] 7123100: javac fails with java.lang.StackOverflowError Inference of under-constrained type-variables creates erroneous recursive wildcard types Reviewed-by: jjg --- .../classes/com/sun/tools/javac/comp/Infer.java | 14 +++++++++----- .../test/tools/javac/cast/7123100/T7123100a.java | 16 ++++++++++++++++ .../test/tools/javac/cast/7123100/T7123100a.out | 4 ++++ .../test/tools/javac/cast/7123100/T7123100b.java | 12 ++++++++++++ .../test/tools/javac/cast/7123100/T7123100b.out | 4 ++++ .../test/tools/javac/cast/7123100/T7123100c.java | 16 ++++++++++++++++ .../test/tools/javac/cast/7123100/T7123100c.out | 4 ++++ .../test/tools/javac/cast/7123100/T7123100d.java | 16 ++++++++++++++++ .../test/tools/javac/cast/7123100/T7123100d.out | 4 ++++ 9 files changed, 85 insertions(+), 5 deletions(-) create mode 100644 langtools/test/tools/javac/cast/7123100/T7123100a.java create mode 100644 langtools/test/tools/javac/cast/7123100/T7123100a.out create mode 100644 langtools/test/tools/javac/cast/7123100/T7123100b.java create mode 100644 langtools/test/tools/javac/cast/7123100/T7123100b.out create mode 100644 langtools/test/tools/javac/cast/7123100/T7123100c.java create mode 100644 langtools/test/tools/javac/cast/7123100/T7123100c.out create mode 100644 langtools/test/tools/javac/cast/7123100/T7123100d.java create mode 100644 langtools/test/tools/javac/cast/7123100/T7123100d.out 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 00564d9e5f7..17ce35af2c1 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 @@ -1,5 +1,5 @@ /* - * Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1999, 2012, 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 @@ -332,25 +332,29 @@ public class Infer { //replace uninferred type-vars targs = types.subst(targs, that.tvars, - instaniateAsUninferredVars(undetvars, that.tvars)); + instantiateAsUninferredVars(undetvars, that.tvars)); } return chk.checkType(warn.pos(), that.inst(targs, types), to); } //where - private List instaniateAsUninferredVars(List undetvars, List tvars) { + private List instantiateAsUninferredVars(List undetvars, List tvars) { + Assert.check(undetvars.length() == tvars.length()); ListBuffer new_targs = ListBuffer.lb(); - //step 1 - create syntethic captured vars + //step 1 - create synthetic captured vars for (Type t : undetvars) { UndetVar uv = (UndetVar)t; Type newArg = new CapturedType(t.tsym.name, t.tsym, uv.inst, syms.botType, null); new_targs = new_targs.append(newArg); } //step 2 - replace synthetic vars in their bounds + List formals = tvars; for (Type t : new_targs.toList()) { CapturedType ct = (CapturedType)t; ct.bound = types.subst(ct.bound, tvars, new_targs.toList()); - WildcardType wt = new WildcardType(ct.bound, BoundKind.EXTENDS, syms.boundClass); + WildcardType wt = new WildcardType(syms.objectType, BoundKind.UNBOUND, syms.boundClass); + wt.bound = (TypeVar)formals.head; ct.wildcard = wt; + formals = formals.tail; } return new_targs.toList(); } diff --git a/langtools/test/tools/javac/cast/7123100/T7123100a.java b/langtools/test/tools/javac/cast/7123100/T7123100a.java new file mode 100644 index 00000000000..1fbee2c2cfb --- /dev/null +++ b/langtools/test/tools/javac/cast/7123100/T7123100a.java @@ -0,0 +1,16 @@ +/* + * @test /nodynamiccopyright/ + * @bug 7123100 + * @summary javac fails with java.lang.StackOverflowError + * @compile/fail/ref=T7123100a.out -Werror -Xlint:unchecked -XDrawDiagnostics T7123100a.java + */ + +class T7123100a { + > E m() { + return null; + } + + void test() { + Z z = (Z)m(); + } +} diff --git a/langtools/test/tools/javac/cast/7123100/T7123100a.out b/langtools/test/tools/javac/cast/7123100/T7123100a.out new file mode 100644 index 00000000000..a816314f5b5 --- /dev/null +++ b/langtools/test/tools/javac/cast/7123100/T7123100a.out @@ -0,0 +1,4 @@ +T7123100a.java:14:19: compiler.warn.prob.found.req: (compiler.misc.unchecked.cast.to.type), compiler.misc.type.captureof: 1, ?, Z +- compiler.err.warnings.and.werror +1 error +1 warning diff --git a/langtools/test/tools/javac/cast/7123100/T7123100b.java b/langtools/test/tools/javac/cast/7123100/T7123100b.java new file mode 100644 index 00000000000..6a96afa270d --- /dev/null +++ b/langtools/test/tools/javac/cast/7123100/T7123100b.java @@ -0,0 +1,12 @@ +/* + * @test /nodynamiccopyright/ + * @bug 7123100 + * @summary javac fails with java.lang.StackOverflowError + * @compile/fail/ref=T7123100b.out -Werror -Xlint:unchecked -XDrawDiagnostics T7123100b.java + */ + +class T7123100b { + void test(Enum e) { + Z z = (Z)e; + } +} diff --git a/langtools/test/tools/javac/cast/7123100/T7123100b.out b/langtools/test/tools/javac/cast/7123100/T7123100b.out new file mode 100644 index 00000000000..7c3c1d689e5 --- /dev/null +++ b/langtools/test/tools/javac/cast/7123100/T7123100b.out @@ -0,0 +1,4 @@ +T7123100b.java:10:18: compiler.warn.prob.found.req: (compiler.misc.unchecked.cast.to.type), java.lang.Enum, Z +- compiler.err.warnings.and.werror +1 error +1 warning diff --git a/langtools/test/tools/javac/cast/7123100/T7123100c.java b/langtools/test/tools/javac/cast/7123100/T7123100c.java new file mode 100644 index 00000000000..cb8816174dd --- /dev/null +++ b/langtools/test/tools/javac/cast/7123100/T7123100c.java @@ -0,0 +1,16 @@ +/* + * @test /nodynamiccopyright/ + * @bug 7123100 + * @summary javac fails with java.lang.StackOverflowError + * @compile/fail/ref=T7123100c.out -Werror -Xlint:unchecked -XDrawDiagnostics T7123100c.java + */ + +class T7123100c { + E m(E e) { + return null; + } + + void test(Enum e) { + Z z = (Z)m(e); + } +} diff --git a/langtools/test/tools/javac/cast/7123100/T7123100c.out b/langtools/test/tools/javac/cast/7123100/T7123100c.out new file mode 100644 index 00000000000..9af9357e551 --- /dev/null +++ b/langtools/test/tools/javac/cast/7123100/T7123100c.out @@ -0,0 +1,4 @@ +T7123100c.java:14:19: compiler.warn.prob.found.req: (compiler.misc.unchecked.cast.to.type), java.lang.Enum, Z +- compiler.err.warnings.and.werror +1 error +1 warning diff --git a/langtools/test/tools/javac/cast/7123100/T7123100d.java b/langtools/test/tools/javac/cast/7123100/T7123100d.java new file mode 100644 index 00000000000..90002d3be4b --- /dev/null +++ b/langtools/test/tools/javac/cast/7123100/T7123100d.java @@ -0,0 +1,16 @@ +/* + * @test /nodynamiccopyright/ + * @bug 7123100 + * @summary javac fails with java.lang.StackOverflowError + * @compile/fail/ref=T7123100d.out -Werror -Xlint:unchecked -XDrawDiagnostics T7123100d.java + */ + +class T7123100d { + > E m(Enum e) { + return null; + } + + void test(Enum e) { + Z z = (Z)m(e); + } +} diff --git a/langtools/test/tools/javac/cast/7123100/T7123100d.out b/langtools/test/tools/javac/cast/7123100/T7123100d.out new file mode 100644 index 00000000000..52a9ce31750 --- /dev/null +++ b/langtools/test/tools/javac/cast/7123100/T7123100d.out @@ -0,0 +1,4 @@ +T7123100d.java:14:19: compiler.warn.prob.found.req: (compiler.misc.unchecked.cast.to.type), compiler.misc.type.captureof: 1, ?, Z +- compiler.err.warnings.and.werror +1 error +1 warning From 3d0da40b0d2b54b06c67b43060ba40cdd9228f9c Mon Sep 17 00:00:00 2001 From: Jim Holmlund Date: Tue, 17 Jan 2012 17:14:44 -0800 Subject: [PATCH 3/5] 7127924: langtools regression tests sometimes fail en-masse on windows Reviewed-by: jjg --- langtools/test/tools/javac/diags/CheckExamples.java | 7 +++++-- langtools/test/tools/javac/diags/MessageInfo.java | 7 +++++-- langtools/test/tools/javac/diags/RunExamples.java | 7 +++++-- 3 files changed, 15 insertions(+), 6 deletions(-) diff --git a/langtools/test/tools/javac/diags/CheckExamples.java b/langtools/test/tools/javac/diags/CheckExamples.java index b29c5447b97..648f9833e6c 100644 --- a/langtools/test/tools/javac/diags/CheckExamples.java +++ b/langtools/test/tools/javac/diags/CheckExamples.java @@ -23,10 +23,13 @@ /* * @test - * @bug 6968063 + * @bug 6968063, 7127924 * @summary provide examples of code that generate diagnostics * @build Example CheckExamples - * @run main CheckExamples + * @run main/othervm CheckExamples + */ +/* + * See CR 7127924 for info on why othervm is used. */ import java.io.*; diff --git a/langtools/test/tools/javac/diags/MessageInfo.java b/langtools/test/tools/javac/diags/MessageInfo.java index 885183cd1d8..8e40670efca 100644 --- a/langtools/test/tools/javac/diags/MessageInfo.java +++ b/langtools/test/tools/javac/diags/MessageInfo.java @@ -23,10 +23,13 @@ /** * @test - * @bug 7013272 + * @bug 7013272, 7127924 * @summary Automatically generate info about how compiler resource keys are used * @build Example ArgTypeCompilerFactory MessageFile MessageInfo - * @run main MessageInfo + * @run main/othervm MessageInfo + */ +/* + * See CR 7127924 for info on why othervm is used. */ import java.io.*; diff --git a/langtools/test/tools/javac/diags/RunExamples.java b/langtools/test/tools/javac/diags/RunExamples.java index e4234d53a3b..c09947cdf3e 100644 --- a/langtools/test/tools/javac/diags/RunExamples.java +++ b/langtools/test/tools/javac/diags/RunExamples.java @@ -23,10 +23,13 @@ /** * @test - * @bug 6968063 + * @bug 6968063, 7127924 * @summary provide examples of code that generate diagnostics * @build ArgTypeCompilerFactory Example HTMLWriter RunExamples - * @run main RunExamples + * @run main/othervm RunExamples + */ +/* + * See CR 7127924 for info on why othervm is used. */ import java.io.*; From c569749a21865c071db7b7669b4ff8c172c0c20c Mon Sep 17 00:00:00 2001 From: Joe Darcy Date: Wed, 18 Jan 2012 16:43:59 -0800 Subject: [PATCH 4/5] 7130768: Clarify behavior of Element.getEnclosingElements in subtypes Reviewed-by: mcimadamore, jjg --- .../javax/lang/model/element/Element.java | 17 +++++++++-------- .../lang/model/element/PackageElement.java | 18 ++++++++++++++++-- .../javax/lang/model/element/TypeElement.java | 10 ++++++++-- 3 files changed, 33 insertions(+), 12 deletions(-) diff --git a/langtools/src/share/classes/javax/lang/model/element/Element.java b/langtools/src/share/classes/javax/lang/model/element/Element.java index 06500d2afaf..6d2743ca324 100644 --- a/langtools/src/share/classes/javax/lang/model/element/Element.java +++ b/langtools/src/share/classes/javax/lang/model/element/Element.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2012, 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 @@ -214,14 +214,13 @@ public interface Element { * Returns the elements that are, loosely speaking, directly * enclosed by this element. * - * A class or interface is considered to enclose the fields, - * methods, constructors, and member types that it directly - * declares. This includes any (implicit) default constructor and - * the implicit {@code values} and {@code valueOf} methods of an - * enum type. + * A {@linkplain TypeElement#getEnclosedElements class or + * interface} is considered to enclose the fields, methods, + * constructors, and member types that it directly declares. * - * A package encloses the top-level classes and interfaces within - * it, but is not considered to enclose subpackages. + * A {@linkplain PackageElement#getEnclosedElements package} + * encloses the top-level classes and interfaces within it, but is + * not considered to enclose subpackages. * * Other kinds of elements are not currently considered to enclose * any elements; however, that may change as this API or the @@ -231,6 +230,8 @@ public interface Element { * methods in {@link ElementFilter}. * * @return the enclosed elements, or an empty list if none + * @see PackageElement#getEnclosedElements + * @see TypeElement#getEnclosedElements * @see Elements#getAllMembers * @jls 8.8.9 Default Constructor * @jls 8.9 Enums diff --git a/langtools/src/share/classes/javax/lang/model/element/PackageElement.java b/langtools/src/share/classes/javax/lang/model/element/PackageElement.java index 66f13863ff0..1aafd3476f9 100644 --- a/langtools/src/share/classes/javax/lang/model/element/PackageElement.java +++ b/langtools/src/share/classes/javax/lang/model/element/PackageElement.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2012, 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 @@ -25,6 +25,8 @@ package javax.lang.model.element; +import java.util.List; + /** * Represents a package program element. Provides access to information * about the package and its members. @@ -49,7 +51,7 @@ public interface PackageElement extends Element, QualifiedNameable { /** * Returns the simple name of this package. For an unnamed - * package, an empty name is returned + * package, an empty name is returned. * * @return the simple name of this package or an empty name if * this is an unnamed package @@ -57,6 +59,18 @@ public interface PackageElement extends Element, QualifiedNameable { @Override Name getSimpleName(); + /** + * Returns the {@linkplain NestingKind#TOP_LEVEL top-level} + * classes and interfaces within this package. Note that + * subpackages are not considered to be enclosed by a + * package. + * + * @return the top-level classes and interfaces within this + * package + */ + @Override + List getEnclosedElements(); + /** * Returns {@code true} is this is an unnamed package and {@code * false} otherwise. diff --git a/langtools/src/share/classes/javax/lang/model/element/TypeElement.java b/langtools/src/share/classes/javax/lang/model/element/TypeElement.java index d73adfeec7e..a86db829b21 100644 --- a/langtools/src/share/classes/javax/lang/model/element/TypeElement.java +++ b/langtools/src/share/classes/javax/lang/model/element/TypeElement.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2005, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2005, 2012, 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 @@ -61,7 +61,12 @@ import javax.lang.model.util.*; */ public interface TypeElement extends Element, Parameterizable, QualifiedNameable { /** - * {@inheritDoc} + * Returns the fields, methods, constructors, and member types + * that are directly declared in this class or interface. + * + * This includes any (implicit) default constructor and + * the implicit {@code values} and {@code valueOf} methods of an + * enum type. * *

Note that as a particular instance of the {@linkplain * javax.lang.model.element general accuracy requirements} and the @@ -75,6 +80,7 @@ public interface TypeElement extends Element, Parameterizable, QualifiedNameable * * @return the enclosed elements in proper order, or an empty list if none */ + @Override List getEnclosedElements(); /** From 323665eec5a90c577876e6783a2899ac192e274f Mon Sep 17 00:00:00 2001 From: Jim Holmlund Date: Wed, 18 Jan 2012 18:26:36 -0800 Subject: [PATCH 5/5] 7131308: Three regression tests fail due to bad fix for 7127924 Reviewed-by: jjg --- langtools/test/tools/javac/diags/CheckExamples.java | 2 +- langtools/test/tools/javac/diags/MessageInfo.java | 2 +- langtools/test/tools/javac/diags/RunExamples.java | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/langtools/test/tools/javac/diags/CheckExamples.java b/langtools/test/tools/javac/diags/CheckExamples.java index 648f9833e6c..aa35fc1589b 100644 --- a/langtools/test/tools/javac/diags/CheckExamples.java +++ b/langtools/test/tools/javac/diags/CheckExamples.java @@ -23,7 +23,7 @@ /* * @test - * @bug 6968063, 7127924 + * @bug 6968063 7127924 * @summary provide examples of code that generate diagnostics * @build Example CheckExamples * @run main/othervm CheckExamples diff --git a/langtools/test/tools/javac/diags/MessageInfo.java b/langtools/test/tools/javac/diags/MessageInfo.java index 8e40670efca..f053b3da3be 100644 --- a/langtools/test/tools/javac/diags/MessageInfo.java +++ b/langtools/test/tools/javac/diags/MessageInfo.java @@ -23,7 +23,7 @@ /** * @test - * @bug 7013272, 7127924 + * @bug 7013272 7127924 * @summary Automatically generate info about how compiler resource keys are used * @build Example ArgTypeCompilerFactory MessageFile MessageInfo * @run main/othervm MessageInfo diff --git a/langtools/test/tools/javac/diags/RunExamples.java b/langtools/test/tools/javac/diags/RunExamples.java index c09947cdf3e..858948387a6 100644 --- a/langtools/test/tools/javac/diags/RunExamples.java +++ b/langtools/test/tools/javac/diags/RunExamples.java @@ -23,7 +23,7 @@ /** * @test - * @bug 6968063, 7127924 + * @bug 6968063 7127924 * @summary provide examples of code that generate diagnostics * @build ArgTypeCompilerFactory Example HTMLWriter RunExamples * @run main/othervm RunExamples