diff --git a/langtools/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/DocEnv.java b/langtools/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/DocEnv.java index 1168986a93b..0be30ebf45a 100644 --- a/langtools/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/DocEnv.java +++ b/langtools/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/DocEnv.java @@ -705,14 +705,6 @@ public class DocEnv { return false; } - @Override @DefinedBy(Api.LANGUAGE_MODEL) - public Boolean defaultAction(Element e, Void p) { - if (includedSet.contains(e) || shouldDocument(e)) { - return true; - } - return false; - } - @Override @DefinedBy(Api.LANGUAGE_MODEL) public Boolean visitPackage(PackageElement e, Void p) { return includedSet.contains(e); @@ -720,7 +712,12 @@ public class DocEnv { @Override @DefinedBy(Api.LANGUAGE_MODEL) public Boolean visitUnknown(Element e, Void p) { - throw new AssertionError("got element: " + e); + throw new AssertionError("unknown element: " + e); + } + + @Override @DefinedBy(Api.LANGUAGE_MODEL) + public Boolean defaultAction(Element e, Void p) { + return visit(e.getEnclosingElement()) && shouldDocument(e); } }; } diff --git a/langtools/test/jdk/javadoc/doclet/testIncluded/TestIncluded.java b/langtools/test/jdk/javadoc/doclet/testIncluded/TestIncluded.java new file mode 100644 index 00000000000..2abe9f05a29 --- /dev/null +++ b/langtools/test/jdk/javadoc/doclet/testIncluded/TestIncluded.java @@ -0,0 +1,55 @@ +/* + * Copyright (c) 2016, 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 8149468 + * @summary Verify that non included classes are not inspected. + * @library ../lib + * @modules jdk.javadoc/jdk.javadoc.internal.tool + * @build JavadocTester + * @run main TestIncluded + */ + +public class TestIncluded extends JavadocTester { + + public static void main(String... args) throws Exception { + TestIncluded tester = new TestIncluded(); + tester.runTests(); + } + + /* + * The arguments specify only "pkg" but "parent" sources are on the path. + * The class parent.A utilizes a non existent taglet, that will trigger + * an error, if doc comments are inspected. + */ + @Test + void test() { + javadoc("-d", "out", + "-Xdoclint:all", + "-sourcepath", testSrc, + "pkg"); + checkExit(Exit.OK); + checkFiles(false, "parent/A.html"); + } +} diff --git a/langtools/test/jdk/javadoc/doclet/testIncluded/parent/A.java b/langtools/test/jdk/javadoc/doclet/testIncluded/parent/A.java new file mode 100644 index 00000000000..9a990eb3063 --- /dev/null +++ b/langtools/test/jdk/javadoc/doclet/testIncluded/parent/A.java @@ -0,0 +1,30 @@ +/* + * Copyright (c) 2016, 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 parent; +public class A { + /** + * Does nothing. Uses an non existent taglet {@enoexist no errors please}. + */ + public void method(){} +} diff --git a/langtools/test/jdk/javadoc/doclet/testIncluded/pkg/B.java b/langtools/test/jdk/javadoc/doclet/testIncluded/pkg/B.java new file mode 100644 index 00000000000..dc9fbc46cf7 --- /dev/null +++ b/langtools/test/jdk/javadoc/doclet/testIncluded/pkg/B.java @@ -0,0 +1,35 @@ +/* + * Copyright (c) 2016, 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 pkg; + +/** + * Just a lonesome class. + */ +public class B extends parent.A { + /** + * The main method. + * @param args the aaaaargs + */ + public static void main(String... args) {} +}