From e3c574e026461f9e1246814dd34c757b3558a6bc Mon Sep 17 00:00:00 2001 From: Kumar Srinivasan Date: Thu, 30 Nov 2017 04:43:09 -0800 Subject: [PATCH] 8190552: Augment the Compiler API tree with APIs to represent HTML content Reviewed-by: jjg, jlahoda --- .../sun/source/doctree/DocCommentTree.java | 38 +++++- .../com/sun/source/doctree/DocTree.java | 6 + .../sun/source/doctree/DocTreeVisitor.java | 19 ++- .../com/sun/source/doctree/DocTypeTree.java | 42 +++++++ .../com/sun/source/util/DocTreeFactory.java | 23 ++++ .../com/sun/source/util/DocTreeScanner.java | 12 ++ .../classes/com/sun/source/util/DocTrees.java | 3 +- .../sun/source/util/SimpleDocTreeVisitor.java | 17 ++- .../com/sun/tools/javac/api/JavacTrees.java | 21 ++-- .../tools/javac/parser/DocCommentParser.java | 111 ++++++++++++++++-- .../com/sun/tools/javac/tree/DCTree.java | 40 ++++++- .../com/sun/tools/javac/tree/DocPretty.java | 10 ++ .../sun/tools/javac/tree/DocTreeMaker.java | 36 +++++- .../shellsupport/doc/JavadocHelper.java | 30 +++-- .../internal/doclets/toolkit/util/Utils.java | 4 + .../shellsupport/doc/JavadocHelperTest.java | 4 +- .../testPackageHtml/TestPackageHtml.java | 2 +- .../doclet/testSummaryTag/TestSummaryTag.java | 2 +- .../tools/javac/doctree/DocCommentTester.java | 14 +++ .../doctree/SimpleDocTreeVisitorTest.java | 5 +- .../dcapi/{OverviewTest.java => Anchor.java} | 6 +- .../dcapi/DocCommentTreeApiTester.java | 76 ++++++++---- .../tools/javac/doctree/dcapi/overview0.html | 46 +------- .../javac/doctree/dcapi/overview0.html.out | 33 ++++++ .../tools/javac/doctree/dcapi/overview1.html | 45 +------ .../javac/doctree/dcapi/overview1.html.out | 29 +++++ .../tools/javac/doctree/dcapi/overview2.html | 45 +------ .../javac/doctree/dcapi/overview2.html.out | 29 +++++ .../tools/javac/doctree/dcapi/overview3.html | 45 +------ .../javac/doctree/dcapi/overview3.html.out | 32 +++++ .../tools/javac/doctree/dcapi/overview4.html | 44 +------ .../javac/doctree/dcapi/overview4.html.out | 23 ++++ .../tools/javac/doctree/dcapi/overview5.html | 45 +------ .../javac/doctree/dcapi/overview5.html.out | 32 +++++ .../tools/javac/doctree/dcapi/overview6.html | 39 +----- .../javac/doctree/dcapi/overview6.html.out | 32 +++++ .../tools/javac/doctree/dcapi/overview7.html | 6 + .../javac/doctree/dcapi/overview7.html.out | 29 +++++ .../tools/javac/doctree/dcapi/package.html | 46 +------- .../javac/doctree/dcapi/package.html.out | 43 +++++++ .../javac/doctree/dcapi/pkg/package.html | 45 +------ .../javac/doctree/dcapi/pkg/package.html.out | 33 ++++++ test/langtools/tools/javac/lib/DPrinter.java | 6 + 43 files changed, 799 insertions(+), 449 deletions(-) create mode 100644 src/jdk.compiler/share/classes/com/sun/source/doctree/DocTypeTree.java rename test/langtools/tools/javac/doctree/dcapi/{OverviewTest.java => Anchor.java} (88%) create mode 100644 test/langtools/tools/javac/doctree/dcapi/overview0.html.out create mode 100644 test/langtools/tools/javac/doctree/dcapi/overview1.html.out create mode 100644 test/langtools/tools/javac/doctree/dcapi/overview2.html.out create mode 100644 test/langtools/tools/javac/doctree/dcapi/overview3.html.out create mode 100644 test/langtools/tools/javac/doctree/dcapi/overview4.html.out create mode 100644 test/langtools/tools/javac/doctree/dcapi/overview5.html.out create mode 100644 test/langtools/tools/javac/doctree/dcapi/overview6.html.out create mode 100644 test/langtools/tools/javac/doctree/dcapi/overview7.html create mode 100644 test/langtools/tools/javac/doctree/dcapi/overview7.html.out create mode 100644 test/langtools/tools/javac/doctree/dcapi/package.html.out create mode 100644 test/langtools/tools/javac/doctree/dcapi/pkg/package.html.out diff --git a/src/jdk.compiler/share/classes/com/sun/source/doctree/DocCommentTree.java b/src/jdk.compiler/share/classes/com/sun/source/doctree/DocCommentTree.java index 810be9ea6ba..e6058f3d910 100644 --- a/src/jdk.compiler/share/classes/com/sun/source/doctree/DocCommentTree.java +++ b/src/jdk.compiler/share/classes/com/sun/source/doctree/DocCommentTree.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2011, 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 @@ -26,6 +26,7 @@ package com.sun.source.doctree; import java.util.ArrayList; +import java.util.Collections; import java.util.List; /** @@ -69,4 +70,39 @@ public interface DocCommentTree extends DocTree { * @return the block tags of a documentation comment */ List getBlockTags(); + + /** + * Returns a list of trees containing the content (if any) preceding + * the content of the documentation comment. + * When the {@code DocCommentTree} has been read from a documentation + * comment in a Java source file, the list will be empty. + * When the {@code DocCommentTree} has been read from an HTML file, this + * represents the content from the beginning of the file up to and + * including the {@code } tag. + * + * @implSpec This implementation returns an empty list. + * + * @return the list of trees + * @since 10 + */ + default List getPreamble() { + return Collections.emptyList(); + } + + /** + * Returns a list of trees containing the content (if any) following the + * content of the documentation comment. + * When the {@code DocCommentTree} has been read from a documentation + * comment in a Java source file, the list will be empty. + * When {@code DocCommentTree} has been read from an HTML file, this + * represents the content from the {@code } tag to the end of file. + * + * @implSpec This implementation returns an empty list. + * + * @return the list of trees + * @since 10 + */ + default List getPostamble() { + return Collections.emptyList(); + } } diff --git a/src/jdk.compiler/share/classes/com/sun/source/doctree/DocTree.java b/src/jdk.compiler/share/classes/com/sun/source/doctree/DocTree.java index ec757e6e348..c9a06ba9b0c 100644 --- a/src/jdk.compiler/share/classes/com/sun/source/doctree/DocTree.java +++ b/src/jdk.compiler/share/classes/com/sun/source/doctree/DocTree.java @@ -77,6 +77,12 @@ public interface DocTree { */ DOC_ROOT("docRoot"), + /** + * Used for instances of {@link DocTypeTree} + * representing an HTML DocType declaration. + */ + DOC_TYPE, + /** * Used for instances of {@link EndElementTree} * representing the end of an HTML element. diff --git a/src/jdk.compiler/share/classes/com/sun/source/doctree/DocTreeVisitor.java b/src/jdk.compiler/share/classes/com/sun/source/doctree/DocTreeVisitor.java index 0a71fe07238..29ccba7474d 100644 --- a/src/jdk.compiler/share/classes/com/sun/source/doctree/DocTreeVisitor.java +++ b/src/jdk.compiler/share/classes/com/sun/source/doctree/DocTreeVisitor.java @@ -104,6 +104,21 @@ public interface DocTreeVisitor { */ R visitDocRoot(DocRootTree node, P p); + /** + * Visits a DocTypeTree node. + * + * @implSpec Visits a {@code DocTypeTree} node + * by calling {@code visitOther(node, p)}. + * + * @param node the node being visited + * @param p a parameter value + * @return a result value + * @since 10 + */ + default R visitDocType(DocTypeTree node, P p) { + return visitOther(node, p); + } + /** * Visits an EndElementTree node. * @param node the node being visited @@ -267,7 +282,9 @@ public interface DocTreeVisitor { * @return a result value * @since 10 */ - default R visitSummary(SummaryTree node, P p) { return visitOther(node, p);} + default R visitSummary(SummaryTree node, P p) { + return visitOther(node, p); + } /** * Visits a TextTree node. diff --git a/src/jdk.compiler/share/classes/com/sun/source/doctree/DocTypeTree.java b/src/jdk.compiler/share/classes/com/sun/source/doctree/DocTypeTree.java new file mode 100644 index 00000000000..dfce8be8636 --- /dev/null +++ b/src/jdk.compiler/share/classes/com/sun/source/doctree/DocTypeTree.java @@ -0,0 +1,42 @@ +/* + * 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. Oracle designates this + * particular file as subject to the "Classpath" exception as provided + * by Oracle in the LICENSE file that accompanied this code. + * + * 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 com.sun.source.doctree; + +/** + * A tree node for a {@code doctype} declaration. + * + *

+ * <!doctype text> + * + * @since 10 + */ +public interface DocTypeTree extends DocTree { + /** + * Returns the text of the doctype declaration. + * @return text + */ + String getText(); +} diff --git a/src/jdk.compiler/share/classes/com/sun/source/util/DocTreeFactory.java b/src/jdk.compiler/share/classes/com/sun/source/util/DocTreeFactory.java index f8488f82f3f..189d0f153c7 100644 --- a/src/jdk.compiler/share/classes/com/sun/source/util/DocTreeFactory.java +++ b/src/jdk.compiler/share/classes/com/sun/source/util/DocTreeFactory.java @@ -39,6 +39,7 @@ import com.sun.source.doctree.DeprecatedTree; import com.sun.source.doctree.DocCommentTree; import com.sun.source.doctree.DocRootTree; import com.sun.source.doctree.DocTree; +import com.sun.source.doctree.DocTypeTree; import com.sun.source.doctree.EndElementTree; import com.sun.source.doctree.EntityTree; import com.sun.source.doctree.ErroneousTree; @@ -121,12 +122,34 @@ public interface DocTreeFactory { */ DocCommentTree newDocCommentTree(List fullBody, List tags); + + /** + * Create a new {@code DocCommentTree} object, to represent the enitire doc comment. + * @param fullBody the entire body of the doc comment + * @param tags the block tags in the doc comment + * @param preamble the meta content of an html file including the body tag + * @param postamble the meta content of an html including the closing body tag + * @return a {@code DocCommentTree} object + * @since 10 + */ + DocCommentTree newDocCommentTree(List fullBody, + List tags, + List preamble, + List postamble); /** * Create a new {@code DocRootTree} object, to represent an {@code {@docroot} } tag. * @return a {@code DocRootTree} object */ DocRootTree newDocRootTree(); + /** + * Create a new {@code DocTypeTree}, to represent a {@code DOCTYPE} HTML declaration. + * @param text the content of the declaration + * @return a {@code CommentTree} object + * @since 10 + */ + DocTypeTree newDocTypeTree(String text); + /** * Create a new {@code EndElement} object, to represent the end of an HTML element. * @param name the name of the HTML element diff --git a/src/jdk.compiler/share/classes/com/sun/source/util/DocTreeScanner.java b/src/jdk.compiler/share/classes/com/sun/source/util/DocTreeScanner.java index 4a48a8c5d40..4f4648f0eb7 100644 --- a/src/jdk.compiler/share/classes/com/sun/source/util/DocTreeScanner.java +++ b/src/jdk.compiler/share/classes/com/sun/source/util/DocTreeScanner.java @@ -198,6 +198,18 @@ public class DocTreeScanner implements DocTreeVisitor { return null; } + /** + * {@inheritDoc} This implementation returns {@code null}. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return the result of scanning + */ + @Override + public R visitDocType(DocTypeTree node, P p) { + return null; + } + /** * {@inheritDoc} This implementation returns {@code null}. * diff --git a/src/jdk.compiler/share/classes/com/sun/source/util/DocTrees.java b/src/jdk.compiler/share/classes/com/sun/source/util/DocTrees.java index 1c0a3ec9895..1f74e0bcb0a 100644 --- a/src/jdk.compiler/share/classes/com/sun/source/util/DocTrees.java +++ b/src/jdk.compiler/share/classes/com/sun/source/util/DocTrees.java @@ -98,13 +98,12 @@ public abstract class DocTrees extends Trees { /** * Returns the doc comment tree of the given file. The file must be * an HTML file, in which case the doc comment tree represents the - * contents of the <body> tag, and any enclosing tags are ignored. + * entire contents of the file. * Returns {@code null} if no doc comment was found. * Future releases may support additional file types. * * @param fileObject the content container * @return the doc comment tree - * * @since 9 */ public abstract DocCommentTree getDocCommentTree(FileObject fileObject); diff --git a/src/jdk.compiler/share/classes/com/sun/source/util/SimpleDocTreeVisitor.java b/src/jdk.compiler/share/classes/com/sun/source/util/SimpleDocTreeVisitor.java index 3b6aacc5b67..d180accc329 100644 --- a/src/jdk.compiler/share/classes/com/sun/source/util/SimpleDocTreeVisitor.java +++ b/src/jdk.compiler/share/classes/com/sun/source/util/SimpleDocTreeVisitor.java @@ -167,6 +167,19 @@ public class SimpleDocTreeVisitor implements DocTreeVisitor { return defaultAction(node, p); } + /** + * {@inheritDoc} + * + * @implSpec This implementation calls {@code defaultAction}. + * + * @param node {@inheritDoc} + * @param p {@inheritDoc} + * @return the result of {@code defaultAction} + * @since 10 + */ + @Override + public R visitDocType(DocTypeTree node, P p) { return defaultAction(node, p); } + /** * {@inheritDoc} This implementation calls {@code defaultAction}. * @@ -175,9 +188,7 @@ public class SimpleDocTreeVisitor implements DocTreeVisitor { * @return the result of {@code defaultAction} */ @Override - public R visitEndElement(EndElementTree node, P p) { - return defaultAction(node, p); - } + public R visitEndElement(EndElementTree node, P p) { return defaultAction(node, p);} /** * {@inheritDoc} This implementation calls {@code defaultAction}. 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 1aeb62da139..75b99b116eb 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 @@ -28,9 +28,8 @@ package com.sun.tools.javac.api; import java.io.FileNotFoundException; import java.io.IOException; import java.text.BreakIterator; -import java.util.HashMap; +import java.util.Collections; import java.util.HashSet; -import java.util.Map; import java.util.Set; import java.util.regex.Matcher; import java.util.regex.Pattern; @@ -59,6 +58,8 @@ import javax.tools.StandardLocation; import com.sun.source.doctree.DocCommentTree; import com.sun.source.doctree.DocTree; +import com.sun.source.doctree.EndElementTree; +import com.sun.source.doctree.StartElementTree; import com.sun.source.tree.CatchTree; import com.sun.source.tree.CompilationUnitTree; import com.sun.source.tree.Scope; @@ -68,6 +69,7 @@ import com.sun.source.util.DocTreePath; import com.sun.source.util.DocTreeScanner; import com.sun.source.util.DocTrees; import com.sun.source.util.JavacTask; +import com.sun.source.util.SimpleDocTreeVisitor; import com.sun.source.util.TreePath; import com.sun.tools.javac.code.Flags; import com.sun.tools.javac.code.Scope.NamedImportScope; @@ -1006,16 +1008,7 @@ public class JavacTrees extends DocTrees { public String getText() { try { CharSequence rawDoc = fileObject.getCharContent(true); - Pattern bodyPat = - Pattern.compile("(?is).*?]*>(.*) tagParsers; - public DocCommentParser(ParserFactory fac, DiagnosticSource diagSource, Comment comment) { + public DocCommentParser(ParserFactory fac, DiagnosticSource diagSource, + Comment comment, boolean isFileContent) { this.fac = fac; this.diagSource = diagSource; this.comment = comment; names = fac.names; + this.isFileContent = isFileContent; m = fac.docTreeMaker; initTagParsers(); } + public DocCommentParser(ParserFactory fac, DiagnosticSource diagSource, Comment comment) { + this(fac, diagSource, comment, false); + } + public DocCommentParser(ParserFactory fac) { - this(fac, null, null); + this(fac, null, null, false); } public DCDocComment parse() { @@ -115,13 +127,22 @@ public class DocCommentParser { bp = -1; nextChar(); - List body = blockContent(); + List preamble = isFileContent ? blockContent(Phase.PREAMBLE) : List.nil(); + List body = blockContent(Phase.BODY); List tags = blockTags(); - int pos = !body.isEmpty() - ? body.head.pos - : !tags.isEmpty() ? tags.head.pos : Position.NOPOS; + List postamble = isFileContent ? blockContent(Phase.POSTAMBLE) : List.nil(); - DCDocComment dc = m.at(pos).newDocCommentTree(comment, body, tags); + int pos = Position.NOPOS; + if (!preamble.isEmpty()) + pos = preamble.head.pos; + else if (!body.isEmpty()) + pos = body.head.pos; + else if (!tags.isEmpty()) + pos = tags.head.pos; + else if (!postamble.isEmpty()) + pos = postamble.head.pos; + + DCDocComment dc = m.at(pos).newDocCommentTree(comment, body, tags, preamble, postamble); return dc; } @@ -133,13 +154,17 @@ public class DocCommentParser { } } + protected List blockContent() { + return blockContent(Phase.BODY); + } + /** * Read block content, consisting of text, html and inline tags. * Terminated by the end of input, or the beginning of the next block tag: * i.e. @ as the first non-whitespace character on a line. */ @SuppressWarnings("fallthrough") - protected List blockContent() { + protected List blockContent(Phase phase) { ListBuffer trees = new ListBuffer<>(); textStart = -1; @@ -160,8 +185,36 @@ public class DocCommentParser { case '<': newline = false; + if (isFileContent) { + switch (phase) { + case PREAMBLE: + if (peek("body")) { + trees.add(html()); + if (textStart == -1) { + textStart = bp; + lastNonWhite = -1; + } + // mark this as the start, for processing purposes + newline = true; + break loop; + } + break; + case BODY: + if (peek("/body")) { + addPendingText(trees, lastNonWhite); + break loop; + } + break; + default: + // fallthrough + } + } addPendingText(trees, bp - 1); trees.add(html()); + + if (phase == Phase.PREAMBLE || phase == Phase.POSTAMBLE) { + break; // Ignore newlines after html tags, in the meta content + } if (textStart == -1) { textStart = bp; lastNonWhite = -1; @@ -734,11 +787,37 @@ public class DocCommentParser { } } + boolean peek(String s) { + final int savedpos = bp; + try { + if (ch == '<') + nextChar(); + + if (ch == '/') { + if (s.charAt(0) != ch) { + return false; + } else { + s = s.substring(1, s.length()); + nextChar(); + } + } + + if (isIdentifierStart(ch)) { + Name name = readIdentifier(); + return StringUtils.toLowerCase(name.toString()).equals(s); + } + return false; + } finally { + bp = savedpos; + ch = buf[bp]; + } + } + /** * Read the start or end of an HTML tag, or an HTML comment * {@literal } or {@literal } */ - protected DCTree html() { + private DCTree html() { int p = bp; nextChar(); if (isIdentifierStart(ch)) { @@ -790,6 +869,19 @@ public class DocCommentParser { nextChar(); } } + } else if (isIdentifierStart(ch) && peek("doctype")) { + readIdentifier(); + nextChar(); + skipWhitespace(); + int d = bp; + while (bp < buflen) { + if (ch == '>') { + int mark = bp; + nextChar(); + return m.at(d).newDocTypeTree(newString(d, mark)); + } + nextChar(); + } } } @@ -1316,4 +1408,5 @@ public class DocCommentParser { tagParsers.put(names.fromString(p.getTreeKind().tagName), p); } + } diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DCTree.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DCTree.java index 2f8d53b3cba..c2abd514131 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DCTree.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DCTree.java @@ -109,17 +109,23 @@ public abstract class DCTree implements DocTree { public final List firstSentence; public final List body; public final List tags; + public final List preamble; + public final List postamble; public DCDocComment(Comment comment, List fullBody, List firstSentence, List body, - List tags) { + List tags, + List preamble, + List postamble) { this.comment = comment; this.firstSentence = firstSentence; this.fullBody = fullBody; this.body = body; this.tags = tags; + this.preamble = preamble; + this.postamble = postamble; } @Override @DefinedBy(Api.COMPILER_TREE) @@ -152,6 +158,15 @@ public abstract class DCTree implements DocTree { return tags; } + @Override @DefinedBy(Api.COMPILER_TREE) + public List getPreamble() { + return preamble; + } + + @Override @DefinedBy(Api.COMPILER_TREE) + public List getPostamble() { + return postamble; + } } public static abstract class DCBlockTag extends DCTree implements BlockTagTree { @@ -288,6 +303,29 @@ public abstract class DCTree implements DocTree { } } + public static class DCDocType extends DCTree implements DocTypeTree { + public final String text; + + DCDocType(String text) { + this.text = text; + } + + @Override @DefinedBy(Api.COMPILER_TREE) + public Kind getKind() { + return Kind.DOC_TYPE; + } + + @Override @DefinedBy(Api.COMPILER_TREE) + public R accept(DocTreeVisitor v, D d) { + return v.visitDocType(this, d); + } + + @Override @DefinedBy(Api.COMPILER_TREE) + public String getText() { + return text; + } + } + public static class DCEndElement extends DCTree implements EndElementTree { public final Name name; diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocPretty.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocPretty.java index 00101f0bc28..ae7a9b897da 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocPretty.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocPretty.java @@ -224,6 +224,16 @@ public class DocPretty implements DocTreeVisitor { return null; } + @Override @DefinedBy(Api.COMPILER_TREE) + public Void visitDocType(DocTypeTree node, Void p) { + try { + print(node.getText()); + } catch (IOException e) { + throw new UncheckedIOException(e); + } + return null; + } + @Override @DefinedBy(Api.COMPILER_TREE) public Void visitEndElement(EndElementTree node, Void p) { try { diff --git a/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocTreeMaker.java b/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocTreeMaker.java index ab12175b199..f51049fe030 100644 --- a/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocTreeMaker.java +++ b/src/jdk.compiler/share/classes/com/sun/tools/javac/tree/DocTreeMaker.java @@ -28,6 +28,7 @@ package com.sun.tools.javac.tree; import java.text.BreakIterator; import java.util.ArrayList; import java.util.Collection; +import java.util.Collections; import java.util.EnumSet; import java.util.List; import java.util.ListIterator; @@ -37,6 +38,7 @@ import javax.tools.Diagnostic; import javax.tools.JavaFileObject; import com.sun.source.doctree.AttributeTree.ValueKind; +import com.sun.source.doctree.DocCommentTree; import com.sun.source.doctree.DocTree; import com.sun.source.doctree.DocTree.Kind; import com.sun.source.doctree.EndElementTree; @@ -59,6 +61,7 @@ import com.sun.tools.javac.tree.DCTree.DCComment; import com.sun.tools.javac.tree.DCTree.DCDeprecated; import com.sun.tools.javac.tree.DCTree.DCDocComment; import com.sun.tools.javac.tree.DCTree.DCDocRoot; +import com.sun.tools.javac.tree.DCTree.DCDocType; import com.sun.tools.javac.tree.DCTree.DCEndElement; import com.sun.tools.javac.tree.DCTree.DCEntity; import com.sun.tools.javac.tree.DCTree.DCErroneous; @@ -195,9 +198,23 @@ public class DocTreeMaker implements DocTreeFactory { return tree; } - public DCDocComment newDocCommentTree(Comment comment, List fullBody, List tags) { + @Override @DefinedBy(Api.COMPILER_TREE) + public DCDocComment newDocCommentTree(List fullBody, List tags) { Pair, List> pair = splitBody(fullBody); - DCDocComment tree = new DCDocComment(comment, cast(fullBody), pair.fst, pair.snd, cast(tags)); + List preamble = Collections.emptyList(); + List postamble = Collections.emptyList(); + + return newDocCommentTree(fullBody, tags, preamble, postamble); + } + + public DCDocComment newDocCommentTree(Comment comment, + List fullBody, + List tags, + List preamble, + List postamble) { + Pair, List> pair = splitBody(fullBody); + DCDocComment tree = new DCDocComment(comment, cast(fullBody), pair.fst, pair.snd, + cast(tags), cast(preamble), cast(postamble)); tree.pos = pos; return tree; } @@ -208,7 +225,10 @@ public class DocTreeMaker implements DocTreeFactory { * where the trees are being synthesized by a tool. */ @Override @DefinedBy(Api.COMPILER_TREE) - public DCDocComment newDocCommentTree(List fullBody, List tags) { + public DCDocComment newDocCommentTree(List fullBody, + List tags, + List preamble, + List postamble) { ListBuffer lb = new ListBuffer<>(); lb.addAll(cast(fullBody)); List fBody = lb.toList(); @@ -236,7 +256,8 @@ public class DocTreeMaker implements DocTreeFactory { } }; Pair, List> pair = splitBody(fullBody); - DCDocComment tree = new DCDocComment(c, fBody, pair.fst, pair.snd, cast(tags)); + DCDocComment tree = new DCDocComment(c, fBody, pair.fst, pair.snd, cast(tags), + cast(preamble), cast(postamble)); return tree; } @@ -247,6 +268,13 @@ public class DocTreeMaker implements DocTreeFactory { return tree; } + @Override @DefinedBy(Api.COMPILER_TREE) + public DCDocType newDocTypeTree(String text) { + DCDocType tree = new DCDocType(text); + tree.pos = pos; + return tree; + } + @Override @DefinedBy(Api.COMPILER_TREE) public DCEndElement newEndElementTree(Name name) { DCEndElement tree = new DCEndElement(name); diff --git a/src/jdk.compiler/share/classes/jdk/internal/shellsupport/doc/JavadocHelper.java b/src/jdk.compiler/share/classes/jdk/internal/shellsupport/doc/JavadocHelper.java index 42fa30080bd..0edc8458478 100644 --- a/src/jdk.compiler/share/classes/jdk/internal/shellsupport/doc/JavadocHelper.java +++ b/src/jdk.compiler/share/classes/jdk/internal/shellsupport/doc/JavadocHelper.java @@ -61,6 +61,7 @@ import javax.tools.ForwardingJavaFileManager; import javax.tools.JavaCompiler; import javax.tools.JavaFileManager; import javax.tools.JavaFileObject; +import javax.tools.JavaFileObject.Kind; import javax.tools.SimpleJavaFileObject; import javax.tools.StandardJavaFileManager; import javax.tools.StandardLocation; @@ -214,7 +215,9 @@ public abstract class JavadocHelper implements AutoCloseable { } } - DocCommentTree docCommentTree = parseDocComment(task, docComment); + Pair parsed = parseDocComment(task, docComment); + DocCommentTree docCommentTree = parsed.fst; + int offset = parsed.snd; IOException[] exception = new IOException[1]; Map replace = new TreeMap<>((span1, span2) -> span2[0] - span1[0]); @@ -349,7 +352,10 @@ public abstract class JavadocHelper implements AutoCloseable { if (inherited == null) { return null; } - DocCommentTree inheritedDocTree = parseDocComment(inheritedJavacTask, inherited); + Pair parsed = + parseDocComment(inheritedJavacTask, inherited); + DocCommentTree inheritedDocTree = parsed.fst; + int offset = parsed.snd; List> inheritedText = new ArrayList<>(); DocTree parent = interestingParent.peek(); switch (parent.getKind()) { @@ -391,7 +397,6 @@ public abstract class JavadocHelper implements AutoCloseable { break; } if (!inheritedText.isEmpty()) { - long offset = trees.getSourcePositions().getStartPosition(null, inheritedDocTree, inheritedDocTree); long start = Long.MAX_VALUE; long end = Long.MIN_VALUE; @@ -475,7 +480,6 @@ public abstract class JavadocHelper implements AutoCloseable { return docComment; StringBuilder replacedInheritDoc = new StringBuilder(docComment); - int offset = (int) trees.getSourcePositions().getStartPosition(null, docCommentTree, docCommentTree); for (Entry e : replace.entrySet()) { replacedInheritDoc.delete(e.getKey()[0] - offset, e.getKey()[1] - offset + 1); @@ -507,22 +511,28 @@ public abstract class JavadocHelper implements AutoCloseable { } private DocTree parseBlockTag(JavacTask task, String blockTag) { - DocCommentTree dc = parseDocComment(task, blockTag); + DocCommentTree dc = parseDocComment(task, blockTag).fst; return dc.getBlockTags().get(0); } - private DocCommentTree parseDocComment(JavacTask task, String javadoc) { + private Pair parseDocComment(JavacTask task, String javadoc) { DocTrees trees = DocTrees.instance(task); try { - return trees.getDocCommentTree(new SimpleJavaFileObject(new URI("mem://doc.html"), javax.tools.JavaFileObject.Kind.HTML) { + SimpleJavaFileObject fo = + new SimpleJavaFileObject(new URI("mem://doc.html"), Kind.HTML) { @Override @DefinedBy(Api.COMPILER) - public CharSequence getCharContent(boolean ignoreEncodingErrors) throws IOException { + public CharSequence getCharContent(boolean ignoreEncodingErrors) + throws IOException { return "" + javadoc + ""; } - }); + }; + DocCommentTree tree = trees.getDocCommentTree(fo); + int offset = (int) trees.getSourcePositions().getStartPosition(null, tree, tree); + offset += "".length() + 1; + return Pair.of(tree, offset); } catch (URISyntaxException ex) { - return null; + throw new IllegalStateException(ex); } } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/Utils.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/Utils.java index 9deb3900c39..42e21dc1f55 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/Utils.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/Utils.java @@ -3096,6 +3096,10 @@ public class Utils { if (!configuration.isAllowScriptInComments()) { DocCommentTree dct = configuration.cmtUtils.parse( URI.create("option://" + name.replace("-", "")), "" + value + ""); + + if (dct == null) + return; + try { javaScriptScanner.scan(dct, null, p -> { throw new JavaScriptScanner.Fault(); diff --git a/test/langtools/jdk/internal/shellsupport/doc/JavadocHelperTest.java b/test/langtools/jdk/internal/shellsupport/doc/JavadocHelperTest.java index 39d6cbe57f6..766857f94fb 100644 --- a/test/langtools/jdk/internal/shellsupport/doc/JavadocHelperTest.java +++ b/test/langtools/jdk/internal/shellsupport/doc/JavadocHelperTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 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 @@ -23,7 +23,7 @@ /* * @test - * @bug 8131019 + * @bug 8131019 8190552 * @summary Test JavadocHelper * @library /tools/lib * @modules jdk.compiler/com.sun.tools.javac.api diff --git a/test/langtools/jdk/javadoc/doclet/testPackageHtml/TestPackageHtml.java b/test/langtools/jdk/javadoc/doclet/testPackageHtml/TestPackageHtml.java index 9c037b7436f..7bf7df4bc3e 100644 --- a/test/langtools/jdk/javadoc/doclet/testPackageHtml/TestPackageHtml.java +++ b/test/langtools/jdk/javadoc/doclet/testPackageHtml/TestPackageHtml.java @@ -44,7 +44,7 @@ public class TestPackageHtml extends JavadocTester { "-sourcepath", testSrc, "pkg1"); checkExit(Exit.ERROR); - checkOutput(Output.OUT, true, "package.html:10: error: bad use of '>'"); + checkOutput(Output.OUT, true, "package.html:5: error: bad use of '>'"); } // Doclet must handle empty body in package.html, must diff --git a/test/langtools/jdk/javadoc/doclet/testSummaryTag/TestSummaryTag.java b/test/langtools/jdk/javadoc/doclet/testSummaryTag/TestSummaryTag.java index c177574173d..271ad7d9ad2 100644 --- a/test/langtools/jdk/javadoc/doclet/testSummaryTag/TestSummaryTag.java +++ b/test/langtools/jdk/javadoc/doclet/testSummaryTag/TestSummaryTag.java @@ -102,7 +102,7 @@ public class TestSummaryTag extends JavadocTester { "p2"); checkExit(Exit.OK); - checkOutput(Output.OUT, true, "package.html:5: warning: invalid use of @summary"); + checkOutput(Output.OUT, true, "package.html:3: warning: invalid use of @summary"); checkOutput("index-all.html", true, "

foo bar
\n"); diff --git a/test/langtools/tools/javac/doctree/DocCommentTester.java b/test/langtools/tools/javac/doctree/DocCommentTester.java index cf7759f7722..c2b5a80f0c5 100644 --- a/test/langtools/tools/javac/doctree/DocCommentTester.java +++ b/test/langtools/tools/javac/doctree/DocCommentTester.java @@ -404,9 +404,18 @@ public class DocCommentTester { public Void visitDocComment(DocCommentTree node, Void p) { header(node); indent(+1); + // Applicable only to html files, print iff non-empty + if (!node.getPreamble().isEmpty()) + print("preamble", node.getPreamble()); + print("firstSentence", node.getFirstSentence()); print("body", node.getBody()); print("block tags", node.getBlockTags()); + + // Applicable only to html files, print iff non-empty + if (!node.getPostamble().isEmpty()) + print("postamble", node.getPostamble()); + indent(-1); indent(); out.println("]"); @@ -418,6 +427,11 @@ public class DocCommentTester { return null; } + public Void visitDocType(DocTypeTree node, Void p) { + header(node, compress(node.getText())); + return null; + } + public Void visitEndElement(EndElementTree node, Void p) { header(node, node.getName().toString()); return null; diff --git a/test/langtools/tools/javac/doctree/SimpleDocTreeVisitorTest.java b/test/langtools/tools/javac/doctree/SimpleDocTreeVisitorTest.java index f7959549783..12f64538726 100644 --- a/test/langtools/tools/javac/doctree/SimpleDocTreeVisitorTest.java +++ b/test/langtools/tools/javac/doctree/SimpleDocTreeVisitorTest.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 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 @@ -31,6 +31,7 @@ import com.sun.source.doctree.DocCommentTree; import com.sun.source.doctree.DocTree; +import com.sun.source.doctree.DocTree.Kind; import com.sun.source.doctree.DocTreeVisitor; import com.sun.source.tree.ClassTree; import com.sun.source.tree.CompilationUnitTree; @@ -84,7 +85,7 @@ public class SimpleDocTreeVisitorTest { } for (DocTree.Kind k: DocTree.Kind.values()) { - if (!found.contains(k) && k != DocTree.Kind.OTHER) + if (!found.contains(k) && k != DocTree.Kind.OTHER && k != DocTree.Kind.DOC_TYPE) error("not found: " + k); } diff --git a/test/langtools/tools/javac/doctree/dcapi/OverviewTest.java b/test/langtools/tools/javac/doctree/dcapi/Anchor.java similarity index 88% rename from test/langtools/tools/javac/doctree/dcapi/OverviewTest.java rename to test/langtools/tools/javac/doctree/dcapi/Anchor.java index 51353cadb42..6b4720dc099 100644 --- a/test/langtools/tools/javac/doctree/dcapi/OverviewTest.java +++ b/test/langtools/tools/javac/doctree/dcapi/Anchor.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 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 @@ -22,6 +22,6 @@ */ /** - * OverviewTest test. + * Anchor test. */ -public class OverviewTest {} +public class Anchor {} diff --git a/test/langtools/tools/javac/doctree/dcapi/DocCommentTreeApiTester.java b/test/langtools/tools/javac/doctree/dcapi/DocCommentTreeApiTester.java index 71cb78ced62..a0fab711b95 100644 --- a/test/langtools/tools/javac/doctree/dcapi/DocCommentTreeApiTester.java +++ b/test/langtools/tools/javac/doctree/dcapi/DocCommentTreeApiTester.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2015, 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 @@ -23,7 +23,7 @@ /* * @test - * @bug 8132096 8157611 + * @bug 8132096 8157611 8190552 * @summary test the APIs in the DocTree interface * @modules jdk.compiler/com.sun.tools.javac.api * jdk.compiler/com.sun.tools.javac.file @@ -52,6 +52,7 @@ import javax.lang.model.element.PackageElement; import javax.lang.model.util.Elements; import javax.tools.FileObject; import javax.tools.JavaFileObject; +import javax.tools.JavaFileObject.Kind; import javax.tools.StandardJavaFileManager; import com.sun.source.doctree.DocTree; @@ -64,8 +65,8 @@ import com.sun.tools.javac.tree.DocPretty; public class DocCommentTreeApiTester { - private static final String MARKER_START = ""; + private static final String MARKER_START = "EXPECT_START"; + private static final String MARKER_END = "EXPECT_END"; private static final String testSrc = System.getProperty("test.src", "."); @@ -85,22 +86,26 @@ public class DocCommentTreeApiTester { DocCommentTreeApiTester test = new DocCommentTreeApiTester(); try { // test getting a DocTree from an element - test.runElementAndBreakIteratorTests("OverviewTest.java", "OverviewTest test."); + test.runElementAndBreakIteratorTests("Anchor.java", "Anchor test."); // test relative paths in a class within a package - test.runRelativePathTest("pkg/Anchor.java", "package.html"); + test.runRelativePathTest("pkg/Anchor.java", "package.html", true); // tests files relative path in an unnamed package - test.runRelativePathTest("OverviewTest.java", "overview0.html"); + test.runRelativePathTest("Anchor.java", "overview0.html", true); - // tests doctreepath using package element and package.html - test.runDocTreePath("pkg/Anchor.java", "package.html"); + // test doctree path and Doc + test.runDocTreePath("Anchor.java", "package.html"); // test for correct parsing using valid and some invalid html tags - for (int i = 0; i < 7; i++) { - String hname = "overview" + i + ".html"; - test.runFileObjectTest(hname); - } + test.runFileObjectTest("overview0.html"); + test.runFileObjectTest("overview1.html"); + test.runFileObjectTest("overview2.html"); + test.runFileObjectTest("overview3.html"); + test.runFileObjectTest("overview4.html"); + test.runFileObjectTest("overview5.html"); + test.runFileObjectTest("overview6.html"); + test.runFileObjectTest("overview7.html"); } finally { test.status(); @@ -166,7 +171,8 @@ public class DocCommentTreeApiTester { * @param fileName the relative html file * @throws java.lang.Exception ouch */ - public void runRelativePathTest(String javaFileName, String fileName) throws Exception { + public void runRelativePathTest(String javaFileName, String fileName, + boolean bodyOnly) throws Exception { List javaFiles = new ArrayList<>(); javaFiles.add(new File(testSrc, javaFileName)); @@ -185,13 +191,17 @@ public class DocCommentTreeApiTester { Element klass = elements.iterator().next(); DocCommentTree dcTree = trees.getDocCommentTree(klass, fileName); + + if (dcTree == null) + throw new Error("invalid input: " + fileName); + StringWriter sw = new StringWriter(); printer.print(dcTree, sw); String found = sw.toString(); FileObject htmlFo = fm.getFileForInput(javax.tools.StandardLocation.SOURCE_PATH, t.getElements().getPackageOf(klass).getQualifiedName().toString(), - fileName); + fileName + ".out"); String expected = getExpected(htmlFo.openReader(true)); astcheck(fileName, expected, found); @@ -209,6 +219,7 @@ public class DocCommentTreeApiTester { List otherFiles = new ArrayList<>(); otherFiles.add(new File(testSrc, htmlfileName)); + otherFiles.add(new File(testSrc, htmlfileName + ".out")); try (StandardJavaFileManager fm = javac.getStandardFileManager(null, null, null)) { Iterable fos = fm.getJavaFileObjectsFromFiles(javaFiles); @@ -218,10 +229,22 @@ public class DocCommentTreeApiTester { final DocTrees trees = DocTrees.instance(t); StringWriter sw = new StringWriter(); + DocCommentTree dct = null; + String expected = null; + for (JavaFileObject jfo : others) { + switch (jfo.getKind()) { + case HTML: + dct = trees.getDocCommentTree(jfo); + if (dct == null) + throw new Exception("invalid input: " + jfo); + break; + default: + expected = getExpected(jfo.openReader(true)); + } + } - printer.print(trees.getDocCommentTree(others.iterator().next()), sw); + printer.print(dct, sw); String found = sw.toString(); - String expected = getExpected(otherFiles.iterator().next().toPath()); astcheck(otherFiles.toString(), expected, found); } } @@ -237,6 +260,9 @@ public class DocCommentTreeApiTester { List javaFiles = new ArrayList<>(); javaFiles.add(new File(testSrc, javaFileName)); + List otherFiles = new ArrayList<>(); + otherFiles.add(new File(testSrc, pkgFileName + ".out")); + List dirs = new ArrayList<>(); dirs.add(new File(testSrc)); @@ -256,15 +282,23 @@ public class DocCommentTreeApiTester { FileObject htmlFo = fm.getFileForInput(javax.tools.StandardLocation.SOURCE_PATH, t.getElements().getPackageOf(klass).getQualifiedName().toString(), "package.html"); - System.out.println(); DocTreePath treePath = trees.getDocTreePath(htmlFo, pkg); + + if (treePath == null) { + throw new Exception("invalid input: " + htmlFo); + } + DocCommentTree dcTree = treePath.getDocComment(); + if (dcTree == null) + throw new Exception("invalid input" + htmlFo); StringWriter sw = new StringWriter(); printer.print(dcTree, sw); String found = sw.toString(); + Iterable oos = fm.getJavaFileObjectsFromFiles(otherFiles); + JavaFileObject otherFo = oos.iterator().next(); + String expected = getExpected(otherFo.openReader(true)); - String expected = getExpected(htmlFo.openReader(true)); astcheck(pkgFileName, expected, found); } } @@ -300,10 +334,6 @@ public class DocCommentTreeApiTester { return getExpected(lines); } - String getExpected(Path p) throws IOException { - return getExpected(Files.readAllLines(p)); - } - String getExpected(List lines) { boolean start = false; StringWriter sw = new StringWriter(); diff --git a/test/langtools/tools/javac/doctree/dcapi/overview0.html b/test/langtools/tools/javac/doctree/dcapi/overview0.html index 710ac32d9f4..8484422cc1f 100644 --- a/test/langtools/tools/javac/doctree/dcapi/overview0.html +++ b/test/langtools/tools/javac/doctree/dcapi/overview0.html @@ -1,48 +1,8 @@ - - + -A simple well formed html document
overview0.html
.
+A simple well formed html document 
overview0.html
. - - + \ No newline at end of file diff --git a/test/langtools/tools/javac/doctree/dcapi/overview0.html.out b/test/langtools/tools/javac/doctree/dcapi/overview0.html.out new file mode 100644 index 00000000000..9ae529dbcd1 --- /dev/null +++ b/test/langtools/tools/javac/doctree/dcapi/overview0.html.out @@ -0,0 +1,33 @@ +EXPECT_START +DocComment[DOC_COMMENT, pos:0 + preamble: 5 + Comment[COMMENT, pos:0, ] + StartElement[START_ELEMENT, pos:30 + name:HTML + attributes: empty + ] + StartElement[START_ELEMENT, pos:37 + name:HEAD + attributes: empty + ] + EndElement[END_ELEMENT, pos:44, HEAD] + StartElement[START_ELEMENT, pos:52 + name:BODY + attributes: empty + ] + firstSentence: 1 + Text[TEXT, pos:59, A_simple_well_fo...rmed_html_document] + body: 4 + StartElement[START_ELEMENT, pos:94 + name:pre + attributes: empty + ] + Text[TEXT, pos:99, overview0.html] + EndElement[END_ELEMENT, pos:113, pre] + Text[TEXT, pos:119, .] + block tags: empty + postamble: 2 + EndElement[END_ELEMENT, pos:121, BODY] + EndElement[END_ELEMENT, pos:129, HTML] +] +EXPECT_END diff --git a/test/langtools/tools/javac/doctree/dcapi/overview1.html b/test/langtools/tools/javac/doctree/dcapi/overview1.html index 984632b0654..3012e5b3767 100644 --- a/test/langtools/tools/javac/doctree/dcapi/overview1.html +++ b/test/langtools/tools/javac/doctree/dcapi/overview1.html @@ -1,47 +1,8 @@ - - + -Html document
overview1.html
.
+Html document 
overview1.html
. Missing HTML. - + \ No newline at end of file diff --git a/test/langtools/tools/javac/doctree/dcapi/overview1.html.out b/test/langtools/tools/javac/doctree/dcapi/overview1.html.out new file mode 100644 index 00000000000..2feccc1af58 --- /dev/null +++ b/test/langtools/tools/javac/doctree/dcapi/overview1.html.out @@ -0,0 +1,29 @@ +EXPECT_START +DocComment[DOC_COMMENT, pos:0 + preamble: 4 + Comment[COMMENT, pos:0, ] + StartElement[START_ELEMENT, pos:30 + name:HEAD + attributes: empty + ] + EndElement[END_ELEMENT, pos:37, HEAD] + StartElement[START_ELEMENT, pos:45 + name:BODY + attributes: empty + ] + firstSentence: 1 + Text[TEXT, pos:52, Html_document] + body: 4 + StartElement[START_ELEMENT, pos:66 + name:pre + attributes: empty + ] + Text[TEXT, pos:71, overview1.html] + EndElement[END_ELEMENT, pos:85, pre] + Text[TEXT, pos:91, .|Missing_HTML.] + block tags: empty + postamble: 2 + EndElement[END_ELEMENT, pos:107, BODY] + EndElement[END_ELEMENT, pos:115, HTML] +] +EXPECT_END diff --git a/test/langtools/tools/javac/doctree/dcapi/overview2.html b/test/langtools/tools/javac/doctree/dcapi/overview2.html index 6ad01d5c820..432bb7d25bc 100644 --- a/test/langtools/tools/javac/doctree/dcapi/overview2.html +++ b/test/langtools/tools/javac/doctree/dcapi/overview2.html @@ -1,47 +1,8 @@ - - + -Html document
overview2.html
.
+Html document 
overview2.html
. Missing HEAD. - + \ No newline at end of file diff --git a/test/langtools/tools/javac/doctree/dcapi/overview2.html.out b/test/langtools/tools/javac/doctree/dcapi/overview2.html.out new file mode 100644 index 00000000000..07fc0c74d3e --- /dev/null +++ b/test/langtools/tools/javac/doctree/dcapi/overview2.html.out @@ -0,0 +1,29 @@ +EXPECT_START +DocComment[DOC_COMMENT, pos:0 + preamble: 4 + Comment[COMMENT, pos:0, ] + StartElement[START_ELEMENT, pos:30 + name:HTML + attributes: empty + ] + EndElement[END_ELEMENT, pos:37, HEAD] + StartElement[START_ELEMENT, pos:45 + name:BODY + attributes: empty + ] + firstSentence: 1 + Text[TEXT, pos:52, Html_document] + body: 4 + StartElement[START_ELEMENT, pos:66 + name:pre + attributes: empty + ] + Text[TEXT, pos:71, overview2.html] + EndElement[END_ELEMENT, pos:85, pre] + Text[TEXT, pos:91, .|Missing_HEAD.] + block tags: empty + postamble: 2 + EndElement[END_ELEMENT, pos:107, BODY] + EndElement[END_ELEMENT, pos:115, HTML] +] +EXPECT_END diff --git a/test/langtools/tools/javac/doctree/dcapi/overview3.html b/test/langtools/tools/javac/doctree/dcapi/overview3.html index cd4f2c32a8d..fed93a832f8 100644 --- a/test/langtools/tools/javac/doctree/dcapi/overview3.html +++ b/test/langtools/tools/javac/doctree/dcapi/overview3.html @@ -1,47 +1,8 @@ - - + -Html document
overview3.html
.
+Html document 
overview3.html
. Missing enclosing HEAD. - + \ No newline at end of file diff --git a/test/langtools/tools/javac/doctree/dcapi/overview3.html.out b/test/langtools/tools/javac/doctree/dcapi/overview3.html.out new file mode 100644 index 00000000000..84ac2e3e674 --- /dev/null +++ b/test/langtools/tools/javac/doctree/dcapi/overview3.html.out @@ -0,0 +1,32 @@ +EXPECT_START +DocComment[DOC_COMMENT, pos:0 + preamble: 4 + Comment[COMMENT, pos:0, ] + StartElement[START_ELEMENT, pos:30 + name:HTML + attributes: empty + ] + StartElement[START_ELEMENT, pos:37 + name:HEAD + attributes: empty + ] + StartElement[START_ELEMENT, pos:44 + name:BODY + attributes: empty + ] + firstSentence: 1 + Text[TEXT, pos:51, Html_document] + body: 4 + StartElement[START_ELEMENT, pos:65 + name:pre + attributes: empty + ] + Text[TEXT, pos:70, overview3.html] + EndElement[END_ELEMENT, pos:84, pre] + Text[TEXT, pos:90, .|Missing_enclosing_HEAD.] + block tags: empty + postamble: 2 + EndElement[END_ELEMENT, pos:116, BODY] + EndElement[END_ELEMENT, pos:124, HTML] +] +EXPECT_END diff --git a/test/langtools/tools/javac/doctree/dcapi/overview4.html b/test/langtools/tools/javac/doctree/dcapi/overview4.html index 6391c7b4982..57fa54e556c 100644 --- a/test/langtools/tools/javac/doctree/dcapi/overview4.html +++ b/test/langtools/tools/javac/doctree/dcapi/overview4.html @@ -1,44 +1,6 @@ - - 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. ---> - -Html document
overview4.html
.
+Html document 
overview4.html
. Only BODY - + \ No newline at end of file diff --git a/test/langtools/tools/javac/doctree/dcapi/overview4.html.out b/test/langtools/tools/javac/doctree/dcapi/overview4.html.out new file mode 100644 index 00000000000..2e9351ce0ef --- /dev/null +++ b/test/langtools/tools/javac/doctree/dcapi/overview4.html.out @@ -0,0 +1,23 @@ +EXPECT_START +DocComment[DOC_COMMENT, pos:0 + preamble: 2 + Comment[COMMENT, pos:0, ] + StartElement[START_ELEMENT, pos:31 + name:BODY + attributes: empty + ] + firstSentence: 1 + Text[TEXT, pos:38, Html_document] + body: 4 + StartElement[START_ELEMENT, pos:52 + name:pre + attributes: empty + ] + Text[TEXT, pos:57, overview4.html] + EndElement[END_ELEMENT, pos:71, pre] + Text[TEXT, pos:77, .|Only_BODY] + block tags: empty + postamble: 1 + EndElement[END_ELEMENT, pos:89, BODY] +] +EXPECT_END diff --git a/test/langtools/tools/javac/doctree/dcapi/overview5.html b/test/langtools/tools/javac/doctree/dcapi/overview5.html index 5532a18a06a..af7d365a440 100644 --- a/test/langtools/tools/javac/doctree/dcapi/overview5.html +++ b/test/langtools/tools/javac/doctree/dcapi/overview5.html @@ -1,47 +1,8 @@ - - + -Html document
overview5.html
.
+Html document 
overview5.html
. Missing enclosing HTML - + \ No newline at end of file diff --git a/test/langtools/tools/javac/doctree/dcapi/overview5.html.out b/test/langtools/tools/javac/doctree/dcapi/overview5.html.out new file mode 100644 index 00000000000..07970b4b151 --- /dev/null +++ b/test/langtools/tools/javac/doctree/dcapi/overview5.html.out @@ -0,0 +1,32 @@ +EXPECT_START +DocComment[DOC_COMMENT, pos:0 + preamble: 5 + Comment[COMMENT, pos:0, ] + StartElement[START_ELEMENT, pos:30 + name:HTML + attributes: empty + ] + StartElement[START_ELEMENT, pos:37 + name:HEAD + attributes: empty + ] + EndElement[END_ELEMENT, pos:44, HEAD] + StartElement[START_ELEMENT, pos:52 + name:BODY + attributes: empty + ] + firstSentence: 1 + Text[TEXT, pos:59, Html_document] + body: 4 + StartElement[START_ELEMENT, pos:73 + name:pre + attributes: empty + ] + Text[TEXT, pos:78, overview5.html] + EndElement[END_ELEMENT, pos:92, pre] + Text[TEXT, pos:98, .|Missing_enclosing_HTML] + block tags: empty + postamble: 1 + EndElement[END_ELEMENT, pos:123, BODY] +] +EXPECT_END diff --git a/test/langtools/tools/javac/doctree/dcapi/overview6.html b/test/langtools/tools/javac/doctree/dcapi/overview6.html index 72f57cd74a6..2d464cd6580 100644 --- a/test/langtools/tools/javac/doctree/dcapi/overview6.html +++ b/test/langtools/tools/javac/doctree/dcapi/overview6.html @@ -1,40 +1,4 @@ - - + @@ -46,4 +10,3 @@ The first correct body pair. Illegal second body pair, the first body should not be ignored. - diff --git a/test/langtools/tools/javac/doctree/dcapi/overview6.html.out b/test/langtools/tools/javac/doctree/dcapi/overview6.html.out new file mode 100644 index 00000000000..ef8c147c7fb --- /dev/null +++ b/test/langtools/tools/javac/doctree/dcapi/overview6.html.out @@ -0,0 +1,32 @@ +EXPECT_START +DocComment[DOC_COMMENT, pos:0 + preamble: 5 + Comment[COMMENT, pos:0, ] + StartElement[START_ELEMENT, pos:30 + name:HTML + attributes: empty + ] + StartElement[START_ELEMENT, pos:37 + name:HEAD + attributes: empty + ] + EndElement[END_ELEMENT, pos:44, HEAD] + StartElement[START_ELEMENT, pos:52 + name:BODY + attributes: empty + ] + firstSentence: 1 + Text[TEXT, pos:59, The_first_correct_body_pair.] + body: empty + block tags: empty + postamble: 5 + EndElement[END_ELEMENT, pos:88, BODY] + StartElement[START_ELEMENT, pos:97 + name:BODY + attributes: empty + ] + Text[TEXT, pos:104, Illegal_second_b...ody_pair,_the_first_body_should_not_be_ignored.|] + EndElement[END_ELEMENT, pos:168, BODY] + EndElement[END_ELEMENT, pos:176, HTML] +] +EXPECT_END diff --git a/test/langtools/tools/javac/doctree/dcapi/overview7.html b/test/langtools/tools/javac/doctree/dcapi/overview7.html new file mode 100644 index 00000000000..8c47bd84cd0 --- /dev/null +++ b/test/langtools/tools/javac/doctree/dcapi/overview7.html @@ -0,0 +1,6 @@ + + + + +@since 1.0 + diff --git a/test/langtools/tools/javac/doctree/dcapi/overview7.html.out b/test/langtools/tools/javac/doctree/dcapi/overview7.html.out new file mode 100644 index 00000000000..fd2958e0e5e --- /dev/null +++ b/test/langtools/tools/javac/doctree/dcapi/overview7.html.out @@ -0,0 +1,29 @@ +EXPECT_START +DocComment[DOC_COMMENT, pos:0 + preamble: 5 + Comment[COMMENT, pos:0, ] + StartElement[START_ELEMENT, pos:30 + name:HTML + attributes: empty + ] + StartElement[START_ELEMENT, pos:37 + name:HEAD + attributes: empty + ] + EndElement[END_ELEMENT, pos:44, HEAD] + StartElement[START_ELEMENT, pos:52 + name:BODY + attributes: empty + ] + firstSentence: empty + body: empty + block tags: 1 + Since[SINCE, pos:58 + body: 1 + Text[TEXT, pos:65, 1.0] + ] + postamble: 2 + EndElement[END_ELEMENT, pos:68, BODY] + EndElement[END_ELEMENT, pos:76, HTML] +] +EXPECT_END diff --git a/test/langtools/tools/javac/doctree/dcapi/package.html b/test/langtools/tools/javac/doctree/dcapi/package.html index 6a6084159fb..82201fd92dc 100644 --- a/test/langtools/tools/javac/doctree/dcapi/package.html +++ b/test/langtools/tools/javac/doctree/dcapi/package.html @@ -1,47 +1,11 @@ - + + + The Crafty Fox A simple well formed html document
package.html
.
 
-
-
+
\ No newline at end of file
diff --git a/test/langtools/tools/javac/doctree/dcapi/package.html.out b/test/langtools/tools/javac/doctree/dcapi/package.html.out
new file mode 100644
index 00000000000..ea658e16c02
--- /dev/null
+++ b/test/langtools/tools/javac/doctree/dcapi/package.html.out
@@ -0,0 +1,43 @@
+EXPECT_START
+DocComment[DOC_COMMENT, pos:10
+  preamble: 9
+    DocType[DOC_TYPE, pos:10, HTML_PUBLIC_"-//...W3C//DTD_HTML_4.01//EN"|________"http://www.w3.org/TR/html4/strict.dtd"]
+    Comment[COMMENT, pos:99, ]
+    StartElement[START_ELEMENT, pos:129
+      name:HTML
+      attributes: empty
+    ]
+    StartElement[START_ELEMENT, pos:136
+      name:HEAD
+      attributes: empty
+    ]
+    StartElement[START_ELEMENT, pos:147
+      name:TITLE
+      attributes: empty
+    ]
+    Text[TEXT, pos:154, The_Crafty_Fox]
+    EndElement[END_ELEMENT, pos:168, TITLE]
+    EndElement[END_ELEMENT, pos:177, HEAD]
+    StartElement[START_ELEMENT, pos:185
+      name:BODY
+      attributes: empty
+    ]
+  firstSentence: 1
+    Text[TEXT, pos:192, A_simple_well_fo...rmed_html_document]
+  body: 4
+    StartElement[START_ELEMENT, pos:227
+      name:pre
+      attributes: empty
+    ]
+    Text[TEXT, pos:232, package.html]
+    StartElement[START_ELEMENT, pos:244
+      name:pre
+      attributes: empty
+    ]
+    Text[TEXT, pos:249, .]
+  block tags: empty
+  postamble: 2
+    EndElement[END_ELEMENT, pos:251, BODY]
+    EndElement[END_ELEMENT, pos:259, HTML]
+]
+EXPECT_END
diff --git a/test/langtools/tools/javac/doctree/dcapi/pkg/package.html b/test/langtools/tools/javac/doctree/dcapi/pkg/package.html
index 262a10c315f..bd8212d7109 100644
--- a/test/langtools/tools/javac/doctree/dcapi/pkg/package.html
+++ b/test/langtools/tools/javac/doctree/dcapi/pkg/package.html
@@ -1,48 +1,9 @@
-
-
+
 
 
 
 
-A simple well formed html document 
package.html
.
+A simple well formed html document 
package.html
. In package pkg. - + \ No newline at end of file diff --git a/test/langtools/tools/javac/doctree/dcapi/pkg/package.html.out b/test/langtools/tools/javac/doctree/dcapi/pkg/package.html.out new file mode 100644 index 00000000000..892e83b9349 --- /dev/null +++ b/test/langtools/tools/javac/doctree/dcapi/pkg/package.html.out @@ -0,0 +1,33 @@ +EXPECT_START +DocComment[DOC_COMMENT, pos:0 + preamble: 5 + Comment[COMMENT, pos:0, ] + StartElement[START_ELEMENT, pos:31 + name:HTML + attributes: empty + ] + StartElement[START_ELEMENT, pos:38 + name:HEAD + attributes: empty + ] + EndElement[END_ELEMENT, pos:45, HEAD] + StartElement[START_ELEMENT, pos:53 + name:BODY + attributes: empty + ] + firstSentence: 1 + Text[TEXT, pos:60, A_simple_well_fo...rmed_html_document] + body: 4 + StartElement[START_ELEMENT, pos:95 + name:pre + attributes: empty + ] + Text[TEXT, pos:100, package.html] + EndElement[END_ELEMENT, pos:112, pre] + Text[TEXT, pos:118, .|In_package_pkg.] + block tags: empty + postamble: 2 + EndElement[END_ELEMENT, pos:136, BODY] + EndElement[END_ELEMENT, pos:144, HTML] +] +EXPECT_END \ No newline at end of file diff --git a/test/langtools/tools/javac/lib/DPrinter.java b/test/langtools/tools/javac/lib/DPrinter.java index 1c713a38daa..d681d642f76 100644 --- a/test/langtools/tools/javac/lib/DPrinter.java +++ b/test/langtools/tools/javac/lib/DPrinter.java @@ -1028,6 +1028,12 @@ public class DPrinter { return visitInlineTag(node, null); } + @Override + public Void visitDocType(DocTypeTree node, Void aVoid) { + printLimitedEscapedString("body", node.getText()); + return visitTree(node, null); + } + public Void visitEndElement(EndElementTree node, Void p) { printName("name", node.getName()); return visitTree(node, null);