From 0be39054a631f282acc7ea05b2d98878a2b250bf Mon Sep 17 00:00:00 2001 From: Jim Laskey Date: Thu, 8 Jun 2023 17:51:11 +0000 Subject: [PATCH] 8309595: Allow javadoc to process unnamed classes Reviewed-by: hannesw --- .../javadoc/internal/tool/ElementsTable.java | 2 +- .../internal/tool/ToolEnvironment.java | 4 + .../jdk/javadoc/doclet/unnamed/Unnamed.java | 82 +++++++++++++++++++ 3 files changed, 87 insertions(+), 1 deletion(-) create mode 100644 test/langtools/jdk/javadoc/doclet/unnamed/Unnamed.java diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ElementsTable.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ElementsTable.java index 4318b2ea404..3f642658deb 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ElementsTable.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ElementsTable.java @@ -987,7 +987,7 @@ public class ElementsTable { * @return true if the element is visible */ public boolean isSelected(Element e) { - if (toolEnv.isSynthetic((Symbol) e)) { + if (toolEnv.isSynthetic((Symbol) e) && !toolEnv.isUnnamed((Symbol) e)) { return false; } if (visibleElementVisitor == null) { diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ToolEnvironment.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ToolEnvironment.java index 4b1e1c66258..a8cb10651dd 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ToolEnvironment.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/tool/ToolEnvironment.java @@ -174,6 +174,10 @@ public class ToolEnvironment { return (sym.flags() & Flags.SYNTHETIC) != 0; } + boolean isUnnamed(Symbol sym) { + return (sym.flags() & Flags.UNNAMED_CLASS) != 0; + } + void setElementToTreePath(Element e, TreePath tree) { if (e == null || tree == null) return; diff --git a/test/langtools/jdk/javadoc/doclet/unnamed/Unnamed.java b/test/langtools/jdk/javadoc/doclet/unnamed/Unnamed.java new file mode 100644 index 00000000000..b146aaf987a --- /dev/null +++ b/test/langtools/jdk/javadoc/doclet/unnamed/Unnamed.java @@ -0,0 +1,82 @@ +/* + * Copyright (c) 2017, 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 8309595 + * @summary Allow javadoc to process unnamed classes + * @library /tools/lib ../../lib + * @modules jdk.javadoc/jdk.javadoc.internal.tool + * @build toolbox.ToolBox javadoc.tester.* + * @run main Unnamed + */ + +import java.io.File; +import java.io.IOException; +import java.nio.file.Files; +import java.nio.file.Path; + +import javadoc.tester.JavadocTester; +import toolbox.ToolBox; + +public class Unnamed extends JavadocTester { + + private static final String thisVersion = System.getProperty("java.specification.version"); + + private static final ToolBox tb = new ToolBox(); + + public static void main(String... args) throws Exception { + new Unnamed().runTests(); + } + + @Test + public void testUnnamed(Path base) throws IOException { + String className = "Sample"; + Files.createDirectories(base); + Path out = base.resolve("out"); + Path src = base.resolve("src"); + Path sample = src.resolve(className + ".java"); + + Files.createDirectories(out); + Files.createDirectories(src); + Files.writeString(sample, """ + /** + * This is a comment for the main method. + */ + void main() { + System.out.println("Done"); + } + """); + + javadoc( + "--enable-preview", + "--source", thisVersion, + "-private", + "-d", out.toString(), + sample.toString() + ); + + checkOutput(className + ".html", true, "This is a comment for the main method."); + } + +}