8302324: Inheritance tree does not show correct type parameters/arguments
Reviewed-by: prappo
This commit is contained in:
parent
7dfe75cf55
commit
6d4b02b6c9
@ -1093,22 +1093,8 @@ public class Utils {
|
|||||||
* be found.
|
* be found.
|
||||||
*/
|
*/
|
||||||
public TypeMirror getFirstVisibleSuperClass(TypeMirror type) {
|
public TypeMirror getFirstVisibleSuperClass(TypeMirror type) {
|
||||||
return getFirstVisibleSuperClass(asTypeElement(type));
|
List<? extends TypeMirror> superTypes = typeUtils.directSupertypes(type);
|
||||||
}
|
TypeMirror superType = superTypes.isEmpty() ? getObjectType() : superTypes.get(0);
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Given a class, return the closest visible superclass.
|
|
||||||
*
|
|
||||||
* @param te the TypeElement to be interrogated
|
|
||||||
* @return the closest visible superclass. Return null if it cannot
|
|
||||||
* be found.
|
|
||||||
*/
|
|
||||||
public TypeMirror getFirstVisibleSuperClass(TypeElement te) {
|
|
||||||
TypeMirror superType = te.getSuperclass();
|
|
||||||
if (isNoType(superType)) {
|
|
||||||
superType = getObjectType();
|
|
||||||
}
|
|
||||||
TypeElement superClass = asTypeElement(superType);
|
TypeElement superClass = asTypeElement(superType);
|
||||||
// skip "hidden" classes
|
// skip "hidden" classes
|
||||||
while ((superClass != null && hasHiddenTag(superClass))
|
while ((superClass != null && hasHiddenTag(superClass))
|
||||||
@ -1122,12 +1108,24 @@ public class Utils {
|
|||||||
superType = supersuperType;
|
superType = supersuperType;
|
||||||
superClass = supersuperClass;
|
superClass = supersuperClass;
|
||||||
}
|
}
|
||||||
if (typeUtils.isSameType(te.asType(), superType)) {
|
if (typeUtils.isSameType(type, superType)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
return superType;
|
return superType;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Given a class, return the closest visible superclass.
|
||||||
|
*
|
||||||
|
* @param te the TypeElement to be interrogated
|
||||||
|
* @return the closest visible superclass. Return null if it cannot
|
||||||
|
* be found.
|
||||||
|
*/
|
||||||
|
public TypeMirror getFirstVisibleSuperClass(TypeElement te) {
|
||||||
|
return getFirstVisibleSuperClass(te.asType());
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the name of the kind of a type element (Class, Interface, etc.).
|
* Returns the name of the kind of a type element (Class, Interface, etc.).
|
||||||
*
|
*
|
||||||
|
@ -0,0 +1,107 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2023, 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 8302324
|
||||||
|
* @summary Inheritance tree does not show correct type parameters/arguments
|
||||||
|
* @library /tools/lib ../../lib
|
||||||
|
* @modules jdk.javadoc/jdk.javadoc.internal.tool
|
||||||
|
* @build toolbox.ToolBox javadoc.tester.*
|
||||||
|
* @run main TestInheritance
|
||||||
|
*/
|
||||||
|
|
||||||
|
import java.nio.file.Path;
|
||||||
|
|
||||||
|
import javadoc.tester.JavadocTester;
|
||||||
|
import toolbox.ToolBox;
|
||||||
|
|
||||||
|
public class TestInheritance extends JavadocTester {
|
||||||
|
|
||||||
|
public static void main(String... args) throws Exception {
|
||||||
|
var test = new TestInheritance();
|
||||||
|
test.runTests();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testInheritanceGeneric(Path base) throws Exception {
|
||||||
|
Path src = base.resolve("src");
|
||||||
|
new ToolBox().writeJavaFiles(src, """
|
||||||
|
package pkg;
|
||||||
|
/**
|
||||||
|
* Base class
|
||||||
|
* @param <M> param M
|
||||||
|
* @param <N> param N
|
||||||
|
*/
|
||||||
|
public class A<M, N> { private A() { } }
|
||||||
|
""",
|
||||||
|
"""
|
||||||
|
package pkg;
|
||||||
|
/**
|
||||||
|
* First subclass
|
||||||
|
* @param <O> param O
|
||||||
|
* @param <P> param P
|
||||||
|
*/
|
||||||
|
public class B<O, P> extends A<O, P> { private B() { } }
|
||||||
|
""",
|
||||||
|
"""
|
||||||
|
package pkg;
|
||||||
|
/**
|
||||||
|
* Second subclass
|
||||||
|
* @param <Q> param Q
|
||||||
|
*/
|
||||||
|
public class C<Q> extends B<String, Q> { private C() { } }
|
||||||
|
""",
|
||||||
|
"""
|
||||||
|
package pkg;
|
||||||
|
/**
|
||||||
|
* Second subclass
|
||||||
|
* @param <R> param R
|
||||||
|
* @param <S> param S
|
||||||
|
*/
|
||||||
|
public class D<R, S> extends B<S, B> { private D() { } }
|
||||||
|
""");
|
||||||
|
javadoc("-d", base.resolve("docs").toString(),
|
||||||
|
"-sourcepath", src.toString(),
|
||||||
|
"--no-platform-links",
|
||||||
|
"pkg");
|
||||||
|
checkExit(Exit.OK);
|
||||||
|
checkOrder("pkg/A.html", """
|
||||||
|
<div class="inheritance" title="Inheritance Tree">java.lang.Object
|
||||||
|
<div class="inheritance">pkg.A<M,<wbr>N></div>""");
|
||||||
|
checkOrder("pkg/B.html", """
|
||||||
|
<div class="inheritance" title="Inheritance Tree">java.lang.Object
|
||||||
|
<div class="inheritance"><a href="A.html" title="class in pkg">pkg.A</a><O,<wbr>P>
|
||||||
|
<div class="inheritance">pkg.B<O,<wbr>P></div>""");
|
||||||
|
checkOrder("pkg/C.html", """
|
||||||
|
<div class="inheritance" title="Inheritance Tree">java.lang.Object
|
||||||
|
<div class="inheritance"><a href="A.html" title="class in pkg">pkg.A</a><java.lang.String,<wbr>Q>
|
||||||
|
<div class="inheritance"><a href="B.html" title="class in pkg">pkg.B</a><java.lang.String,<wbr>Q>
|
||||||
|
<div class="inheritance">pkg.C<Q></div>""");
|
||||||
|
checkOrder("pkg/D.html", """
|
||||||
|
<div class="inheritance" title="Inheritance Tree">java.lang.Object
|
||||||
|
<div class="inheritance"><a href="A.html" title="class in pkg">pkg.A</a><S,<wbr><a href="B.html" title="class in pkg">B</a>>
|
||||||
|
<div class="inheritance"><a href="B.html" title="class in pkg">pkg.B</a><S,<wbr><a href="B.html" title="class in pkg">B</a>>
|
||||||
|
<div class="inheritance">pkg.D<R,<wbr>S></div>""");
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user