/* * Copyright (c) 2021, 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 8272944 * @summary Use snippets in jdk.javadoc documentation * @key needs-src needs-src-jdk_javadoc * @library /tools/lib ../../lib * @modules jdk.compiler/com.sun.tools.javac.api * jdk.compiler/com.sun.tools.javac.main * jdk.javadoc/jdk.javadoc.internal.tool * @build snippets.SnippetUtils toolbox.JavacTask toolbox.ToolBox javadoc.tester.* * @run main TestDocletExample */ import java.nio.file.Files; import java.nio.file.Path; import java.util.spi.ToolProvider; import java.util.stream.Stream; import snippets.SnippetUtils; import toolbox.Task; import toolbox.TestRunner; import toolbox.ToolBox; import javax.tools.DiagnosticCollector; import javax.tools.JavaFileObject; public class TestDocletExample extends TestRunner { public static void main(String... args) throws Exception { try { var t = new TestDocletExample(); t.runTests(m -> new Object[] { Path.of(m.getName()) }); } catch (SnippetUtils.ConfigurationException e) { System.err.println("NOTE: " + e.getMessage() + "; test skipped"); } } SnippetUtils snippets; ToolBox tb = new ToolBox(); TestDocletExample() throws SnippetUtils.ConfigurationException { super(System.out); snippets = new SnippetUtils("jdk.javadoc"); } @Test public void testEntryPoint(Path base) throws Exception { var docletPkg = snippets.getElements().getPackageElement("jdk.javadoc.doclet"); var dc = snippets.getDocTrees().getDocCommentTree(docletPkg); var entryPointSnippet = snippets.getSnippetById(dc, "entry-point"); var entryPointCode = entryPointSnippet.getBody().getBody(); var code = """ class C { %s { } } """.formatted(entryPointCode); DiagnosticCollector collector = new DiagnosticCollector<>(); snippets.parse(code, null, collector); var diags = collector.getDiagnostics(); if (diags.isEmpty()) { out.println("parsed entry point snippet"); } else { diags.forEach(out::println); throw new Exception("parse failed"); } } @Test public void testDocletExample(Path base) throws Exception { // get source code var docletPkg = snippets.getElements().getPackageElement("jdk.javadoc.doclet"); var dc = snippets.getDocTrees().getDocCommentTree(docletPkg); var exampleSnippet = snippets.getSnippetById(dc, "Example.java"); var exampleCode = exampleSnippet.getBody().getBody(); // compile it Path src = base.resolve("src"); Path classes = base.resolve("classes"); Files.createDirectories(classes); tb.writeJavaFiles(src, exampleCode); new toolbox.JavacTask(tb) .outdir(classes) .files(tb.findJavaFiles(src)) .run(Task.Expect.SUCCESS) .writeAll(); // get demo command var cmdSnippet = snippets.getSnippetById(dc, "run-doclet"); var cmd = cmdSnippet.getBody().getBody() .replaceAll("\\s+//.*", "") // remove markup .replaceAll("\\\\\n", " ") // join lines .trim(); out.println(cmd); tb.writeFile(src.resolve("overview.html"), """ Overview Overview """); var cmdWords = Stream.of(cmd.split("\\s+")) .map(s -> s.replace("source-location", src.toString())) .map(s -> s.replace("doclet-classes", classes.toString())) .toList(); var toolName = cmdWords.get(0); var toolArgs = cmdWords.subList(1, cmdWords.size()); ToolProvider tool = ToolProvider.findFirst(toolName) .orElseThrow(() -> new Exception("tool not found: " + toolName)); int rc = tool.run(System.out, System.err, toolArgs.toArray(new String[0])); if (rc != 0) { throw new Exception("ecommand return code: " + rc); } } }