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;
|
||||
|
||||
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);
|
||||
if (x != null)
|
||||
return x;
|
||||
@ -1320,7 +1320,10 @@ public class Types {
|
||||
|
||||
@Override
|
||||
public Type visitTypeVar(TypeVar t, Symbol sym) {
|
||||
return asSuper(t.bound, sym);
|
||||
if (t.tsym == sym)
|
||||
return t;
|
||||
else
|
||||
return asSuper(t.bound, sym);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -407,6 +407,8 @@ public class Resolve {
|
||||
Type site,
|
||||
Name name,
|
||||
TypeSymbol c) {
|
||||
while (c.type.tag == TYPEVAR)
|
||||
c = c.type.getUpperBound().tsym;
|
||||
Symbol bestSoFar = varNotFound;
|
||||
Symbol sym;
|
||||
Scope.Entry e = c.members().lookup(name);
|
||||
@ -418,7 +420,7 @@ public class Resolve {
|
||||
e = e.next();
|
||||
}
|
||||
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);
|
||||
if (sym.kind < bestSoFar.kind) bestSoFar = sym;
|
||||
}
|
||||
@ -733,7 +735,9 @@ public class Resolve {
|
||||
boolean allowBoxing,
|
||||
boolean useVarargs,
|
||||
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;
|
||||
if ((c.flags() & (ABSTRACT | INTERFACE)) == 0)
|
||||
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