6531090: Cannot access methods/fields of a captured type belonging to an intersection type
Fixed lookup of field/methods on intersection types Reviewed-by: jjg
This commit is contained in:
parent
8ef814eb9c
commit
1be460dbdd
@ -1298,7 +1298,7 @@ public class Types {
|
|||||||
return t;
|
return t;
|
||||||
|
|
||||||
Type st = supertype(t);
|
Type st = supertype(t);
|
||||||
if (st.tag == CLASS || st.tag == ERROR) {
|
if (st.tag == CLASS || st.tag == TYPEVAR || st.tag == ERROR) {
|
||||||
Type x = asSuper(st, sym);
|
Type x = asSuper(st, sym);
|
||||||
if (x != null)
|
if (x != null)
|
||||||
return x;
|
return x;
|
||||||
@ -1320,6 +1320,9 @@ public class Types {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Type visitTypeVar(TypeVar t, Symbol sym) {
|
public Type visitTypeVar(TypeVar t, Symbol sym) {
|
||||||
|
if (t.tsym == sym)
|
||||||
|
return t;
|
||||||
|
else
|
||||||
return asSuper(t.bound, sym);
|
return asSuper(t.bound, sym);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -407,6 +407,8 @@ public class Resolve {
|
|||||||
Type site,
|
Type site,
|
||||||
Name name,
|
Name name,
|
||||||
TypeSymbol c) {
|
TypeSymbol c) {
|
||||||
|
while (c.type.tag == TYPEVAR)
|
||||||
|
c = c.type.getUpperBound().tsym;
|
||||||
Symbol bestSoFar = varNotFound;
|
Symbol bestSoFar = varNotFound;
|
||||||
Symbol sym;
|
Symbol sym;
|
||||||
Scope.Entry e = c.members().lookup(name);
|
Scope.Entry e = c.members().lookup(name);
|
||||||
@ -418,7 +420,7 @@ public class Resolve {
|
|||||||
e = e.next();
|
e = e.next();
|
||||||
}
|
}
|
||||||
Type st = types.supertype(c.type);
|
Type st = types.supertype(c.type);
|
||||||
if (st != null && st.tag == CLASS) {
|
if (st != null && (st.tag == CLASS || st.tag == TYPEVAR)) {
|
||||||
sym = findField(env, site, name, st.tsym);
|
sym = findField(env, site, name, st.tsym);
|
||||||
if (sym.kind < bestSoFar.kind) bestSoFar = sym;
|
if (sym.kind < bestSoFar.kind) bestSoFar = sym;
|
||||||
}
|
}
|
||||||
@ -733,7 +735,9 @@ public class Resolve {
|
|||||||
boolean allowBoxing,
|
boolean allowBoxing,
|
||||||
boolean useVarargs,
|
boolean useVarargs,
|
||||||
boolean operator) {
|
boolean operator) {
|
||||||
for (Type ct = intype; ct.tag == CLASS; ct = types.supertype(ct)) {
|
for (Type ct = intype; ct.tag == CLASS || ct.tag == TYPEVAR; ct = types.supertype(ct)) {
|
||||||
|
while (ct.tag == TYPEVAR)
|
||||||
|
ct = ct.getUpperBound();
|
||||||
ClassSymbol c = (ClassSymbol)ct.tsym;
|
ClassSymbol c = (ClassSymbol)ct.tsym;
|
||||||
if ((c.flags() & (ABSTRACT | INTERFACE)) == 0)
|
if ((c.flags() & (ABSTRACT | INTERFACE)) == 0)
|
||||||
abstractok = false;
|
abstractok = false;
|
||||||
|
59
langtools/test/tools/javac/generics/6531090/T6531090a.java
Normal file
59
langtools/test/tools/javac/generics/6531090/T6531090a.java
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2008 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 6531090
|
||||||
|
*
|
||||||
|
* @summary Cannot access methods/fields of a captured type belonging to an intersection type
|
||||||
|
* @author Maurizio Cimadamore
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class T6531090a {
|
||||||
|
|
||||||
|
static class E {}
|
||||||
|
|
||||||
|
static class F extends E implements I1 {}
|
||||||
|
|
||||||
|
static interface I {}
|
||||||
|
|
||||||
|
static interface I1 {}
|
||||||
|
|
||||||
|
static class G extends F implements I {}
|
||||||
|
|
||||||
|
static class C<T extends E & I> {
|
||||||
|
T field;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String... args) {
|
||||||
|
test(new C<G>());
|
||||||
|
}
|
||||||
|
|
||||||
|
static <W extends F> void test(C<? extends W> arg) {
|
||||||
|
F vf = arg.field;
|
||||||
|
I vi = arg.field;
|
||||||
|
I1 vi1 = arg.field;
|
||||||
|
E ve = arg.field;
|
||||||
|
W vt = arg.field;
|
||||||
|
}
|
||||||
|
}
|
82
langtools/test/tools/javac/generics/6531090/T6531090b.java
Normal file
82
langtools/test/tools/javac/generics/6531090/T6531090b.java
Normal file
@ -0,0 +1,82 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2008 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 6531090
|
||||||
|
*
|
||||||
|
* @summary Cannot access methods/fields of a captured type belonging to an intersection type
|
||||||
|
* @author Maurizio Cimadamore
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
public class T6531090b {
|
||||||
|
|
||||||
|
static class A {
|
||||||
|
public void a() {}
|
||||||
|
public A a;
|
||||||
|
}
|
||||||
|
static class B extends A {
|
||||||
|
public void b(){}
|
||||||
|
public B b;
|
||||||
|
}
|
||||||
|
static interface I{
|
||||||
|
void i();
|
||||||
|
}
|
||||||
|
static interface I1{
|
||||||
|
void i1();
|
||||||
|
}
|
||||||
|
static class E extends B implements I, I1{
|
||||||
|
public void i() {}
|
||||||
|
public void i1() {}
|
||||||
|
}
|
||||||
|
static class C<W extends B & I1, T extends W>{
|
||||||
|
T t;
|
||||||
|
W w;
|
||||||
|
C(W w, T t) {
|
||||||
|
this.w = w;
|
||||||
|
this.t = t;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void main(String... args) {
|
||||||
|
C<E,E> c = new C<E,E>(new E(), new E());
|
||||||
|
testMemberMethods(c);
|
||||||
|
testMemberFields(c);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void testMemberMethods(C<? extends A, ? extends I> arg) {
|
||||||
|
arg.t.a();
|
||||||
|
arg.t.b();
|
||||||
|
arg.t.i1();
|
||||||
|
arg.w.a();
|
||||||
|
arg.w.b();
|
||||||
|
arg.w.i1();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void testMemberFields(C<? extends A, ? extends I> arg) {
|
||||||
|
A ta = arg.t.a;
|
||||||
|
B tb = arg.t.b;
|
||||||
|
A wa = arg.w.a;
|
||||||
|
B wb = arg.w.b;
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user