From c047c5cfcf554b0e4536d8399a423d8982442b5a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Hannes=20Walln=C3=B6fer?= Date: Thu, 22 Nov 2018 15:38:20 +0100 Subject: [PATCH] 8200432: javadoc fails with ClassCastException on {@link byte[]} Reviewed-by: jjg, sundar --- .../com/sun/tools/doclint/Checker.java | 19 ++++++++---- .../doclint/resources/doclint.properties | 1 + .../com/sun/tools/javac/api/JavacTrees.java | 9 +++++- .../javadoc/doclet/testSeeTag/TestSeeTag.java | 19 ++++++++++-- .../doclet/testSeeTag/badref/Test.java | 30 +++++++++++++++++++ .../tools/doclint/ReferenceTest.java | 14 ++++++++- .../langtools/tools/doclint/ReferenceTest.out | 28 +++++++++++++++-- 7 files changed, 109 insertions(+), 11 deletions(-) create mode 100644 test/langtools/jdk/javadoc/doclet/testSeeTag/badref/Test.java diff --git a/src/jdk.compiler/share/classes/com/sun/tools/doclint/Checker.java b/src/jdk.compiler/share/classes/com/sun/tools/doclint/Checker.java index 268a62cc98b..f3f63f295c4 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/doclint/Checker.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/doclint/Checker.java @@ -882,12 +882,15 @@ public class Checker extends DocTreePathScanner { @Override @DefinedBy(Api.COMPILER_TREE) public Void visitReference(ReferenceTree tree, Void ignore) { String sig = tree.getSignature(); - if (sig.contains("<") || sig.contains(">")) + if (sig.contains("<") || sig.contains(">")) { env.messages.error(REFERENCE, tree, "dc.type.arg.not.allowed"); - - Element e = env.trees.getElement(getCurrentPath()); - if (e == null) - env.messages.error(REFERENCE, tree, "dc.ref.not.found"); + } else if (isArrayType(sig)) { + env.messages.error(REFERENCE, tree, "dc.array.type.not.allowed"); + } else { + Element e = env.trees.getElement(getCurrentPath()); + if (e == null) + env.messages.error(REFERENCE, tree, "dc.ref.not.found"); + } return super.visitReference(tree, ignore); } @@ -972,6 +975,12 @@ public class Checker extends DocTreePathScanner { return scan(tree.getDescription(), ignore); } + private boolean isArrayType(String signature) { + int brackets = signature.indexOf('['); + int parens = signature.indexOf('('); + return brackets >= 0 && (parens < 0 || brackets < parens); + } + private boolean isThrowable(TypeMirror tm) { switch (tm.getKind()) { case DECLARED: diff --git a/src/jdk.compiler/share/classes/com/sun/tools/doclint/resources/doclint.properties b/src/jdk.compiler/share/classes/com/sun/tools/doclint/resources/doclint.properties index 221cb3573c8..56afea1aea4 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/doclint/resources/doclint.properties +++ b/src/jdk.compiler/share/classes/com/sun/tools/doclint/resources/doclint.properties @@ -25,6 +25,7 @@ dc.anchor.already.defined = anchor already defined: "{0}" dc.anchor.value.missing = no value given for anchor +dc.array.type.not.allowed = array type not allowed here dc.attr.lacks.value = attribute lacks value dc.attr.not.number = attribute value is not a number dc.attr.not.supported.html4 = attribute not supported in HTML4: {0} diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/api/JavacTrees.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/api/JavacTrees.java index f73cf898c6d..13af71d65f4 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/api/JavacTrees.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/api/JavacTrees.java @@ -443,7 +443,11 @@ public class JavacTrees extends DocTrees { // we first check if qualifierExpression identifies a type, // and if not, then we check to see if it identifies a package. Type t = attr.attribType(ref.qualifierExpression, env); - if (t.isErroneous()) { + + if (t.getKind() == TypeKind.ARRAY) { + // cannot refer to an array type + return null; + } else if (t.isErroneous()) { JCCompilationUnit toplevel = treeMaker.TopLevel(List.nil()); final ModuleSymbol msym = modules.getDefaultModule(); @@ -451,6 +455,9 @@ public class JavacTrees extends DocTrees { toplevel.packge = msym.unnamedPackage; Symbol sym = attr.attribIdent(ref.qualifierExpression, toplevel); + if (sym == null) + return null; + sym.complete(); if ((sym.kind == PCK || sym.kind == TYP) && sym.exists()) { diff --git a/test/langtools/jdk/javadoc/doclet/testSeeTag/TestSeeTag.java b/test/langtools/jdk/javadoc/doclet/testSeeTag/TestSeeTag.java index 5df366cf093..1e9df13cb51 100644 --- a/test/langtools/jdk/javadoc/doclet/testSeeTag/TestSeeTag.java +++ b/test/langtools/jdk/javadoc/doclet/testSeeTag/TestSeeTag.java @@ -23,7 +23,7 @@ /* * @test - * @bug 8017191 8182765 + * @bug 8017191 8182765 8200432 * @summary Javadoc is confused by at-link to imported classes outside of the set of generated packages * @author jjg * @library ../lib @@ -83,5 +83,20 @@ public class TestSeeTag extends JavadocTester { + "Javadoc, \n" + "something\n" + ""); -} + } + + @Test + void testBadReference() { + javadoc("-d", "out-badref", + "-sourcepath", testSrc, + "badref"); + checkExit(Exit.ERROR); + + checkOutput("badref/Test.html", true, + "
\n" + + "
See Also:
\n" + + "
Object[], \n" + + "Foo
\n" + + "
"); + } } diff --git a/test/langtools/jdk/javadoc/doclet/testSeeTag/badref/Test.java b/test/langtools/jdk/javadoc/doclet/testSeeTag/badref/Test.java new file mode 100644 index 00000000000..6dabc35bc03 --- /dev/null +++ b/test/langtools/jdk/javadoc/doclet/testSeeTag/badref/Test.java @@ -0,0 +1,30 @@ +/* + * Copyright (c) 2018, 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. + */ + +package badref; + +/** + * @see Object[] + * @see Foo + */ +public interface Test {} diff --git a/test/langtools/tools/doclint/ReferenceTest.java b/test/langtools/tools/doclint/ReferenceTest.java index ccee4b25400..62010d52dfe 100644 --- a/test/langtools/tools/doclint/ReferenceTest.java +++ b/test/langtools/tools/doclint/ReferenceTest.java @@ -1,6 +1,6 @@ /* * @test /nodynamiccopyright/ - * @bug 8004832 8020556 8002154 + * @bug 8004832 8020556 8002154 8200432 * @summary Add new doclint package * @modules jdk.compiler/com.sun.tools.doclint * @build DocLintTester @@ -59,9 +59,21 @@ public class ReferenceTest { /** * {@link java.util.List} * {@link java.util.List#equals} + * {@link not.Found} * @see java.util.List * @see java.util.List#equals + * @see not.Found */ public void invalid_type_args() { } + + /** + * {@link java.lang.String[]} + * {@link java.lang.String[]#equals} + * {@link not.Found[]} + * @see java.lang.String[] + * @see java.lang.String[]#equals + * @see not.Found[] + */ + public void invalid_array_types() { } } diff --git a/test/langtools/tools/doclint/ReferenceTest.out b/test/langtools/tools/doclint/ReferenceTest.out index f48396db54b..e9a9f04f5f1 100644 --- a/test/langtools/tools/doclint/ReferenceTest.out +++ b/test/langtools/tools/doclint/ReferenceTest.out @@ -32,11 +32,35 @@ ReferenceTest.java:61: error: type arguments not allowed here * {@link java.util.List#equals} ^ ReferenceTest.java:62: error: type arguments not allowed here + * {@link not.Found} + ^ +ReferenceTest.java:63: error: type arguments not allowed here * @see java.util.List ^ -ReferenceTest.java:63: error: type arguments not allowed here +ReferenceTest.java:64: error: type arguments not allowed here * @see java.util.List#equals ^ -12 errors +ReferenceTest.java:65: error: type arguments not allowed here + * @see not.Found + ^ +ReferenceTest.java:70: error: array type not allowed here + * {@link java.lang.String[]} + ^ +ReferenceTest.java:71: error: array type not allowed here + * {@link java.lang.String[]#equals} + ^ +ReferenceTest.java:72: error: array type not allowed here + * {@link not.Found[]} + ^ +ReferenceTest.java:73: error: array type not allowed here + * @see java.lang.String[] + ^ +ReferenceTest.java:74: error: array type not allowed here + * @see java.lang.String[]#equals + ^ +ReferenceTest.java:75: error: array type not allowed here + * @see not.Found[] + ^ +20 errors 1 warning