From fa0093dc2c050d370889e83835e9ba20907307fb Mon Sep 17 00:00:00 2001 From: Jonathan Gibbons Date: Thu, 21 Feb 2019 14:03:57 -0800 Subject: [PATCH] 8215307: Pages do not have

Reviewed-by: hannesw --- .../formats/html/AbstractIndexWriter.java | 6 +- .../formats/html/AbstractMemberWriter.java | 16 +-- .../html/AbstractModuleIndexWriter.java | 5 +- .../html/AbstractPackageIndexWriter.java | 3 +- .../formats/html/AbstractTreeWriter.java | 5 +- .../formats/html/AllClassesFrameWriter.java | 3 +- .../formats/html/AllClassesIndexWriter.java | 3 +- .../formats/html/AllPackagesIndexWriter.java | 3 +- .../html/AnnotationTypeFieldWriterImpl.java | 13 +- ...nnotationTypeOptionalMemberWriterImpl.java | 8 +- ...nnotationTypeRequiredMemberWriterImpl.java | 14 +- .../html/AnnotationTypeWriterImpl.java | 7 +- .../doclets/formats/html/ClassUseWriter.java | 5 +- .../doclets/formats/html/ClassWriterImpl.java | 7 +- .../html/ConstantsSummaryWriterImpl.java | 7 +- .../formats/html/ConstructorWriterImpl.java | 13 +- .../formats/html/DeprecatedListWriter.java | 5 +- .../formats/html/EnumConstantWriterImpl.java | 14 +- .../doclets/formats/html/FieldWriterImpl.java | 16 +-- .../doclets/formats/html/Headings.java | 134 ++++++++++++++++++ .../doclets/formats/html/HelpWriter.java | 31 ++-- .../formats/html/HtmlConfiguration.java | 11 +- .../formats/html/HtmlSerialFieldWriter.java | 10 +- .../formats/html/HtmlSerialMethodWriter.java | 10 +- ...HtmlConstants.java => MarkerComments.java} | 116 ++++----------- .../formats/html/MethodWriterImpl.java | 15 +- .../formats/html/ModuleFrameWriter.java | 5 +- .../formats/html/ModuleIndexFrameWriter.java | 25 ++-- .../html/ModulePackageIndexFrameWriter.java | 27 ++-- .../formats/html/ModuleWriterImpl.java | 13 +- .../formats/html/NestedClassWriterImpl.java | 11 +- .../formats/html/PackageFrameWriter.java | 5 +- .../formats/html/PackageIndexFrameWriter.java | 5 +- .../formats/html/PackageTreeWriter.java | 3 +- .../formats/html/PackageUseWriter.java | 3 +- .../formats/html/PackageWriterImpl.java | 3 +- .../formats/html/PropertyWriterImpl.java | 15 +- .../html/SerializedFormWriterImpl.java | 10 +- .../doclets/formats/html/TreeWriter.java | 3 +- .../formats/html/markup/Navigation.java | 7 +- .../builders/SerializedFormBuilder.java | 6 +- .../doclets/toolkit/resources/stylesheet.css | 22 ++- .../TestAnnotationTypes.java | 8 +- .../doclet/testHeadings/TestHeadings.java | 21 +-- .../doclet/testHiddenTag/TestHiddenTag.java | 4 +- .../jdk/javadoc/doclet/testHref/TestHref.java | 2 +- .../TestHtmlLandmarkRegions.java | 12 +- .../testHtmlVersion/TestHtmlVersion.java | 84 +++++------ .../testIndexTaglet/TestIndexTaglet.java | 6 +- .../doclet/testInterface/TestInterface.java | 8 +- .../javadoc/doclet/testJavaFX/TestJavaFX.java | 32 ++--- .../testModules/TestModuleServices.java | 14 +- .../doclet/testModules/TestModules.java | 2 +- .../TestNewLanguageFeatures.java | 6 +- .../doclet/testOptions/TestOptions.java | 4 +- .../doclet/testOrdering/TestOrdering.java | 90 ++++++------ .../TestBadOverride.java | 4 +- .../TestSerializedForm.java | 12 +- .../TestSummaryHeading.java | 4 +- .../doclet/testSummaryTag/TestSummaryTag.java | 2 +- .../TestSystemPropertyTaglet.java | 6 +- .../lib/javadoc/tester/JavadocTester.java | 79 ++++++++--- .../lib/javadoc/tester/ShowHeadings.java | 102 +++++++++++++ 63 files changed, 660 insertions(+), 485 deletions(-) create mode 100644 src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/Headings.java rename src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/{markup/HtmlConstants.java => MarkerComments.java} (62%) create mode 100644 test/langtools/jdk/javadoc/lib/javadoc/tester/ShowHeadings.java diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractIndexWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractIndexWriter.java index 56e6c83aa3e..4af3df20a79 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractIndexWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractIndexWriter.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, 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 @@ -30,7 +30,6 @@ import java.util.*; import java.util.zip.*; import javax.lang.model.element.Element; -import javax.lang.model.element.ElementKind; import javax.lang.model.element.ExecutableElement; import javax.lang.model.element.ModuleElement; import javax.lang.model.element.PackageElement; @@ -38,7 +37,6 @@ import javax.lang.model.element.TypeElement; import javax.lang.model.util.SimpleElementVisitor9; import com.sun.source.doctree.DocTree; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -170,7 +168,7 @@ public class AbstractIndexWriter extends HtmlDocletWriter { String unicode = uc.toString(); contentTree.addContent(getMarkerAnchorForIndex(unicode)); Content headContent = new StringContent(unicode); - Content heading = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, false, + Content heading = HtmlTree.HEADING(Headings.CONTENT_HEADING, false, HtmlStyle.title, headContent); contentTree.addContent(heading); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractMemberWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractMemberWriter.java index c57408a5fdd..2d0025ee808 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractMemberWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractMemberWriter.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2019, 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 @@ -40,12 +40,10 @@ import javax.lang.model.type.TypeMirror; import com.sun.source.doctree.DocTree; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; import jdk.javadoc.internal.doclets.formats.html.markup.Links; -import jdk.javadoc.internal.doclets.formats.html.markup.StringContent; import jdk.javadoc.internal.doclets.toolkit.Content; import jdk.javadoc.internal.doclets.toolkit.MemberSummaryWriter; import jdk.javadoc.internal.doclets.toolkit.Resources; @@ -375,18 +373,6 @@ public abstract class AbstractMemberWriter implements MemberSummaryWriter { return utils.getSimpleName(member); } - /** - * Get the header for the section. - * - * @param member the member being documented. - * @return a header content for the section. - */ - protected Content getHead(Element member) { - Content memberContent = new StringContent(name(member)); - Content heading = HtmlTree.HEADING(HtmlConstants.MEMBER_HEADING, memberContent); - return heading; - } - /** * Return true if the given ProgramElement is inherited * by the class that is being documented. diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractModuleIndexWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractModuleIndexWriter.java index 794d7ceb5f4..7927c4805ed 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractModuleIndexWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractModuleIndexWriter.java @@ -33,7 +33,6 @@ import java.util.SortedMap; import javax.lang.model.element.ModuleElement; import javax.lang.model.element.PackageElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -224,7 +223,7 @@ public abstract class AbstractModuleIndexWriter extends HtmlDocletWriter { * @param modules the modules to be documented * @param text string which will be used as the heading * @param tableSummary summary for the table - * @param header the document tree to which the navgational links will be added + * @param header the document tree to which the navigational links will be added * @param main the document tree to which the modules list will be added */ protected void addIndexContents(Collection modules, String text, @@ -270,7 +269,7 @@ public abstract class AbstractModuleIndexWriter extends HtmlDocletWriter { protected void addConfigurationTitle(Content body) { if (configuration.doctitle.length() > 0) { Content title = new RawHtml(configuration.doctitle); - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, HtmlStyle.title, title); Content div = HtmlTree.DIV(HtmlStyle.header, heading); body.addContent(div); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractPackageIndexWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractPackageIndexWriter.java index 7ffd97c38dc..cc254f57c3c 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractPackageIndexWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractPackageIndexWriter.java @@ -29,7 +29,6 @@ import java.util.*; import javax.lang.model.element.PackageElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -180,7 +179,7 @@ public abstract class AbstractPackageIndexWriter extends HtmlDocletWriter { protected void addConfigurationTitle(Content body) { if (configuration.doctitle.length() > 0) { Content title = new RawHtml(configuration.doctitle); - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, HtmlStyle.title, title); Content div = HtmlTree.DIV(HtmlStyle.header, heading); body.addContent(div); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractTreeWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractTreeWriter.java index fd310241a10..82009fea847 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractTreeWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AbstractTreeWriter.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, 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 @@ -29,7 +29,6 @@ import java.util.*; import javax.lang.model.element.TypeElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -117,7 +116,7 @@ public abstract class AbstractTreeWriter extends HtmlDocletWriter { if (!sset.isEmpty()) { TypeElement firstTypeElement = sset.first(); Content headingContent = contents.getContent(heading); - Content sectionHeading = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, true, + Content sectionHeading = HtmlTree.HEADING(Headings.CONTENT_HEADING, true, headingContent); HtmlTree htmlTree = HtmlTree.SECTION(sectionHeading); addLevelInfo(!utils.isInterface(firstTypeElement) ? firstTypeElement : null, diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllClassesFrameWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllClassesFrameWriter.java index 2f4a3914448..86931ef0010 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllClassesFrameWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllClassesFrameWriter.java @@ -29,7 +29,6 @@ package jdk.javadoc.internal.doclets.formats.html; import javax.lang.model.element.Element; import javax.lang.model.element.TypeElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -112,7 +111,7 @@ public class AllClassesFrameWriter extends HtmlDocletWriter { String label = resources.getText("doclet.All_Classes"); Content body = getBody(false, getWindowTitle(label)); Content htmlTree = HtmlTree.MAIN(); - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, HtmlStyle.bar, contents.allClassesLabel); htmlTree.addContent(heading); Content ul = new HtmlTree(HtmlTag.UL); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllClassesIndexWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllClassesIndexWriter.java index 3d5ba0dbbc0..906073e7e95 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllClassesIndexWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllClassesIndexWriter.java @@ -32,7 +32,6 @@ import javax.lang.model.element.TypeElement; import com.sun.source.doctree.DocTree; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -148,7 +147,7 @@ public class AllClassesIndexWriter extends HtmlDocletWriter { } } Content titleContent = contents.allClassesLabel; - Content pHeading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, true, + Content pHeading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.title, titleContent); Content headerDiv = HtmlTree.DIV(HtmlStyle.header, pHeading); content.addContent(headerDiv); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllPackagesIndexWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllPackagesIndexWriter.java index d07013c6d2d..545dd7475b4 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllPackagesIndexWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AllPackagesIndexWriter.java @@ -27,7 +27,6 @@ package jdk.javadoc.internal.doclets.formats.html; import javax.lang.model.element.PackageElement; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -94,7 +93,7 @@ public class AllPackagesIndexWriter extends HtmlDocletWriter { div.setStyle(HtmlStyle.allPackagesContainer); addPackages(div); Content titleContent = contents.allPackagesLabel; - Content pHeading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, true, + Content pHeading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.title, titleContent); Content headerDiv = HtmlTree.DIV(HtmlStyle.header, pHeading); mainTree.addContent(headerDiv); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeFieldWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeFieldWriterImpl.java index db13176dd3a..4a219105603 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeFieldWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeFieldWriterImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2013, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2013, 2019, 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 @@ -33,7 +33,6 @@ import javax.lang.model.element.TypeElement; import javax.lang.model.type.TypeMirror; import jdk.javadoc.internal.doclets.formats.html.markup.TableHeader; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -72,7 +71,7 @@ public class AnnotationTypeFieldWriterImpl extends AbstractMemberWriter public Content getMemberSummaryHeader(TypeElement typeElement, Content memberSummaryTree) { memberSummaryTree.addContent( - HtmlConstants.START_OF_ANNOTATION_TYPE_FIELD_SUMMARY); + MarkerComments.START_OF_ANNOTATION_TYPE_FIELD_SUMMARY); Content memberTree = writer.getMemberTreeHeader(); writer.addSummaryHeader(this, typeElement, memberTree); return memberTree; @@ -96,7 +95,7 @@ public class AnnotationTypeFieldWriterImpl extends AbstractMemberWriter * {@inheritDoc} */ public void addAnnotationFieldDetailsMarker(Content memberDetails) { - memberDetails.addContent(HtmlConstants.START_OF_ANNOTATION_TYPE_FIELD_DETAILS); + memberDetails.addContent(MarkerComments.START_OF_ANNOTATION_TYPE_FIELD_DETAILS); } /** @@ -107,7 +106,7 @@ public class AnnotationTypeFieldWriterImpl extends AbstractMemberWriter if (!writer.printedAnnotationFieldHeading) { memberDetailsTree.addContent(links.createAnchor( SectionName.ANNOTATION_TYPE_FIELD_DETAIL)); - Content heading = HtmlTree.HEADING(HtmlConstants.DETAILS_HEADING, + Content heading = HtmlTree.HEADING(Headings.TypeDeclaration.DETAILS_HEADING, contents.fieldDetailsLabel); memberDetailsTree.addContent(heading); writer.printedAnnotationFieldHeading = true; @@ -121,7 +120,7 @@ public class AnnotationTypeFieldWriterImpl extends AbstractMemberWriter Content annotationDetailsTree) { annotationDetailsTree.addContent(links.createAnchor(name(member))); Content annotationDocTree = writer.getMemberTreeHeader(); - Content heading = new HtmlTree(HtmlConstants.MEMBER_HEADING); + Content heading = new HtmlTree(Headings.TypeDeclaration.MEMBER_HEADING); heading.addContent(name(member)); annotationDocTree.addContent(heading); return annotationDocTree; @@ -188,7 +187,7 @@ public class AnnotationTypeFieldWriterImpl extends AbstractMemberWriter * {@inheritDoc} */ public void addSummaryLabel(Content memberTree) { - Content label = HtmlTree.HEADING(HtmlConstants.SUMMARY_HEADING, + Content label = HtmlTree.HEADING(Headings.TypeDeclaration.SUMMARY_HEADING, contents.fieldSummaryLabel); memberTree.addContent(label); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeOptionalMemberWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeOptionalMemberWriterImpl.java index a324361b0df..a91f0fbc32f 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeOptionalMemberWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeOptionalMemberWriterImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2019, 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 @@ -33,9 +33,7 @@ import javax.lang.model.element.Element; import javax.lang.model.element.ExecutableElement; import javax.lang.model.element.TypeElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; -import jdk.javadoc.internal.doclets.formats.html.markup.Navigation; import jdk.javadoc.internal.doclets.formats.html.markup.StringContent; import jdk.javadoc.internal.doclets.toolkit.AnnotationTypeOptionalMemberWriter; import jdk.javadoc.internal.doclets.toolkit.Content; @@ -75,7 +73,7 @@ public class AnnotationTypeOptionalMemberWriterImpl extends public Content getMemberSummaryHeader(TypeElement typeElement, Content memberSummaryTree) { memberSummaryTree.addContent( - HtmlConstants.START_OF_ANNOTATION_TYPE_OPTIONAL_MEMBER_SUMMARY); + MarkerComments.START_OF_ANNOTATION_TYPE_OPTIONAL_MEMBER_SUMMARY); Content memberTree = writer.getMemberTreeHeader(); writer.addSummaryHeader(this, typeElement, memberTree); return memberTree; @@ -112,7 +110,7 @@ public class AnnotationTypeOptionalMemberWriterImpl extends */ @Override public void addSummaryLabel(Content memberTree) { - Content label = HtmlTree.HEADING(HtmlConstants.SUMMARY_HEADING, + Content label = HtmlTree.HEADING(Headings.TypeDeclaration.SUMMARY_HEADING, contents.annotateTypeOptionalMemberSummaryLabel); memberTree.addContent(label); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeRequiredMemberWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeRequiredMemberWriterImpl.java index dc0955391cd..2c23eba047e 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeRequiredMemberWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeRequiredMemberWriterImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2019, 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 @@ -33,11 +33,9 @@ import javax.lang.model.element.TypeElement; import javax.lang.model.type.TypeMirror; import jdk.javadoc.internal.doclets.formats.html.markup.TableHeader; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; -import jdk.javadoc.internal.doclets.formats.html.markup.Navigation; import jdk.javadoc.internal.doclets.formats.html.markup.StringContent; import jdk.javadoc.internal.doclets.toolkit.AnnotationTypeRequiredMemberWriter; import jdk.javadoc.internal.doclets.toolkit.Content; @@ -75,7 +73,7 @@ public class AnnotationTypeRequiredMemberWriterImpl extends AbstractMemberWriter public Content getMemberSummaryHeader(TypeElement typeElement, Content memberSummaryTree) { memberSummaryTree.addContent( - HtmlConstants.START_OF_ANNOTATION_TYPE_REQUIRED_MEMBER_SUMMARY); + MarkerComments.START_OF_ANNOTATION_TYPE_REQUIRED_MEMBER_SUMMARY); Content memberTree = writer.getMemberTreeHeader(); writer.addSummaryHeader(this, typeElement, memberTree); return memberTree; @@ -99,7 +97,7 @@ public class AnnotationTypeRequiredMemberWriterImpl extends AbstractMemberWriter * {@inheritDoc} */ public void addAnnotationDetailsMarker(Content memberDetails) { - memberDetails.addContent(HtmlConstants.START_OF_ANNOTATION_TYPE_DETAILS); + memberDetails.addContent(MarkerComments.START_OF_ANNOTATION_TYPE_DETAILS); } /** @@ -110,7 +108,7 @@ public class AnnotationTypeRequiredMemberWriterImpl extends AbstractMemberWriter if (!writer.printedAnnotationHeading) { memberDetailsTree.addContent(links.createAnchor( SectionName.ANNOTATION_TYPE_ELEMENT_DETAIL)); - Content heading = HtmlTree.HEADING(HtmlConstants.DETAILS_HEADING, + Content heading = HtmlTree.HEADING(Headings.TypeDeclaration.DETAILS_HEADING, contents.annotationTypeDetailsLabel); memberDetailsTree.addContent(heading); writer.printedAnnotationHeading = true; @@ -126,7 +124,7 @@ public class AnnotationTypeRequiredMemberWriterImpl extends AbstractMemberWriter annotationDetailsTree.addContent(links.createAnchor( simpleName + utils.signature((ExecutableElement) member))); Content annotationDocTree = writer.getMemberTreeHeader(); - Content heading = new HtmlTree(HtmlConstants.MEMBER_HEADING); + Content heading = new HtmlTree(Headings.TypeDeclaration.MEMBER_HEADING); heading.addContent(simpleName); annotationDocTree.addContent(heading); return annotationDocTree; @@ -193,7 +191,7 @@ public class AnnotationTypeRequiredMemberWriterImpl extends AbstractMemberWriter * {@inheritDoc} */ public void addSummaryLabel(Content memberTree) { - Content label = HtmlTree.HEADING(HtmlConstants.SUMMARY_HEADING, + Content label = HtmlTree.HEADING(Headings.TypeDeclaration.SUMMARY_HEADING, contents.annotateTypeRequiredMemberSummaryLabel); memberTree.addContent(label); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeWriterImpl.java index c69d76d5f23..ef68b8b194b 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/AnnotationTypeWriterImpl.java @@ -32,7 +32,6 @@ import javax.lang.model.element.PackageElement; import javax.lang.model.element.TypeElement; import com.sun.source.doctree.DocTree; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -95,7 +94,7 @@ public class AnnotationTypeWriterImpl extends SubWriterHolderWriter navBar.setUserHeader(getUserHeaderFooter(true)); htmlTree.addContent(navBar.getContent(true)); bodyTree.addContent(htmlTree); - bodyTree.addContent(HtmlConstants.START_OF_CLASS_DATA); + bodyTree.addContent(MarkerComments.START_OF_CLASS_DATA); HtmlTree div = new HtmlTree(HtmlTag.DIV); div.setStyle(HtmlStyle.header); if (configuration.showModules) { @@ -118,7 +117,7 @@ public class AnnotationTypeWriterImpl extends SubWriterHolderWriter LinkInfoImpl linkInfo = new LinkInfoImpl(configuration, LinkInfoImpl.Kind.CLASS_HEADER, annotationType); Content headerContent = new StringContent(header); - Content heading = HtmlTree.HEADING(HtmlConstants.CLASS_PAGE_HEADING, true, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.title, headerContent); heading.addContent(getTypeParameterLinks(linkInfo)); div.addContent(heading); @@ -139,7 +138,7 @@ public class AnnotationTypeWriterImpl extends SubWriterHolderWriter */ @Override public void addFooter(Content contentTree) { - contentTree.addContent(HtmlConstants.END_OF_CLASS_DATA); + contentTree.addContent(MarkerComments.END_OF_CLASS_DATA); Content htmlTree = HtmlTree.FOOTER(); navBar.setUserFooter(getUserHeaderFooter(false)); htmlTree.addContent(navBar.getContent(false)); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassUseWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassUseWriter.java index 42624d22891..655edfe5167 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassUseWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassUseWriter.java @@ -42,7 +42,6 @@ import javax.lang.model.element.TypeElement; import javax.tools.Diagnostic; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -325,7 +324,7 @@ public class ClassUseWriter extends SubWriterHolderWriter { getLink(new LinkInfoImpl(configuration, LinkInfoImpl.Kind.CLASS_USE_HEADER, typeElement)), getPackageLink(pkg, utils.getPackageName(pkg))); - Content heading = HtmlTree.HEADING(HtmlConstants.SUMMARY_HEADING, link); + Content heading = HtmlTree.HEADING(Headings.TypeUse.SUMMARY_HEADING, link); htmlTree.addContent(heading); addClassUse(pkg, htmlTree); ul.addContent(HtmlTree.LI(HtmlStyle.blockList, htmlTree)); @@ -452,7 +451,7 @@ public class ClassUseWriter extends SubWriterHolderWriter { headContent.addContent(contents.getContent("doclet.ClassUse_Title", cltype)); headContent.addContent(new HtmlTree(HtmlTag.BR)); headContent.addContent(clname); - Content heading = HtmlTree.HEADING(HtmlConstants.CLASS_PAGE_HEADING, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.title, headContent); Content div = HtmlTree.DIV(HtmlStyle.header, heading); mainTree.addContent(div); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassWriterImpl.java index 917d96a1815..3ed401ae47a 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassWriterImpl.java @@ -36,7 +36,6 @@ import javax.lang.model.type.TypeMirror; import javax.lang.model.util.SimpleElementVisitor8; import com.sun.source.doctree.DocTree; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -116,7 +115,7 @@ public class ClassWriterImpl extends SubWriterHolderWriter implements ClassWrite navBar.setUserHeader(getUserHeaderFooter(true)); htmlTree.addContent(navBar.getContent(true)); bodyTree.addContent(htmlTree); - bodyTree.addContent(HtmlConstants.START_OF_CLASS_DATA); + bodyTree.addContent(MarkerComments.START_OF_CLASS_DATA); HtmlTree div = new HtmlTree(HtmlTag.DIV); div.setStyle(HtmlStyle.header); if (configuration.showModules) { @@ -143,7 +142,7 @@ public class ClassWriterImpl extends SubWriterHolderWriter implements ClassWrite //Let's not link to ourselves in the header. linkInfo.linkToSelf = false; Content headerContent = new StringContent(header); - Content heading = HtmlTree.HEADING(HtmlConstants.CLASS_PAGE_HEADING, true, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.title, headerContent); heading.addContent(getTypeParameterLinks(linkInfo)); div.addContent(heading); @@ -164,7 +163,7 @@ public class ClassWriterImpl extends SubWriterHolderWriter implements ClassWrite */ @Override public void addFooter(Content contentTree) { - contentTree.addContent(HtmlConstants.END_OF_CLASS_DATA); + contentTree.addContent(MarkerComments.END_OF_CLASS_DATA); Content htmlTree = HtmlTree.FOOTER(); navBar.setUserFooter(getUserHeaderFooter(false)); htmlTree.addContent(navBar.getContent(false)); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ConstantsSummaryWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ConstantsSummaryWriterImpl.java index b0c08ee17f8..3c381de5f5d 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ConstantsSummaryWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ConstantsSummaryWriterImpl.java @@ -36,7 +36,6 @@ import javax.lang.model.element.TypeElement; import javax.lang.model.element.VariableElement; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -152,11 +151,11 @@ public class ConstantsSummaryWriterImpl extends HtmlDocletWriter implements Cons @Override public void addContentsList(Content contentTree, Content contentListTree) { Content titleContent = contents.constantsSummaryTitle; - Content pHeading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, true, + Content pHeading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.title, titleContent); Content div = HtmlTree.DIV(HtmlStyle.header, pHeading); Content headingContent = contents.contentsHeading; - Content heading = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, true, + Content heading = HtmlTree.HEADING(Headings.CONTENT_HEADING, true, headingContent); HtmlTree section = HtmlTree.SECTION(heading); section.addContent(contentListTree); @@ -192,7 +191,7 @@ public class ConstantsSummaryWriterImpl extends HtmlDocletWriter implements Cons pkgNameContent = getPackageLabel(parsedPackageName); } Content headingContent = new StringContent(".*"); - Content heading = HtmlTree.HEADING(HtmlConstants.PACKAGE_HEADING, true, + Content heading = HtmlTree.HEADING(Headings.ConstantsSummary.PACKAGE_HEADING, true, pkgNameContent); heading.addContent(headingContent); summaryTree = HtmlTree.SECTION(heading); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ConstructorWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ConstructorWriterImpl.java index de70a890dec..f55d78b2acc 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ConstructorWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ConstructorWriterImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2019, 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 @@ -34,7 +34,6 @@ import javax.lang.model.element.Element; import javax.lang.model.element.ExecutableElement; import javax.lang.model.element.TypeElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -98,7 +97,7 @@ public class ConstructorWriterImpl extends AbstractExecutableMemberWriter @Override public Content getMemberSummaryHeader(TypeElement typeElement, Content memberSummaryTree) { - memberSummaryTree.addContent(HtmlConstants.START_OF_CONSTRUCTOR_SUMMARY); + memberSummaryTree.addContent(MarkerComments.START_OF_CONSTRUCTOR_SUMMARY); Content memberTree = writer.getMemberTreeHeader(); writer.addSummaryHeader(this, typeElement, memberTree); return memberTree; @@ -118,11 +117,11 @@ public class ConstructorWriterImpl extends AbstractExecutableMemberWriter @Override public Content getConstructorDetailsTreeHeader(TypeElement typeElement, Content memberDetailsTree) { - memberDetailsTree.addContent(HtmlConstants.START_OF_CONSTRUCTOR_DETAILS); + memberDetailsTree.addContent(MarkerComments.START_OF_CONSTRUCTOR_DETAILS); Content constructorDetailsTree = writer.getMemberTreeHeader(); constructorDetailsTree.addContent(links.createAnchor( SectionName.CONSTRUCTOR_DETAIL)); - Content heading = HtmlTree.HEADING(HtmlConstants.DETAILS_HEADING, + Content heading = HtmlTree.HEADING(Headings.TypeDeclaration.DETAILS_HEADING, contents.constructorDetailsLabel); constructorDetailsTree.addContent(heading); return constructorDetailsTree; @@ -140,7 +139,7 @@ public class ConstructorWriterImpl extends AbstractExecutableMemberWriter } constructorDetailsTree.addContent(links.createAnchor(writer.getAnchor(constructor))); Content constructorDocTree = writer.getMemberTreeHeader(); - Content heading = new HtmlTree(HtmlConstants.MEMBER_HEADING); + Content heading = new HtmlTree(Headings.TypeDeclaration.MEMBER_HEADING); heading.addContent(name(constructor)); constructorDocTree.addContent(heading); return constructorDocTree; @@ -223,7 +222,7 @@ public class ConstructorWriterImpl extends AbstractExecutableMemberWriter */ @Override public void addSummaryLabel(Content memberTree) { - Content label = HtmlTree.HEADING(HtmlConstants.SUMMARY_HEADING, + Content label = HtmlTree.HEADING(Headings.TypeDeclaration.SUMMARY_HEADING, contents.constructorSummaryLabel); memberTree.addContent(label); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/DeprecatedListWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/DeprecatedListWriter.java index 14ad271c9b3..e951fcd3961 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/DeprecatedListWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/DeprecatedListWriter.java @@ -38,7 +38,6 @@ import javax.lang.model.element.PackageElement; import com.sun.source.doctree.DocTree; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -336,11 +335,11 @@ public class DeprecatedListWriter extends SubWriterHolderWriter { */ public Content getContentsList(DeprecatedAPIListBuilder deprapi) { Content headContent = contents.deprecatedAPI; - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, true, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.title, headContent); Content div = HtmlTree.DIV(HtmlStyle.header, heading); Content headingContent = contents.contentsHeading; - div.addContent(HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, true, + div.addContent(HtmlTree.HEADING(Headings.CONTENT_HEADING, true, headingContent)); Content ul = new HtmlTree(HtmlTag.UL); for (DeprElementKind kind : DeprElementKind.values()) { diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/EnumConstantWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/EnumConstantWriterImpl.java index 0993f81e512..2affe50e362 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/EnumConstantWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/EnumConstantWriterImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2019, 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 @@ -33,11 +33,9 @@ import javax.lang.model.element.Element; import javax.lang.model.element.TypeElement; import javax.lang.model.element.VariableElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; -import jdk.javadoc.internal.doclets.formats.html.markup.Navigation; import jdk.javadoc.internal.doclets.formats.html.markup.StringContent; import jdk.javadoc.internal.doclets.toolkit.Content; import jdk.javadoc.internal.doclets.toolkit.EnumConstantWriter; @@ -71,7 +69,7 @@ public class EnumConstantWriterImpl extends AbstractMemberWriter @Override public Content getMemberSummaryHeader(TypeElement typeElement, Content memberSummaryTree) { - memberSummaryTree.addContent(HtmlConstants.START_OF_ENUM_CONSTANT_SUMMARY); + memberSummaryTree.addContent(MarkerComments.START_OF_ENUM_CONSTANT_SUMMARY); Content memberTree = writer.getMemberTreeHeader(); writer.addSummaryHeader(this, typeElement, memberTree); return memberTree; @@ -91,11 +89,11 @@ public class EnumConstantWriterImpl extends AbstractMemberWriter @Override public Content getEnumConstantsDetailsTreeHeader(TypeElement typeElement, Content memberDetailsTree) { - memberDetailsTree.addContent(HtmlConstants.START_OF_ENUM_CONSTANT_DETAILS); + memberDetailsTree.addContent(MarkerComments.START_OF_ENUM_CONSTANT_DETAILS); Content enumConstantsDetailsTree = writer.getMemberTreeHeader(); enumConstantsDetailsTree.addContent(links.createAnchor( SectionName.ENUM_CONSTANT_DETAIL)); - Content heading = HtmlTree.HEADING(HtmlConstants.DETAILS_HEADING, + Content heading = HtmlTree.HEADING(Headings.TypeDeclaration.DETAILS_HEADING, contents.enumConstantDetailLabel); enumConstantsDetailsTree.addContent(heading); return enumConstantsDetailsTree; @@ -109,7 +107,7 @@ public class EnumConstantWriterImpl extends AbstractMemberWriter Content enumConstantsDetailsTree) { enumConstantsDetailsTree.addContent(links.createAnchor(name(enumConstant))); Content enumConstantsTree = writer.getMemberTreeHeader(); - Content heading = new HtmlTree(HtmlConstants.MEMBER_HEADING); + Content heading = new HtmlTree(Headings.TypeDeclaration.MEMBER_HEADING); heading.addContent(name(enumConstant)); enumConstantsTree.addContent(heading); return enumConstantsTree; @@ -182,7 +180,7 @@ public class EnumConstantWriterImpl extends AbstractMemberWriter */ @Override public void addSummaryLabel(Content memberTree) { - Content label = HtmlTree.HEADING(HtmlConstants.SUMMARY_HEADING, + Content label = HtmlTree.HEADING(Headings.TypeDeclaration.SUMMARY_HEADING, contents.enumConstantSummary); memberTree.addContent(label); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/FieldWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/FieldWriterImpl.java index 36f777c7854..c6e337d7f62 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/FieldWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/FieldWriterImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2019, 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 @@ -35,11 +35,9 @@ import javax.lang.model.element.Element; import javax.lang.model.element.TypeElement; import javax.lang.model.element.VariableElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; -import jdk.javadoc.internal.doclets.formats.html.markup.Navigation; import jdk.javadoc.internal.doclets.formats.html.markup.StringContent; import jdk.javadoc.internal.doclets.toolkit.Content; import jdk.javadoc.internal.doclets.toolkit.FieldWriter; @@ -75,7 +73,7 @@ public class FieldWriterImpl extends AbstractMemberWriter @Override public Content getMemberSummaryHeader(TypeElement typeElement, Content memberSummaryTree) { - memberSummaryTree.addContent(HtmlConstants.START_OF_FIELD_SUMMARY); + memberSummaryTree.addContent(MarkerComments.START_OF_FIELD_SUMMARY); Content memberTree = writer.getMemberTreeHeader(); writer.addSummaryHeader(this, typeElement, memberTree); return memberTree; @@ -94,11 +92,11 @@ public class FieldWriterImpl extends AbstractMemberWriter */ @Override public Content getFieldDetailsTreeHeader(TypeElement typeElement, Content memberDetailsTree) { - memberDetailsTree.addContent(HtmlConstants.START_OF_FIELD_DETAILS); + memberDetailsTree.addContent(MarkerComments.START_OF_FIELD_DETAILS); Content fieldDetailsTree = writer.getMemberTreeHeader(); fieldDetailsTree.addContent(links.createAnchor( SectionName.FIELD_DETAIL)); - Content heading = HtmlTree.HEADING(HtmlConstants.DETAILS_HEADING, + Content heading = HtmlTree.HEADING(Headings.TypeDeclaration.DETAILS_HEADING, contents.fieldDetailsLabel); fieldDetailsTree.addContent(heading); return fieldDetailsTree; @@ -111,7 +109,7 @@ public class FieldWriterImpl extends AbstractMemberWriter public Content getFieldDocTreeHeader(VariableElement field, Content fieldDetailsTree) { fieldDetailsTree.addContent(links.createAnchor(name(field))); Content fieldTree = writer.getMemberTreeHeader(); - Content heading = new HtmlTree(HtmlConstants.MEMBER_HEADING); + Content heading = new HtmlTree(Headings.TypeDeclaration.MEMBER_HEADING); heading.addContent(name(field)); fieldTree.addContent(heading); return fieldTree; @@ -186,7 +184,7 @@ public class FieldWriterImpl extends AbstractMemberWriter */ @Override public void addSummaryLabel(Content memberTree) { - Content label = HtmlTree.HEADING(HtmlConstants.SUMMARY_HEADING, + Content label = HtmlTree.HEADING(Headings.TypeDeclaration.SUMMARY_HEADING, contents.fieldSummaryLabel); memberTree.addContent(label); } @@ -247,7 +245,7 @@ public class FieldWriterImpl extends AbstractMemberWriter ? resources.getText("doclet.Fields_Inherited_From_Class") : resources.getText("doclet.Fields_Inherited_From_Interface")); } - Content labelHeading = HtmlTree.HEADING(HtmlConstants.INHERITED_SUMMARY_HEADING, + Content labelHeading = HtmlTree.HEADING(Headings.TypeDeclaration.INHERITED_SUMMARY_HEADING, label); labelHeading.addContent(Contents.SPACE); labelHeading.addContent(classLink); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/Headings.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/Headings.java new file mode 100644 index 00000000000..8190ca47b26 --- /dev/null +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/Headings.java @@ -0,0 +1,134 @@ +/* + * Copyright (c) 1998, 2019, 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 jdk.javadoc.internal.doclets.formats.html; + +import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; + +/** + * Aliases for HTML heading tags (H1..H6) for different kinds of pages. + * + *

This is NOT part of any supported API. + * If you write code that depends on this, you do so at your own risk. + * This code and its internal interfaces are subject to change or + * deletion without notice. + */ +class Headings { + /** + * Standard top-level heading for the page title for all pages. + */ + static final HtmlTag PAGE_TITLE_HEADING = HtmlTag.H1; + + /** + * Standard second-level heading for sundry pages that do + * not have their own page group. + */ + static final HtmlTag CONTENT_HEADING = HtmlTag.H2; + + /** + * Headings for the page for a module declaration. + */ + static class ModuleDeclaration { + static final HtmlTag SUMMARY_HEADING = HtmlTag.H2; + } + + /** + * Headings for the page for a type declaration. + * This includes classes, interfaces, enums and annotation types. + */ + static class TypeDeclaration { + /** + * Heading for the different summary lists: + * Field Summary, Constructor Summary, Method Summary, etc. + */ + static final HtmlTag SUMMARY_HEADING = HtmlTag.H2; + + /** + * Subheading within a summary for the inherited elements: + * inherited methods, etc + */ + static final HtmlTag INHERITED_SUMMARY_HEADING = HtmlTag.H3; + + /** + * Heading for the different detail lists: + * Field Details, Constructor Details, Method Details, etc. + */ + static final HtmlTag DETAILS_HEADING = HtmlTag.H2; + + /** + * Subheading with a Details list for an individual element. + */ + static final HtmlTag MEMBER_HEADING = HtmlTag.H3; + } + + /** + * Headings for the Constants Summary page. + */ + static class ConstantsSummary { + static final HtmlTag PACKAGE_HEADING = HtmlTag.H2; + } + + /** + * Headings for the Serialized Form page. + */ + static class SerializedForm { + /** + * Heading for the package name, preceding a list of types. + */ + static final HtmlTag PACKAGE_HEADING = HtmlTag.H2; + + /** + * Heading for a type name within a package. + */ + static final HtmlTag CLASS_HEADING = HtmlTag.H3; + + /** + * Subheading for info within a type. + */ + static final HtmlTag CLASS_SUBHEADING = HtmlTag.H4; + + /** + * Heading for an individual member element within a type. + */ + static final HtmlTag MEMBER_HEADING = HtmlTag.H5; + } + + /** + * Headings for a type Use page. + */ + static class TypeUse { + static final HtmlTag SUMMARY_HEADING = HtmlTag.H2; + } + + /** + * Headings for index frames pages. + */ + static class IndexFrames { + /** Heading for a list of module names in an index frame. */ + static final HtmlTag MODULE_HEADING = HtmlTag.H2; + /** Heading for a list of package names in an index frame. */ + static final HtmlTag PACKAGE_HEADING = HtmlTag.H2; + } +} diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HelpWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HelpWriter.java index 9ce70ff5d13..07c43f13540 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HelpWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HelpWriter.java @@ -25,7 +25,6 @@ package jdk.javadoc.internal.doclets.formats.html; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -113,7 +112,7 @@ public class HelpWriter extends HtmlDocletWriter { */ protected void addHelpFileContents(Content contentTree) { // Heading - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, false, HtmlStyle.title, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, false, HtmlStyle.title, contents.getContent("doclet.help.main_heading")); Content div = HtmlTree.DIV(HtmlStyle.header, heading); Content intro = HtmlTree.DIV(HtmlStyle.subTitle, @@ -126,7 +125,7 @@ public class HelpWriter extends HtmlDocletWriter { // Overview if (configuration.createoverview) { - Content overviewHeading = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content overviewHeading = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.overviewLabel); htmlTree = HtmlTree.SECTION(overviewHeading); String overviewKey = configuration.showModules @@ -143,7 +142,7 @@ public class HelpWriter extends HtmlDocletWriter { // Module if (configuration.showModules) { - Content moduleHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content moduleHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.moduleLabel); htmlTree = HtmlTree.SECTION(moduleHead); Content moduleIntro = contents.getContent("doclet.help.module.intro"); @@ -158,7 +157,7 @@ public class HelpWriter extends HtmlDocletWriter { } // Package - Content packageHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content packageHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.packageLabel); htmlTree = HtmlTree.SECTION(packageHead); Content packageIntro = contents.getContent("doclet.help.package.intro"); @@ -175,7 +174,7 @@ public class HelpWriter extends HtmlDocletWriter { ul.addContent(HtmlTree.LI(HtmlStyle.blockList, htmlTree)); // Class/interface - Content classHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content classHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.getContent("doclet.help.class_interface.head")); htmlTree = HtmlTree.SECTION(classHead); Content classIntro = contents.getContent("doclet.help.class_interface.intro"); @@ -210,7 +209,7 @@ public class HelpWriter extends HtmlDocletWriter { ul.addContent(HtmlTree.LI(HtmlStyle.blockList, htmlTree)); // Annotation Types - Content aHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content aHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.annotationType); htmlTree = HtmlTree.SECTION(aHead); Content aIntro = contents.getContent("doclet.help.annotation_type.intro"); @@ -226,7 +225,7 @@ public class HelpWriter extends HtmlDocletWriter { ul.addContent(HtmlTree.LI(HtmlStyle.blockList, htmlTree)); // Enums - Content enumHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, contents.enum_); + Content enumHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.enum_); htmlTree = HtmlTree.SECTION(enumHead); Content eIntro = contents.getContent("doclet.help.enum.intro"); Content enumPara = HtmlTree.P(eIntro); @@ -241,7 +240,7 @@ public class HelpWriter extends HtmlDocletWriter { // Class Use if (configuration.classuse) { - Content useHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content useHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.getContent("doclet.help.use.head")); htmlTree = HtmlTree.SECTION(useHead); Content useBody = contents.getContent("doclet.help.use.body"); @@ -252,7 +251,7 @@ public class HelpWriter extends HtmlDocletWriter { // Tree if (configuration.createtree) { - Content treeHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content treeHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.getContent("doclet.help.tree.head")); htmlTree = HtmlTree.SECTION(treeHead); Content treeIntro = contents.getContent("doclet.help.tree.intro", @@ -270,7 +269,7 @@ public class HelpWriter extends HtmlDocletWriter { // Deprecated if (!(configuration.nodeprecatedlist || configuration.nodeprecated)) { - Content dHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content dHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.deprecatedAPI); htmlTree = HtmlTree.SECTION(dHead); Content deprBody = contents.getContent("doclet.help.deprecated.body", @@ -291,7 +290,7 @@ public class HelpWriter extends HtmlDocletWriter { indexlink = links.createLink(DocPaths.INDEX_ALL, resources.getText("doclet.Index")); } - Content indexHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content indexHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.getContent("doclet.help.index.head")); htmlTree = HtmlTree.SECTION(indexHead); Content indexBody = contents.getContent("doclet.help.index.body", indexlink); @@ -302,7 +301,7 @@ public class HelpWriter extends HtmlDocletWriter { // Frames if (configuration.frames) { - Content frameHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content frameHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.getContent("doclet.help.frames.head")); htmlTree = HtmlTree.SECTION(frameHead); Content framesBody = contents.getContent("doclet.help.frames.body"); @@ -313,7 +312,7 @@ public class HelpWriter extends HtmlDocletWriter { } // Serialized Form - Content sHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content sHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.serializedForm); htmlTree = HtmlTree.SECTION(sHead); Content serialBody = contents.getContent("doclet.help.serial_form.body"); @@ -322,7 +321,7 @@ public class HelpWriter extends HtmlDocletWriter { ul.addContent(HtmlTree.LI(HtmlStyle.blockList, htmlTree)); // Constant Field Values - Content constHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content constHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.constantsSummaryTitle); htmlTree = HtmlTree.SECTION(constHead); Content constantsBody = contents.getContent("doclet.help.constants.body", @@ -333,7 +332,7 @@ public class HelpWriter extends HtmlDocletWriter { ul.addContent(HtmlTree.LI(HtmlStyle.blockList, htmlTree)); // Search - Content searchHead = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content searchHead = HtmlTree.HEADING(Headings.CONTENT_HEADING, contents.getContent("doclet.help.search.head")); htmlTree = HtmlTree.SECTION(searchHead); Content searchBody = contents.getContent("doclet.help.search.body"); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java index d034d99461d..c8ae3447213 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, 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 @@ -41,11 +41,9 @@ import com.sun.tools.doclint.DocLint; import jdk.javadoc.doclet.Doclet; import jdk.javadoc.doclet.DocletEnvironment; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlVersion; import jdk.javadoc.internal.doclets.toolkit.BaseConfiguration; -import jdk.javadoc.internal.doclets.toolkit.Content; import jdk.javadoc.internal.doclets.toolkit.DocletException; import jdk.javadoc.internal.doclets.toolkit.Messages; import jdk.javadoc.internal.doclets.toolkit.Resources; @@ -82,6 +80,11 @@ import static javax.tools.Diagnostic.Kind.*; */ public class HtmlConfiguration extends BaseConfiguration { + /** + * Default charset for HTML. + */ + public static final String HTML_DEFAULT_CHARSET = "utf-8"; + /** * Argument for command line option "-header". */ @@ -762,7 +765,7 @@ public class HtmlConfiguration extends BaseConfiguration { protected boolean finishOptionSettings0() throws DocletException { if (docencoding == null) { if (charset == null) { - docencoding = charset = (encoding == null) ? HtmlConstants.HTML_DEFAULT_CHARSET : encoding; + docencoding = charset = (encoding == null) ? HTML_DEFAULT_CHARSET : encoding; } else { docencoding = charset; } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlSerialFieldWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlSerialFieldWriter.java index 10688190640..65a320359c0 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlSerialFieldWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlSerialFieldWriter.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, 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 @@ -34,7 +34,6 @@ import javax.lang.model.type.TypeMirror; import com.sun.source.doctree.DocTree; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -108,8 +107,7 @@ public class HtmlSerialFieldWriter extends FieldWriterImpl li.setStyle(HtmlStyle.blockList); if (serializableFieldsTree.isValid()) { Content headingContent = new StringContent(heading); - Content serialHeading = HtmlTree.HEADING(HtmlConstants.SERIALIZED_MEMBER_HEADING, - headingContent); + Content serialHeading = HtmlTree.HEADING(Headings.SerializedForm.CLASS_SUBHEADING, headingContent); li.addContent(serialHeading); li.addContent(serializableFieldsTree); } @@ -120,7 +118,7 @@ public class HtmlSerialFieldWriter extends FieldWriterImpl public void addMemberHeader(TypeElement fieldType, String fieldTypeStr, String fieldDimensions, String fieldName, Content contentTree) { Content nameContent = new StringContent(fieldName); - Content heading = HtmlTree.HEADING(HtmlConstants.MEMBER_HEADING, nameContent); + Content heading = HtmlTree.HEADING(Headings.SerializedForm.MEMBER_HEADING, nameContent); contentTree.addContent(heading); Content pre = new HtmlTree(HtmlTag.PRE); if (fieldType == null) { @@ -138,7 +136,7 @@ public class HtmlSerialFieldWriter extends FieldWriterImpl @Override public void addMemberHeader(TypeMirror fieldType, String fieldName, Content contentTree) { Content nameContent = new StringContent(fieldName); - Content heading = HtmlTree.HEADING(HtmlConstants.MEMBER_HEADING, nameContent); + Content heading = HtmlTree.HEADING(HtmlTag.H5, nameContent); contentTree.addContent(heading); Content pre = new HtmlTree(HtmlTag.PRE); Content fieldContent = writer.getLink(new LinkInfoImpl( diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlSerialMethodWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlSerialMethodWriter.java index 070bb7f83bc..e16f853c6a4 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlSerialMethodWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlSerialMethodWriter.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1998, 2017, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1998, 2019, 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 @@ -29,7 +29,6 @@ import javax.lang.model.element.ExecutableElement; import javax.lang.model.element.TypeElement; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -95,8 +94,7 @@ public class HtmlSerialMethodWriter extends MethodWriterImpl implements */ public Content getSerializableMethods(String heading, Content serializableMethodContent) { Content headingContent = new StringContent(heading); - Content serialHeading = HtmlTree.HEADING(HtmlConstants.SERIALIZED_MEMBER_HEADING, - headingContent); + Content serialHeading = HtmlTree.HEADING(Headings.SerializedForm.CLASS_SUBHEADING, headingContent); Content li = HtmlTree.LI(HtmlStyle.blockList, serialHeading); li.addContent(serializableMethodContent); return li; @@ -120,7 +118,9 @@ public class HtmlSerialMethodWriter extends MethodWriterImpl implements * @param methodsContentTree the content tree to which the member header will be added */ public void addMemberHeader(ExecutableElement member, Content methodsContentTree) { - methodsContentTree.addContent(getHead(member)); + Content memberContent = new StringContent(name(member)); + Content heading = HtmlTree.HEADING(Headings.SerializedForm.MEMBER_HEADING, memberContent); + methodsContentTree.addContent(heading); methodsContentTree.addContent(getSignature(member)); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/HtmlConstants.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/MarkerComments.java similarity index 62% rename from src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/HtmlConstants.java rename to src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/MarkerComments.java index 32383d1b288..8131fc54ae6 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/HtmlConstants.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/MarkerComments.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2010, 2016, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2010, 2019, 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,12 +23,12 @@ * questions. */ -package jdk.javadoc.internal.doclets.formats.html.markup; +package jdk.javadoc.internal.doclets.formats.html; -import jdk.javadoc.internal.doclets.toolkit.Content; +import jdk.javadoc.internal.doclets.formats.html.markup.Comment; /** - * Stores constants for Html Doclet. + * Marker comments to identify regions in the generated files. * *

This is NOT part of any supported API. * If you write code that depends on this, you do so at your own risk. @@ -37,216 +37,162 @@ import jdk.javadoc.internal.doclets.toolkit.Content; * * @author Bhavesh Patel */ -public class HtmlConstants { +public class MarkerComments { /** * Marker to identify start of top navigation bar. */ - public static final Content START_OF_TOP_NAVBAR = + public static final Comment START_OF_TOP_NAVBAR = new Comment("========= START OF TOP NAVBAR ======="); /** * Marker to identify start of bottom navigation bar. */ - public static final Content START_OF_BOTTOM_NAVBAR = + public static final Comment START_OF_BOTTOM_NAVBAR = new Comment("======= START OF BOTTOM NAVBAR ======"); /** * Marker to identify end of top navigation bar. */ - public static final Content END_OF_TOP_NAVBAR = + public static final Comment END_OF_TOP_NAVBAR = new Comment("========= END OF TOP NAVBAR ========="); /** * Marker to identify end of bottom navigation bar. */ - public static final Content END_OF_BOTTOM_NAVBAR = + public static final Comment END_OF_BOTTOM_NAVBAR = new Comment("======== END OF BOTTOM NAVBAR ======="); /** * Marker to identify start of module description. */ - public static final Content START_OF_MODULE_DESCRIPTION = + public static final Comment START_OF_MODULE_DESCRIPTION = new Comment("============ MODULE DESCRIPTION ==========="); /** * Marker to identify start of modules summary. */ - public static final Content START_OF_MODULES_SUMMARY = + public static final Comment START_OF_MODULES_SUMMARY = new Comment("============ MODULES SUMMARY ==========="); /** * Marker to identify start of packages summary. */ - public static final Content START_OF_PACKAGES_SUMMARY = + public static final Comment START_OF_PACKAGES_SUMMARY = new Comment("============ PACKAGES SUMMARY ==========="); /** * Marker to identify start of services summary. */ - public static final Content START_OF_SERVICES_SUMMARY = + public static final Comment START_OF_SERVICES_SUMMARY = new Comment("============ SERVICES SUMMARY ==========="); /** * Marker to identify start of class data. */ - public static final Content START_OF_CLASS_DATA = + public static final Comment START_OF_CLASS_DATA = new Comment("======== START OF CLASS DATA ========"); /** * Marker to identify end of class data. */ - public static final Content END_OF_CLASS_DATA = + public static final Comment END_OF_CLASS_DATA = new Comment("========= END OF CLASS DATA ========="); /** * Marker to identify start of nested class summary. */ - public static final Content START_OF_NESTED_CLASS_SUMMARY = + public static final Comment START_OF_NESTED_CLASS_SUMMARY = new Comment("======== NESTED CLASS SUMMARY ========"); /** * Marker to identify start of annotation type optional member summary. */ - public static final Content START_OF_ANNOTATION_TYPE_OPTIONAL_MEMBER_SUMMARY = + public static final Comment START_OF_ANNOTATION_TYPE_OPTIONAL_MEMBER_SUMMARY = new Comment("=========== ANNOTATION TYPE OPTIONAL MEMBER SUMMARY ==========="); /** * Marker to identify start of annotation type required member summary. */ - public static final Content START_OF_ANNOTATION_TYPE_REQUIRED_MEMBER_SUMMARY = + public static final Comment START_OF_ANNOTATION_TYPE_REQUIRED_MEMBER_SUMMARY = new Comment("=========== ANNOTATION TYPE REQUIRED MEMBER SUMMARY ==========="); /** * Marker to identify start of annotation type required member summary. */ - public static final Content START_OF_ANNOTATION_TYPE_FIELD_SUMMARY = + public static final Comment START_OF_ANNOTATION_TYPE_FIELD_SUMMARY = new Comment("=========== ANNOTATION TYPE FIELD SUMMARY ==========="); /** * Marker to identify start of constructor summary. */ - public static final Content START_OF_CONSTRUCTOR_SUMMARY = + public static final Comment START_OF_CONSTRUCTOR_SUMMARY = new Comment("======== CONSTRUCTOR SUMMARY ========"); /** * Marker to identify start of enum constants summary. */ - public static final Content START_OF_ENUM_CONSTANT_SUMMARY = + public static final Comment START_OF_ENUM_CONSTANT_SUMMARY = new Comment("=========== ENUM CONSTANT SUMMARY ==========="); /** * Marker to identify start of field summary. */ - public static final Content START_OF_FIELD_SUMMARY = + public static final Comment START_OF_FIELD_SUMMARY = new Comment("=========== FIELD SUMMARY ==========="); /** * Marker to identify start of properties summary. */ - public static final Content START_OF_PROPERTY_SUMMARY = + public static final Comment START_OF_PROPERTY_SUMMARY = new Comment("=========== PROPERTY SUMMARY ==========="); /** * Marker to identify start of method summary. */ - public static final Content START_OF_METHOD_SUMMARY = + public static final Comment START_OF_METHOD_SUMMARY = new Comment("========== METHOD SUMMARY ==========="); /** * Marker to identify start of annotation type details. */ - public static final Content START_OF_ANNOTATION_TYPE_DETAILS = + public static final Comment START_OF_ANNOTATION_TYPE_DETAILS = new Comment("============ ANNOTATION TYPE MEMBER DETAIL ==========="); /** * Marker to identify start of annotation type field details. */ - public static final Content START_OF_ANNOTATION_TYPE_FIELD_DETAILS = + public static final Comment START_OF_ANNOTATION_TYPE_FIELD_DETAILS = new Comment("============ ANNOTATION TYPE FIELD DETAIL ==========="); /** * Marker to identify start of method details. */ - public static final Content START_OF_METHOD_DETAILS = + public static final Comment START_OF_METHOD_DETAILS = new Comment("============ METHOD DETAIL =========="); /** * Marker to identify start of field details. */ - public static final Content START_OF_FIELD_DETAILS = + public static final Comment START_OF_FIELD_DETAILS = new Comment("============ FIELD DETAIL ==========="); /** * Marker to identify start of property details. */ - public static final Content START_OF_PROPERTY_DETAILS = + public static final Comment START_OF_PROPERTY_DETAILS = new Comment("============ PROPERTY DETAIL ==========="); /** * Marker to identify start of constructor details. */ - public static final Content START_OF_CONSTRUCTOR_DETAILS = + public static final Comment START_OF_CONSTRUCTOR_DETAILS = new Comment("========= CONSTRUCTOR DETAIL ========"); /** * Marker to identify start of enum constants details. */ - public static final Content START_OF_ENUM_CONSTANT_DETAILS = + public static final Comment START_OF_ENUM_CONSTANT_DETAILS = new Comment("============ ENUM CONSTANT DETAIL ==========="); - /** - * Html tag for the page title heading. - */ - public static final HtmlTag TITLE_HEADING = HtmlTag.H1; - - /** - * Html tag for the class page title heading. - */ - public static final HtmlTag CLASS_PAGE_HEADING = HtmlTag.H2; - - /** - * Html tag for the content heading. - */ - public static final HtmlTag CONTENT_HEADING = HtmlTag.H2; - - /** - * Html tag for the package name heading. - */ - public static final HtmlTag PACKAGE_HEADING = HtmlTag.H2; - - /** - * Html tag for the module name heading. - */ - public static final HtmlTag MODULE_HEADING = HtmlTag.H2; - - /** - * Html tag for the member summary heading. - */ - public static final HtmlTag SUMMARY_HEADING = HtmlTag.H3; - - /** - * Html tag for the inherited member summary heading. - */ - public static final HtmlTag INHERITED_SUMMARY_HEADING = HtmlTag.H3; - - /** - * Html tag for the member details heading. - */ - public static final HtmlTag DETAILS_HEADING = HtmlTag.H3; - - /** - * Html tag for the serialized member heading. - */ - public static final HtmlTag SERIALIZED_MEMBER_HEADING = HtmlTag.H3; - - /** - * Html tag for the member heading. - */ - public static final HtmlTag MEMBER_HEADING = HtmlTag.H4; - - /** - * Default charset for HTML. - */ - public static final String HTML_DEFAULT_CHARSET = "utf-8"; } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/MethodWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/MethodWriterImpl.java index 34f24698463..5c3735bc6fb 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/MethodWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/MethodWriterImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2019, 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 @@ -36,7 +36,6 @@ import javax.lang.model.element.ExecutableElement; import javax.lang.model.element.TypeElement; import javax.lang.model.type.TypeMirror; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -87,7 +86,7 @@ public class MethodWriterImpl extends AbstractExecutableMemberWriter */ @Override public Content getMemberSummaryHeader(TypeElement typeElement, Content memberSummaryTree) { - memberSummaryTree.addContent(HtmlConstants.START_OF_METHOD_SUMMARY); + memberSummaryTree.addContent(MarkerComments.START_OF_METHOD_SUMMARY); Content memberTree = writer.getMemberTreeHeader(); writer.addSummaryHeader(this, typeElement, memberTree); return memberTree; @@ -106,10 +105,10 @@ public class MethodWriterImpl extends AbstractExecutableMemberWriter */ @Override public Content getMethodDetailsTreeHeader(TypeElement typeElement, Content memberDetailsTree) { - memberDetailsTree.addContent(HtmlConstants.START_OF_METHOD_DETAILS); + memberDetailsTree.addContent(MarkerComments.START_OF_METHOD_DETAILS); Content methodDetailsTree = writer.getMemberTreeHeader(); methodDetailsTree.addContent(links.createAnchor(SectionName.METHOD_DETAIL)); - Content heading = HtmlTree.HEADING(HtmlConstants.DETAILS_HEADING, + Content heading = HtmlTree.HEADING(Headings.TypeDeclaration.DETAILS_HEADING, contents.methodDetailLabel); methodDetailsTree.addContent(heading); return methodDetailsTree; @@ -126,7 +125,7 @@ public class MethodWriterImpl extends AbstractExecutableMemberWriter } methodDetailsTree.addContent(links.createAnchor(writer.getAnchor(method))); Content methodDocTree = writer.getMemberTreeHeader(); - Content heading = new HtmlTree(HtmlConstants.MEMBER_HEADING); + Content heading = new HtmlTree(Headings.TypeDeclaration.MEMBER_HEADING); heading.addContent(name(method)); methodDocTree.addContent(heading); return methodDocTree; @@ -229,7 +228,7 @@ public class MethodWriterImpl extends AbstractExecutableMemberWriter */ @Override public void addSummaryLabel(Content memberTree) { - Content label = HtmlTree.HEADING(HtmlConstants.SUMMARY_HEADING, + Content label = HtmlTree.HEADING(Headings.TypeDeclaration.SUMMARY_HEADING, contents.methodSummary); memberTree.addContent(label); } @@ -295,7 +294,7 @@ public class MethodWriterImpl extends AbstractExecutableMemberWriter ? resources.getText("doclet.Methods_Inherited_From_Class") : resources.getText("doclet.Methods_Inherited_From_Interface")); } - Content labelHeading = HtmlTree.HEADING(HtmlConstants.INHERITED_SUMMARY_HEADING, + Content labelHeading = HtmlTree.HEADING(Headings.TypeDeclaration.INHERITED_SUMMARY_HEADING, label); labelHeading.addContent(Contents.SPACE); labelHeading.addContent(classLink); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleFrameWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleFrameWriter.java index bc6cb06bea1..1e328498978 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleFrameWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleFrameWriter.java @@ -32,7 +32,6 @@ import javax.lang.model.element.PackageElement; import javax.lang.model.element.TypeElement; import javax.lang.model.util.ElementFilter; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -101,7 +100,7 @@ public class ModuleFrameWriter extends HtmlDocletWriter { DocPath moduleSummary = configuration.useModuleDirectories ? DocPaths.DOT_DOT.resolve(configuration.docPaths.moduleSummary(moduleElement)) : configuration.docPaths.moduleSummary(moduleElement); - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, HtmlStyle.bar, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, HtmlStyle.bar, mdlgen.links.createLink(moduleSummary, mdlLabel, "", "classFrame")); htmlTree.addContent(heading); HtmlTree div = new HtmlTree(HtmlTag.DIV); @@ -172,7 +171,7 @@ public class ModuleFrameWriter extends HtmlDocletWriter { continue; } if (!printedHeader) { - Content heading = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content heading = HtmlTree.HEADING(Headings.CONTENT_HEADING, true, labelContent); htmlTree.addContent(heading); printedHeader = true; diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleIndexFrameWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleIndexFrameWriter.java index f096330fd4a..bcc04b7bcf2 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleIndexFrameWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleIndexFrameWriter.java @@ -32,7 +32,6 @@ import javax.lang.model.element.ModuleElement; import javax.lang.model.element.PackageElement; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlAttr; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -57,6 +56,12 @@ import jdk.javadoc.internal.doclets.toolkit.util.DocPaths; * @author Bhavesh Patel */ public class ModuleIndexFrameWriter extends AbstractModuleIndexWriter { + /** + * The heading (h1 or h2) to use for the module list, + * set by addNavigationBarHeader depending on whether or not there + * is an additional initial heading. + */ + private HtmlTag moduleListHeading; /** * Construct the ModuleIndexFrameWriter object. @@ -83,8 +88,9 @@ public class ModuleIndexFrameWriter extends AbstractModuleIndexWriter { /** * {@inheritDoc} */ + @Override protected void addModulesList(Content main) { - Content heading = HtmlTree.HEADING(HtmlConstants.MODULE_HEADING, true, + Content heading = HtmlTree.HEADING(moduleListHeading, true, contents.modulesLabel); HtmlTree htmlTree = HtmlTree.DIV(HtmlStyle.indexContainer, heading); HtmlTree ul = new HtmlTree(HtmlTag.UL); @@ -125,15 +131,16 @@ public class ModuleIndexFrameWriter extends AbstractModuleIndexWriter { * {@inheritDoc} */ protected void addNavigationBarHeader(Content header) { - Content headerContent; - if (configuration.packagesheader.length() > 0) { - headerContent = new RawHtml(replaceDocRootDir(configuration.packagesheader)); + String headerContent = !configuration.packagesheader.isEmpty() ? configuration.packagesheader + : configuration.header; + if (!headerContent.isEmpty()) { + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, + HtmlStyle.bar, new RawHtml(replaceDocRootDir(headerContent))); + header.addContent(heading); + moduleListHeading = Headings.IndexFrames.MODULE_HEADING; } else { - headerContent = new RawHtml(replaceDocRootDir(configuration.header)); + moduleListHeading = Headings.PAGE_TITLE_HEADING; } - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, true, - HtmlStyle.bar, headerContent); - header.addContent(heading); } /** diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModulePackageIndexFrameWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModulePackageIndexFrameWriter.java index be5eb67c346..23de9557290 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModulePackageIndexFrameWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModulePackageIndexFrameWriter.java @@ -33,7 +33,6 @@ import java.util.Set; import javax.lang.model.element.ModuleElement; import javax.lang.model.element.PackageElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -57,6 +56,12 @@ import jdk.javadoc.internal.doclets.toolkit.util.DocPaths; * @author Bhavesh Patel */ public class ModulePackageIndexFrameWriter extends AbstractModuleIndexWriter { + /** + * The heading (h1 or h2) to use for the module packages list, + * set by addNavigationBarHeader depending on whether or not there + * is an additional initial heading. + */ + private HtmlTag modulePackagesListHeading; /** * Construct the ModulePackageIndexFrameWriter object. @@ -89,7 +94,7 @@ public class ModulePackageIndexFrameWriter extends AbstractModuleIndexWriter { protected void addModulePackagesList(Map> modules, String text, String tableSummary, Content main, ModuleElement mdle) { Content profNameContent = new StringContent(mdle.getQualifiedName().toString()); - Content heading = HtmlTree.HEADING(HtmlConstants.PACKAGE_HEADING, true, + Content heading = HtmlTree.HEADING(modulePackagesListHeading, true, getTargetModuleLink("classFrame", profNameContent, mdle)); heading.addContent(Contents.SPACE); heading.addContent(contents.packagesLabel); @@ -112,7 +117,7 @@ public class ModulePackageIndexFrameWriter extends AbstractModuleIndexWriter { protected void addModulePackagesList(Set modules, String text, String tableSummary, Content body, ModuleElement mdle) { Content moduleNameContent = new StringContent(mdle.getQualifiedName().toString()); - Content heading = HtmlTree.HEADING(HtmlConstants.PACKAGE_HEADING, true, + Content heading = HtmlTree.HEADING(modulePackagesListHeading, true, getTargetModuleLink("classFrame", moduleNameContent, mdle)); heading.addContent(Contents.SPACE); heading.addContent(contents.packagesLabel); @@ -157,15 +162,16 @@ public class ModulePackageIndexFrameWriter extends AbstractModuleIndexWriter { * {@inheritDoc} */ protected void addNavigationBarHeader(Content header) { - Content headerContent; - if (configuration.packagesheader.length() > 0) { - headerContent = new RawHtml(replaceDocRootDir(configuration.packagesheader)); + String headerContent = !configuration.packagesheader.isEmpty() ? configuration.packagesheader + : configuration.header; + if (!headerContent.isEmpty()) { + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, + HtmlStyle.bar, new RawHtml(replaceDocRootDir(headerContent))); + header.addContent(heading); + modulePackagesListHeading = Headings.IndexFrames.PACKAGE_HEADING; } else { - headerContent = new RawHtml(replaceDocRootDir(configuration.header)); + modulePackagesListHeading = Headings.PAGE_TITLE_HEADING; } - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, true, - HtmlStyle.bar, headerContent); - header.addContent(heading); } /** @@ -177,6 +183,7 @@ public class ModulePackageIndexFrameWriter extends AbstractModuleIndexWriter { /** * Do nothing as there is no modules list on this page. */ + @Override protected void addModulesList(Content body) { } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleWriterImpl.java index 9f5e8a4e083..1098e3f1891 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleWriterImpl.java @@ -46,7 +46,6 @@ import javax.lang.model.util.ElementFilter; import com.sun.source.doctree.DocTree; import jdk.javadoc.doclet.DocletEnvironment.ModuleMode; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -213,7 +212,7 @@ public class ModuleWriterImpl extends HtmlDocletWriter implements ModuleSummaryW div.addContent(annotationContent); Content label = mdle.isOpen() && (configuration.docEnv.getModuleMode() == ModuleMode.ALL) ? contents.openModuleLabel : contents.moduleLabel; - Content tHeading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, true, + Content tHeading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.title, label); tHeading.addContent(Contents.SPACE); Content moduleHead = new RawHtml(heading); @@ -461,7 +460,7 @@ public class ModuleWriterImpl extends HtmlDocletWriter implements ModuleSummaryW Content htmltree) { htmltree.addContent(startMarker); htmltree.addContent(links.createAnchor(markerAnchor)); - htmltree.addContent(HtmlTree.HEADING(HtmlTag.H3, heading)); + htmltree.addContent(HtmlTree.HEADING(Headings.ModuleDeclaration.SUMMARY_HEADING, heading)); } /** @@ -509,7 +508,7 @@ public class ModuleWriterImpl extends HtmlDocletWriter implements ModuleSummaryW contents.descriptionLabel); HtmlTree li = new HtmlTree(HtmlTag.LI); li.setStyle(HtmlStyle.blockList); - addSummaryHeader(HtmlConstants.START_OF_MODULES_SUMMARY, SectionName.MODULES, + addSummaryHeader(MarkerComments.START_OF_MODULES_SUMMARY, SectionName.MODULES, contents.navModules, li); if (display(requires)) { String text = resources.getText("doclet.Requires_Summary"); @@ -561,7 +560,7 @@ public class ModuleWriterImpl extends HtmlDocletWriter implements ModuleSummaryW || display(indirectPackages) || display(indirectOpenPackages)) { HtmlTree li = new HtmlTree(HtmlTag.LI); li.setStyle(HtmlStyle.blockList); - addSummaryHeader(HtmlConstants.START_OF_PACKAGES_SUMMARY, SectionName.PACKAGES, + addSummaryHeader(MarkerComments.START_OF_PACKAGES_SUMMARY, SectionName.PACKAGES, contents.navPackages, li); if (display(packages)) { addPackageSummary(li); @@ -740,7 +739,7 @@ public class ModuleWriterImpl extends HtmlDocletWriter implements ModuleSummaryW if (haveProvides || haveUses) { HtmlTree li = new HtmlTree(HtmlTag.LI); li.setStyle(HtmlStyle.blockList); - addSummaryHeader(HtmlConstants.START_OF_SERVICES_SUMMARY, SectionName.SERVICES, + addSummaryHeader(MarkerComments.START_OF_SERVICES_SUMMARY, SectionName.SERVICES, contents.navServices, li); TableHeader usesProvidesTableHeader = new TableHeader(contents.typeLabel, contents.descriptionLabel); @@ -869,7 +868,7 @@ public class ModuleWriterImpl extends HtmlDocletWriter implements ModuleSummaryW if (!utils.getFullBody(mdle).isEmpty()) { Content tree = HtmlTree.SECTION(); addDeprecationInfo(tree); - tree.addContent(HtmlConstants.START_OF_MODULE_DESCRIPTION); + tree.addContent(MarkerComments.START_OF_MODULE_DESCRIPTION); tree.addContent(links.createAnchor(SectionName.MODULE_DESCRIPTION)); addInlineComment(mdle, tree); moduleContentTree.addContent(tree); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/NestedClassWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/NestedClassWriterImpl.java index 3eab7599a49..bbb0fa15a7d 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/NestedClassWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/NestedClassWriterImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2019, 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 @@ -34,10 +34,8 @@ import java.util.List; import javax.lang.model.element.Element; import javax.lang.model.element.TypeElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; -import jdk.javadoc.internal.doclets.formats.html.markup.Navigation; import jdk.javadoc.internal.doclets.formats.html.markup.StringContent; import jdk.javadoc.internal.doclets.toolkit.Content; import jdk.javadoc.internal.doclets.toolkit.MemberSummaryWriter; @@ -72,7 +70,7 @@ public class NestedClassWriterImpl extends AbstractMemberWriter @Override public Content getMemberSummaryHeader(TypeElement typeElement, Content memberSummaryTree) { - memberSummaryTree.addContent(HtmlConstants.START_OF_NESTED_CLASS_SUMMARY); + memberSummaryTree.addContent(MarkerComments.START_OF_NESTED_CLASS_SUMMARY); Content memberTree = writer.getMemberTreeHeader(); writer.addSummaryHeader(this, typeElement, memberTree); return memberTree; @@ -91,7 +89,7 @@ public class NestedClassWriterImpl extends AbstractMemberWriter */ @Override public void addSummaryLabel(Content memberTree) { - Content label = HtmlTree.HEADING(HtmlConstants.SUMMARY_HEADING, + Content label = HtmlTree.HEADING(Headings.TypeDeclaration.SUMMARY_HEADING, contents.nestedClassSummary); memberTree.addContent(label); } @@ -155,8 +153,7 @@ public class NestedClassWriterImpl extends AbstractMemberWriter ? resources.getText("doclet.Nested_Classes_Interfaces_Inherited_From_Interface") : resources.getText("doclet.Nested_Classes_Interfaces_Inherited_From_Class")); } - Content labelHeading = HtmlTree.HEADING(HtmlConstants.INHERITED_SUMMARY_HEADING, - label); + Content labelHeading = HtmlTree.HEADING(Headings.TypeDeclaration.SUMMARY_HEADING, label); labelHeading.addContent(Contents.SPACE); labelHeading.addContent(classLink); inheritedTree.addContent(labelHeading); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageFrameWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageFrameWriter.java index ac1269a70c7..7a0857b9fab 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageFrameWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageFrameWriter.java @@ -30,7 +30,6 @@ import java.util.*; import javax.lang.model.element.PackageElement; import javax.lang.model.element.TypeElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -102,7 +101,7 @@ public class PackageFrameWriter extends HtmlDocletWriter { HtmlTree body = packgen.getBody(false, packgen.getWindowTitle(pkgName)); Content pkgNameContent = new StringContent(pkgName); HtmlTree htmlTree = HtmlTree.MAIN(); - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, HtmlStyle.bar, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, HtmlStyle.bar, packgen.getTargetPackageLink(packageElement, "classFrame", pkgNameContent)); htmlTree.addContent(heading); HtmlTree div = new HtmlTree(HtmlTag.DIV); @@ -178,7 +177,7 @@ public class PackageFrameWriter extends HtmlDocletWriter { continue; } if (!printedHeader) { - Content heading = HtmlTree.HEADING(HtmlConstants.CONTENT_HEADING, + Content heading = HtmlTree.HEADING(Headings.CONTENT_HEADING, true, labelContent); htmlTree.addContent(heading); printedHeader = true; diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageIndexFrameWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageIndexFrameWriter.java index ecbf34fd4e3..6860d4d4cf9 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageIndexFrameWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageIndexFrameWriter.java @@ -27,7 +27,6 @@ package jdk.javadoc.internal.doclets.formats.html; import javax.lang.model.element.PackageElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -79,7 +78,7 @@ public class PackageIndexFrameWriter extends AbstractPackageIndexWriter { */ @Override protected void addPackagesList(Content main) { - Content heading = HtmlTree.HEADING(HtmlConstants.PACKAGE_HEADING, true, + Content heading = HtmlTree.HEADING(Headings.IndexFrames.PACKAGE_HEADING, true, contents.packagesLabel); HtmlTree htmlTree = HtmlTree.DIV(HtmlStyle.indexContainer, heading); HtmlTree ul = new HtmlTree(HtmlTag.UL); @@ -130,7 +129,7 @@ public class PackageIndexFrameWriter extends AbstractPackageIndexWriter { } else { headerContent = new RawHtml(replaceDocRootDir(configuration.header)); } - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, true, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.bar, headerContent); header.addContent(heading); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageTreeWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageTreeWriter.java index 359a8bb953a..98de33e8acb 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageTreeWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageTreeWriter.java @@ -27,7 +27,6 @@ package jdk.javadoc.internal.doclets.formats.html; import javax.lang.model.element.PackageElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -101,7 +100,7 @@ public class PackageTreeWriter extends AbstractTreeWriter { HtmlTree mainTree = HtmlTree.MAIN(); Content headContent = contents.getContent("doclet.Hierarchy_For_Package", utils.getPackageName(packageElement)); - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, false, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, false, HtmlStyle.title, headContent); Content div = HtmlTree.DIV(HtmlStyle.header, heading); if (configuration.packages.size() > 1) { diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageUseWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageUseWriter.java index 6bdb9472fc2..a0f17d28277 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageUseWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageUseWriter.java @@ -34,7 +34,6 @@ import javax.lang.model.element.PackageElement; import javax.lang.model.element.TypeElement; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -252,7 +251,7 @@ public class PackageUseWriter extends SubWriterHolderWriter { headContent.addContent(contents.getContent("doclet.ClassUse_Title", packageText)); headContent.addContent(new HtmlTree(HtmlTag.BR)); headContent.addContent(name); - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, true, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.title, headContent); Content div = HtmlTree.DIV(HtmlStyle.header, heading); mainTree.addContent(div); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageWriterImpl.java index bcf2aebdfc5..2a85edae038 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PackageWriterImpl.java @@ -36,7 +36,6 @@ import javax.lang.model.element.TypeElement; import com.sun.source.doctree.DocTree; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -129,7 +128,7 @@ public class PackageWriterImpl extends HtmlDocletWriter Content annotationContent = new HtmlTree(HtmlTag.P); addAnnotationInfo(packageElement, annotationContent); div.addContent(annotationContent); - Content tHeading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, true, + Content tHeading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.title, contents.packageLabel); tHeading.addContent(Contents.SPACE); Content packageHead = new StringContent(heading); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PropertyWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PropertyWriterImpl.java index d34be75791e..9a256f8763e 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PropertyWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/PropertyWriterImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1997, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1997, 2019, 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 @@ -33,7 +33,6 @@ import javax.lang.model.element.Element; import javax.lang.model.element.ExecutableElement; import javax.lang.model.element.TypeElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -68,7 +67,7 @@ public class PropertyWriterImpl extends AbstractMemberWriter */ @Override public Content getMemberSummaryHeader(TypeElement typeElement, Content memberSummaryTree) { - memberSummaryTree.addContent(HtmlConstants.START_OF_PROPERTY_SUMMARY); + memberSummaryTree.addContent(MarkerComments.START_OF_PROPERTY_SUMMARY); Content memberTree = writer.getMemberTreeHeader(); writer.addSummaryHeader(this, typeElement, memberTree); return memberTree; @@ -88,10 +87,10 @@ public class PropertyWriterImpl extends AbstractMemberWriter @Override public Content getPropertyDetailsTreeHeader(TypeElement typeElement, Content memberDetailsTree) { - memberDetailsTree.addContent(HtmlConstants.START_OF_PROPERTY_DETAILS); + memberDetailsTree.addContent(MarkerComments.START_OF_PROPERTY_DETAILS); Content propertyDetailsTree = writer.getMemberTreeHeader(); propertyDetailsTree.addContent(links.createAnchor(SectionName.PROPERTY_DETAIL)); - Content heading = HtmlTree.HEADING(HtmlConstants.DETAILS_HEADING, + Content heading = HtmlTree.HEADING(Headings.TypeDeclaration.DETAILS_HEADING, contents.propertyDetailsLabel); propertyDetailsTree.addContent(heading); return propertyDetailsTree; @@ -105,7 +104,7 @@ public class PropertyWriterImpl extends AbstractMemberWriter Content propertyDetailsTree) { propertyDetailsTree.addContent(links.createAnchor(name(property))); Content propertyDocTree = writer.getMemberTreeHeader(); - Content heading = new HtmlTree(HtmlConstants.MEMBER_HEADING); + Content heading = new HtmlTree(Headings.TypeDeclaration.MEMBER_HEADING); heading.addContent(utils.getPropertyLabel(name(property))); propertyDocTree.addContent(heading); return propertyDocTree; @@ -200,7 +199,7 @@ public class PropertyWriterImpl extends AbstractMemberWriter */ @Override public void addSummaryLabel(Content memberTree) { - Content label = HtmlTree.HEADING(HtmlConstants.SUMMARY_HEADING, + Content label = HtmlTree.HEADING(Headings.TypeDeclaration.SUMMARY_HEADING, contents.propertySummaryLabel); memberTree.addContent(label); } @@ -261,7 +260,7 @@ public class PropertyWriterImpl extends AbstractMemberWriter ? resources.getText("doclet.Properties_Inherited_From_Class") : resources.getText("doclet.Properties_Inherited_From_Interface")); } - Content labelHeading = HtmlTree.HEADING(HtmlConstants.INHERITED_SUMMARY_HEADING, + Content labelHeading = HtmlTree.HEADING(Headings.TypeDeclaration.INHERITED_SUMMARY_HEADING, label); labelHeading.addContent(Contents.SPACE); labelHeading.addContent(classLink); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SerializedFormWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SerializedFormWriterImpl.java index b11367ef32f..986e3618c3a 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SerializedFormWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SerializedFormWriterImpl.java @@ -29,7 +29,6 @@ import java.util.*; import javax.lang.model.element.TypeElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -42,7 +41,7 @@ import jdk.javadoc.internal.doclets.toolkit.util.DocFileIOException; import jdk.javadoc.internal.doclets.toolkit.util.DocPaths; /** - * Generate the Serialized Form Information Page. + * Generates the Serialized Form Information Page, serialized-form.html. * *

This is NOT part of any supported API. * If you write code that depends on this, you do so at your own risk. @@ -86,7 +85,7 @@ public class SerializedFormWriterImpl extends SubWriterHolderWriter htmlTree.addContent(navBar.getContent(true)); bodyTree.addContent(htmlTree); Content h1Content = new StringContent(header); - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, true, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, true, HtmlStyle.title, h1Content); Content div = HtmlTree.DIV(HtmlStyle.header, heading); mainTree.addContent(div); @@ -120,7 +119,7 @@ public class SerializedFormWriterImpl extends SubWriterHolderWriter * @return a content tree for the package header */ public Content getPackageHeader(String packageName) { - Content heading = HtmlTree.HEADING(HtmlConstants.PACKAGE_HEADING, true, + Content heading = HtmlTree.HEADING(Headings.SerializedForm.PACKAGE_HEADING, true, contents.packageLabel); heading.addContent(Contents.SPACE); heading.addContent(packageName); @@ -173,8 +172,7 @@ public class SerializedFormWriterImpl extends SubWriterHolderWriter contents.getContent( "doclet.Class_0_extends_implements_serializable", classLink, superClassLink); - li.addContent(HtmlTree.HEADING(HtmlConstants.SERIALIZED_MEMBER_HEADING, - className)); + li.addContent(HtmlTree.HEADING(Headings.SerializedForm.CLASS_HEADING, className)); return li; } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/TreeWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/TreeWriter.java index b5d3b026e38..50b27b73b2d 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/TreeWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/TreeWriter.java @@ -29,7 +29,6 @@ import java.util.SortedSet; import javax.lang.model.element.PackageElement; -import jdk.javadoc.internal.doclets.formats.html.markup.HtmlConstants; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTag; import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree; @@ -108,7 +107,7 @@ public class TreeWriter extends AbstractTreeWriter { public void generateTreeFile() throws DocFileIOException { HtmlTree body = getTreeHeader(); Content headContent = contents.hierarchyForAllPackages; - Content heading = HtmlTree.HEADING(HtmlConstants.TITLE_HEADING, false, + Content heading = HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, false, HtmlStyle.title, headContent); Content div = HtmlTree.DIV(HtmlStyle.header, heading); addPackageTreeLinks(div); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Navigation.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Navigation.java index 56a2e16c446..f2139dfd1ad 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Navigation.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Navigation.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2019, 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 @@ -42,6 +42,7 @@ import javax.lang.model.element.TypeElement; import jdk.javadoc.internal.doclets.formats.html.AbstractMemberWriter; import jdk.javadoc.internal.doclets.formats.html.Contents; import jdk.javadoc.internal.doclets.formats.html.HtmlConfiguration; +import jdk.javadoc.internal.doclets.formats.html.MarkerComments; import jdk.javadoc.internal.doclets.formats.html.SectionName; import jdk.javadoc.internal.doclets.toolkit.Content; import jdk.javadoc.internal.doclets.toolkit.builders.MemberSummaryBuilder; @@ -106,8 +107,8 @@ public class Navigation { } enum Position { - BOTTOM(HtmlConstants.START_OF_BOTTOM_NAVBAR, HtmlConstants.END_OF_BOTTOM_NAVBAR), - TOP(HtmlConstants.START_OF_TOP_NAVBAR, HtmlConstants.END_OF_TOP_NAVBAR); + BOTTOM(MarkerComments.START_OF_BOTTOM_NAVBAR, MarkerComments.END_OF_BOTTOM_NAVBAR), + TOP(MarkerComments.START_OF_TOP_NAVBAR, MarkerComments.END_OF_TOP_NAVBAR); final Content startOfNav; final Content endOfNav; diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/SerializedFormBuilder.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/SerializedFormBuilder.java index 96f1d1d2aeb..ecaa514939c 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/SerializedFormBuilder.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/SerializedFormBuilder.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2019, 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 @@ -304,8 +304,8 @@ public class SerializedFormBuilder extends AbstractBuilder { Content noCustomizationMsg = methodWriter.getNoCustomizationMsg( resources.getText("doclet.Serializable_no_customization")); classContentTree.addContent(methodWriter.getSerializableMethods( - resources.getText("doclet.Serialized_Form_methods"), - noCustomizationMsg)); + resources.getText("doclet.Serialized_Form_methods"), + noCustomizationMsg)); } } } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/resources/stylesheet.css b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/resources/stylesheet.css index e46e2825f36..287dde6433d 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/resources/stylesheet.css +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/resources/stylesheet.css @@ -296,25 +296,32 @@ ul.subNavList li { /* * Styles for headings. */ -div.details ul.blockList ul.blockList ul.blockList li.blockList h4, div.details ul.blockList ul.blockList ul.blockListLast li.blockList h4 { +div.details ul.blockList ul.blockList ul.blockList li.blockList h3, +div.details ul.blockList ul.blockList ul.blockListLast li.blockList h3, +div.serializedFormContainer ul.blockList ul.blockList ul.blockList li.blockList h4 { background-color:#dee3e9; border:1px solid #d0d9e0; margin:0 0 6px -8px; padding:7px 5px; } -ul.blockList ul.blockList ul.blockList li.blockList h3 { +div.details h2, +div.summary h2 { + font-style: italic; +} +div.details h3, +div.summary h3 { + font-style: normal; +} +ul.blockList ul.blockList ul.blockList li.blockList h2 { background-color:#dee3e9; border:1px solid #d0d9e0; margin:0 0 6px -8px; padding:7px 5px; } -ul.blockList ul.blockList li.blockList h3 { +ul.blockList ul.blockList li.blockList h2 { padding:0; margin:15px 0; } -ul.blockList li.blockList h2 { - padding:0px 0 20px 0; -} /* * Styles for page layout containers. */ @@ -597,7 +604,8 @@ th.colDeprecatedItemName a:link, th.colDeprecatedItemName a:visited, .docSummary { padding:0; } -ul.blockList ul.blockList ul.blockList li.blockList h3 { +ul.blockList ul.blockList ul.blockList li.blockList h3, +ul.blockList ul.blockList ul.blockListLast li.blockList h3 { font-style:normal; } div.block { diff --git a/test/langtools/jdk/javadoc/doclet/testAnnotationTypes/TestAnnotationTypes.java b/test/langtools/jdk/javadoc/doclet/testAnnotationTypes/TestAnnotationTypes.java index d9af68abce3..3664f73395f 100644 --- a/test/langtools/jdk/javadoc/doclet/testAnnotationTypes/TestAnnotationTypes.java +++ b/test/langtools/jdk/javadoc/doclet/testAnnotationTypes/TestAnnotationTypes.java @@ -57,11 +57,11 @@ public class TestAnnotationTypes extends JavadocTester { + "

  • Field | 
  • ", "", - "

    Field Summary

    ", + "

    Field Summary

    ", "DEFAULT_NAME" + "", "", - "

    DEFAULT_NAME

    \n" + "

    DEFAULT_NAME

    \n" + "
    static final java."
                     + "lang.String DEFAULT_NAME
    "); @@ -77,13 +77,13 @@ public class TestAnnotationTypes extends JavadocTester { "
  • ", "", "", - "

    Element Detail

    ", + "

    Element Detail

    ", "", "", "", "
      ", "
    • ", - "

      value

      ", + "

      value

      ", "
      int value
      " ); checkOutput("pkg/AnnotationType.html", false, diff --git a/test/langtools/jdk/javadoc/doclet/testHeadings/TestHeadings.java b/test/langtools/jdk/javadoc/doclet/testHeadings/TestHeadings.java index 1336f1b6afd..0d301c86e0e 100644 --- a/test/langtools/jdk/javadoc/doclet/testHeadings/TestHeadings.java +++ b/test/langtools/jdk/javadoc/doclet/testHeadings/TestHeadings.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2019, 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 @@ -37,23 +37,6 @@ import javadoc.tester.JavadocTester; public class TestHeadings extends JavadocTester { - private static final String[][] TEST = { - - { - }, - { "serialized-form.html" - }, - { "serialized-form.html" - }, - - { - }, - { "overview-frame.html" - }, - { - } - }; - public static void main(String... args) throws Exception { TestHeadings tester = new TestHeadings(); tester.runTests(); @@ -108,7 +91,7 @@ public class TestHeadings extends JavadocTester { "

      Package pkg1

      ", "

      Class " + "pkg1.C1 extends java.lang.Object implements Serializable

      ", - "

      Serialized Fields

      "); + "

      Serialized Fields

      "); // Overview Frame checkOutput("overview-frame.html", true, diff --git a/test/langtools/jdk/javadoc/doclet/testHiddenTag/TestHiddenTag.java b/test/langtools/jdk/javadoc/doclet/testHiddenTag/TestHiddenTag.java index e968a156d5d..846736046e4 100644 --- a/test/langtools/jdk/javadoc/doclet/testHiddenTag/TestHiddenTag.java +++ b/test/langtools/jdk/javadoc/doclet/testHiddenTag/TestHiddenTag.java @@ -67,8 +67,8 @@ public class TestHiddenTag extends JavadocTester { checkOutput("pkg1/A.VisibleInner.html", true, "visibleField", "visibleMethod", - "

      Nested classes/interfaces inherited from class pkg1." + - "A

      \n" + + "

      Nested classes/interfaces inherited from class pkg1." + + "A

      \n" + "" + "A.VisibleInner, A.VisibleInnerExtendsInvisibleInner
    • \n" + diff --git a/test/langtools/jdk/javadoc/doclet/testHref/TestHref.java b/test/langtools/jdk/javadoc/doclet/testHref/TestHref.java index 7bf5eeb18a3..506bf946773 100644 --- a/test/langtools/jdk/javadoc/doclet/testHref/TestHref.java +++ b/test/langtools/jdk/javadoc/doclet/testHref/TestHref.java @@ -75,7 +75,7 @@ public class TestHref extends JavadocTester { checkOutput("pkg/C4.html", true, //Header does not link to the page itself. - "Class C4<E extends C4<E>>
  • ", + "Class C4<E extends C4<E>>", //Signature does not link to the page itself. "public abstract class C4<E extends C4<E>>" ); diff --git a/test/langtools/jdk/javadoc/doclet/testHtmlLandmarkRegions/TestHtmlLandmarkRegions.java b/test/langtools/jdk/javadoc/doclet/testHtmlLandmarkRegions/TestHtmlLandmarkRegions.java index 882976201d4..d18687a1616 100644 --- a/test/langtools/jdk/javadoc/doclet/testHtmlLandmarkRegions/TestHtmlLandmarkRegions.java +++ b/test/langtools/jdk/javadoc/doclet/testHtmlLandmarkRegions/TestHtmlLandmarkRegions.java @@ -109,7 +109,7 @@ public class TestHtmlLandmarkRegions extends JavadocTester { Path srcDir = base.resolve("src"); createPackages(srcDir); - Path outDir = base.resolve("out3"); + Path outDir = base.resolve("out"); javadoc("-d", outDir.toString(), "-doctitle", "Document Title", "-header", "Test Header", @@ -153,7 +153,7 @@ public class TestHtmlLandmarkRegions extends JavadocTester { + " \n" + "")); - Path outDir = base.resolve("out5"); + Path outDir = base.resolve("out"); javadoc("-d", outDir.toString(), "-sourcepath", srcDir.toString(), "pkg1", "pkg2"); @@ -171,12 +171,12 @@ public class TestHtmlLandmarkRegions extends JavadocTester { void createModules(Path srcDir) throws Exception { new ModuleBuilder(tb, "m1") - .classes("package p1; public class a{}") - .classes("package p2; public class b{}") + .classes("package p1; public class a { }") + .classes("package p2; public class b { }") .write(srcDir); new ModuleBuilder(tb, "m2") - .classes("package p3; public class c{}") - .classes("package p4; public class d{}") + .classes("package p3; public class c { }") + .classes("package p4; public class d { }") .write(srcDir); } diff --git a/test/langtools/jdk/javadoc/doclet/testHtmlVersion/TestHtmlVersion.java b/test/langtools/jdk/javadoc/doclet/testHtmlVersion/TestHtmlVersion.java index afe5a6a9568..d5277d1a803 100644 --- a/test/langtools/jdk/javadoc/doclet/testHtmlVersion/TestHtmlVersion.java +++ b/test/langtools/jdk/javadoc/doclet/testHtmlVersion/TestHtmlVersion.java @@ -349,46 +349,46 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Nested Class Summary

    \n" + + "

    Nested Class Summary

    \n" + "
    \n", "
    \n" + "
      \n" + "
    • \n" + "\n" + "\n" - + "

      Field Summary

      \n" + + "

      Field Summary

      \n" + "
      \n
    ", "
    \n" + "
      \n" + "
    • \n" + "\n" + "\n" - + "

      Constructor Summary

      \n" + + "

      Constructor Summary

      \n" + "
      \n
    ", "
    \n" + "
      \n" + "
    • \n" + "\n" + "\n" - + "

      Method Summary

      ", + + "

      Method Summary

      ", "
      \n" + "
        \n" + "
      • \n" + "\n" + "\n" - + "

        Field Detail

        ", + + "

        Field Detail

        ", "
        \n" + "
          \n" + "
        • \n" + "\n" + "\n" - + "

          Constructor Detail

          ", + + "

          Constructor Detail

          ", "
          \n" + "
            \n" + "
          • \n" + "\n" + "\n" - + "

            Method Detail

            ", + + "

            Method Detail

            ", "
            \n" + "
    \n", "
    \n" @@ -419,7 +419,7 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Method Summary

    \n" + + "

    Method Summary

    \n" + "
    \n", "
  • ", "
    \n" @@ -427,13 +427,13 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Enum Constant Detail

    ", + + "

    Enum Constant Detail

    ", "
    \n" + "
      \n" + "
    • \n" + "\n" + "\n" - + "

      Method Detail

      ", + + "

      Method Detail

      ", "
      \n" + "
  • \n", "
    \n" @@ -464,7 +464,7 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Method Detail

    ", + + "

    Method Detail

    ", "
    \n" + "
  • ", "
    \n" + "
      \n" + "
    • \n" + "\n" + "\n" - + "

      Optional Element Summary

      \n" + + "

      Optional Element Summary

      \n" + "
      \n
    ", "
    \n" + "
    ", "
    \n" + "
    ", "\n" @@ -831,7 +831,7 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Field Summary

    \n" + + "

    Field Summary

    \n" + "
    \n" + "
  • ", "\n" @@ -839,7 +839,7 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Constructor Summary

    \n" + + "

    Constructor Summary

    \n" + "
    \n" + "
  • ", "\n" @@ -847,7 +847,7 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Method Summary

    \n" + + "

    Method Summary

    \n" + "
    \n" + "
  • ", "\n" @@ -855,19 +855,19 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Field Detail

    ", + + "

    Field Detail

    ", "\n" + "
      \n" + "
    • \n" + "\n" + "\n" - + "

      Constructor Detail

      ", + + "

      Constructor Detail

      ", "\n" + "
        \n" + "
      • \n" + "\n" + "\n" - + "

        Method Detail

        "); + + "

        Method Detail

        "); // Negated test for enum page checkOutput("pkg/AnotherClass.ModalExclusionType.html", false, @@ -883,7 +883,7 @@ public class TestHtmlVersion extends JavadocTester { + "
      • \n" + "\n" + "\n" - + "

        Enum Constant Summary

        \n" + + "

        Enum Constant Summary

        \n" + "
        \n" + "
  • ", "\n" @@ -891,7 +891,7 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Method Summary

    \n" + + "

    Method Summary

    \n" + "
    \n" + "
  • ", "\n" @@ -899,13 +899,13 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Enum Constant Detail

    ", + + "

    Enum Constant Detail

    ", "\n" + "
      \n" + "
    • \n" + "\n" + "\n" - + "

      Method Detail

      "); + + "

      Method Detail

      "); // Negated test for interface page checkOutput("pkg2/Interface.html", false, @@ -921,7 +921,7 @@ public class TestHtmlVersion extends JavadocTester { + "
    • \n" + "\n" + "\n" - + "

      Method Summary

      \n" + + "

      Method Summary

      \n" + "
      \n" + "
  • ", "\n" @@ -929,7 +929,7 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Method Detail

    "); + + "

    Method Detail

    "); // Negated test for error page checkOutput("pkg/TestError.html", false, @@ -945,13 +945,13 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Constructor Summary

    ", + + "

    Constructor Summary

    ", "\n" + "
      \n" + "
    • \n" + "\n" + "\n" - + "

      Constructor Detail

      "); + + "

      Constructor Detail

      "); // Negated test for exception page checkOutput("pkg/TestException.html", false, @@ -967,13 +967,13 @@ public class TestHtmlVersion extends JavadocTester { + "
    • \n" + "\n" + "\n" - + "

      Constructor Summary

      ", + + "

      Constructor Summary

      ", "\n" + "
        \n" + "
      • \n" + "\n" + "\n" - + "

        Constructor Detail

        "); + + "

        Constructor Detail

        "); // Negated test for annotation page checkOutput("pkg2/TestAnnotationType.html", false, @@ -989,7 +989,7 @@ public class TestHtmlVersion extends JavadocTester { + "
      • \n" + "\n" + "\n" - + "

        Required Element Summary

        \n" + + "

        Required Element Summary

        \n" + "
        \n" + "
  • ", "\n" @@ -997,7 +997,7 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Optional Element Summary

    \n" + + "

    Optional Element Summary

    \n" + "
    \n" + "
  • ", "\n" @@ -1005,7 +1005,7 @@ public class TestHtmlVersion extends JavadocTester { + "
  • \n" + "\n" + "\n" - + "

    Element Detail

    "); + + "

    Element Detail

    "); // Negated test for class use page checkOutput("pkg1/class-use/RegClass.html", false, @@ -1027,7 +1027,7 @@ public class TestHtmlVersion extends JavadocTester { "
  • \n" + "\n" + "\n" - + "

    Uses of RegClass in pkg

    \n" + + "

    Uses of RegClass in pkg

    \n" + "
    \n
  • "); // Negated test for main index page diff --git a/test/langtools/jdk/javadoc/doclet/testIndexTaglet/TestIndexTaglet.java b/test/langtools/jdk/javadoc/doclet/testIndexTaglet/TestIndexTaglet.java index fe7eb3b2f1f..4276f526cee 100644 --- a/test/langtools/jdk/javadoc/doclet/testIndexTaglet/TestIndexTaglet.java +++ b/test/langtools/jdk/javadoc/doclet/testIndexTaglet/TestIndexTaglet.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2019, 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 @@ -75,12 +75,12 @@ public class TestIndexTaglet extends JavadocTester { checkExit(Exit.OK); checkOrder("pkg/A.html", - "

    Method Detail

    \n", + "

    Method Detail

    \n", "
    test description with search_phrase_a
    "); checkOrder("pkg/A.html", - "

    Method Summary

    \n", + "

    Method Summary

    \n", "
    test description with search_phrase_a
    "); } diff --git a/test/langtools/jdk/javadoc/doclet/testInterface/TestInterface.java b/test/langtools/jdk/javadoc/doclet/testInterface/TestInterface.java index 6842dcaabbd..fd7f2d46b2d 100644 --- a/test/langtools/jdk/javadoc/doclet/testInterface/TestInterface.java +++ b/test/langtools/jdk/javadoc/doclet/testInterface/TestInterface.java @@ -131,7 +131,7 @@ public class TestInterface extends JavadocTester { "
    Specified by:
    \n"); checkOutput("pkg/ClassWithStaticMembers.html", true, - "

    f

    \n" + "

    f

    \n" + "
    public static int f
    \n" + "
    A hider field
    ", @@ -142,7 +142,7 @@ public class TestInterface extends JavadocTester { + "
    A hider method
    \n" + "\n", - "

    staticMethod

    \n" + "

    staticMethod

    \n" + "
    public static void staticMethod()
    \n" + "
    " + "Description copied from interface: " @@ -183,8 +183,8 @@ public class TestInterface extends JavadocTester { checkOutput("pkg2/Spliterator.OfDouble.html", true, // Ensure the correct type parameters are displayed correctly - "

    Nested classes/interfaces inherited from interface pkg2." - + "Spliterator

    \n" + "

    Nested classes/interfaces inherited from interface pkg2." + + "Spliterator

    \n" + "" + "Spliterator.OfDouble, Spliterator.OfInt<" diff --git a/test/langtools/jdk/javadoc/doclet/testJavaFX/TestJavaFX.java b/test/langtools/jdk/javadoc/doclet/testJavaFX/TestJavaFX.java index 87fb4b62d12..c91f74e7d73 100644 --- a/test/langtools/jdk/javadoc/doclet/testJavaFX/TestJavaFX.java +++ b/test/langtools/jdk/javadoc/doclet/testJavaFX/TestJavaFX.java @@ -86,14 +86,14 @@ public class TestJavaFX extends JavadocTester { + "paused
    \n" + "
    \n" + "
    Defines if paused.
    ", - "

    paused

    \n" + "

    paused

    \n" + "
    public final C.BooleanProperty pausedProperty
    \n" + "
    Defines if paused. The second line.
    ", - "

    isPaused

    \n" + "

    isPaused

    \n" + "
    public final double isPaused()
    \n" + "
    Gets the value of the property paused.
    ", - "

    setPaused

    \n" + "

    setPaused

    \n" + "
    public final void setPaused​(boolean value)
    \n" + "
    Sets the value of the property paused.
    \n" + "
    \n" @@ -101,7 +101,7 @@ public class TestJavaFX extends JavadocTester { + "
    Defines if paused. The second line.
    \n" + "
    Default value:
    \n" + "
    false
    ", - "

    isPaused

    \n" + "

    isPaused

    \n" + "
    public final double isPaused()
    \n" + "
    Gets the value of the property paused.
    \n" + "
    \n" @@ -109,13 +109,13 @@ public class TestJavaFX extends JavadocTester { + "
    Defines if paused. The second line.
    \n" + "
    Default value:
    \n" + "
    false
    ", - "

    rate

    \n" + "

    rate

    \n" + "
    public final C.DoubleProperty rateProperty
    \n" + "
    Defines the direction/speed at which the " + "Timeline is expected to\n" + " be played. This is the second line.
    ", - "

    setRate

    \n" + "

    setRate

    \n" + "
    public final void setRate​(double value)
    \n" + "
    Sets the value of the property rate.
    \n" + "
    \n" @@ -126,7 +126,7 @@ public class TestJavaFX extends JavadocTester { + "
    11
    \n" + "
    Since:
    \n" + "
    JavaFX 8.0
    ", - "

    getRate

    \n" + "

    getRate

    \n" + "
    public final double getRate()
    \n" + "
    Gets the value of the property rate.
    \n" + "
    \n" @@ -137,7 +137,7 @@ public class TestJavaFX extends JavadocTester { + "
    11
    \n" + "
    Since:
    \n" + "
    JavaFX 8.0
    ", - "

    Property Summary

    \n" + "

    Property Summary

    \n" + "
    \n\n" + "", "\n" @@ -147,7 +147,7 @@ public class TestJavaFX extends JavadocTester { checkOutput("pkg1/C.html", false, "A()", - "

    Property Summary

    \n" + "

    Property Summary

    \n" + "
    \n" + "
    Properties 
    \n" + ""); checkOutput("pkg2/Test.html", false, - "

    Property Summary

    \n" + "

    Property Summary

    \n" + "
    \n" + "
    \n" + "\n" diff --git a/test/langtools/jdk/javadoc/doclet/testModules/TestModuleServices.java b/test/langtools/jdk/javadoc/doclet/testModules/TestModuleServices.java index 264df25715b..3c5fdee8898 100644 --- a/test/langtools/jdk/javadoc/doclet/testModules/TestModuleServices.java +++ b/test/langtools/jdk/javadoc/doclet/testModules/TestModuleServices.java @@ -173,7 +173,7 @@ public class TestModuleServices extends JavadocTester { checkExit(Exit.OK); checkOutput("m/module-summary.html", false, - "

    Services

    "); + "

    Services

    "); } @Test @@ -194,7 +194,7 @@ public class TestModuleServices extends JavadocTester { checkExit(Exit.OK); checkOutput("m/module-summary.html", true, - "

    Services

    "); + "

    Services

    "); checkOutput("m/module-summary.html", true, "
    \n
    Properties 
    Modifier and TypeMethod
    \n" + @@ -235,7 +235,7 @@ public class TestModuleServices extends JavadocTester { checkExit(Exit.OK); checkOutput("m/module-summary.html", true, - "

    Services

    "); + "

    Services

    "); checkOutput("m/module-summary.html", true, "
    \n
    \n" + @@ -276,7 +276,7 @@ public class TestModuleServices extends JavadocTester { checkExit(Exit.OK); checkOutput("m/module-summary.html", false, - "

    Services

    "); + "

    Services

    "); } @Test @@ -302,7 +302,7 @@ public class TestModuleServices extends JavadocTester { checkExit(Exit.OK); checkOutput("m/module-summary.html", true, - "

    Services

    "); + "

    Services

    "); checkOutput("m/module-summary.html", true, "
    \n
    \n" + @@ -346,7 +346,7 @@ public class TestModuleServices extends JavadocTester { checkExit(Exit.OK); checkOutput("m/module-summary.html", true, - "

    Services

    "); + "

    Services

    "); checkOutput("m/module-summary.html", true, "
    \n
    \n" + @@ -389,7 +389,7 @@ public class TestModuleServices extends JavadocTester { checkExit(Exit.OK); checkOutput("m/module-summary.html", true, - "

    Services

    "); + "

    Services

    "); checkOutput("m/module-summary.html", true, "
    \n
    \n" + diff --git a/test/langtools/jdk/javadoc/doclet/testModules/TestModules.java b/test/langtools/jdk/javadoc/doclet/testModules/TestModules.java index e46f1c18401..d1cc0af7679 100644 --- a/test/langtools/jdk/javadoc/doclet/testModules/TestModules.java +++ b/test/langtools/jdk/javadoc/doclet/testModules/TestModules.java @@ -1261,7 +1261,7 @@ public class TestModules extends JavadocTester { + "
    This is a test description for the test.moduleFullName.
    \n" + ""); checkOutput("module-overview-frame.html", found, - "

    Modules

    \n" + "

    Modules

    \n" + "
      \n" + "
    • moduleB
    • \n" + "
    • test.moduleFullName
    • \n" diff --git a/test/langtools/jdk/javadoc/doclet/testNewLanguageFeatures/TestNewLanguageFeatures.java b/test/langtools/jdk/javadoc/doclet/testNewLanguageFeatures/TestNewLanguageFeatures.java index aaa9ee3e0dc..c04f0c1b5cb 100644 --- a/test/langtools/jdk/javadoc/doclet/testNewLanguageFeatures/TestNewLanguageFeatures.java +++ b/test/langtools/jdk/javadoc/doclet/testNewLanguageFeatures/TestNewLanguageFeatures.java @@ -24,7 +24,7 @@ /* * @test * @bug 4789689 4905985 4927164 4827184 4993906 5004549 7025314 7010344 8025633 8026567 8162363 - * 8175200 8186332 8182765 8196202 8187288 8173730 + * 8175200 8186332 8182765 8196202 8187288 8173730 8215307 * @summary Run Javadoc on a set of source files that demonstrate new * language features. Check the output to ensure that the new * language features are properly documented. @@ -66,7 +66,7 @@ public class TestNewLanguageFeatures extends JavadocTester { void checkEnums() { checkOutput("pkg/Coin.html", true, // Make sure enum header is correct. - "Enum Coin", + "Enum Coin", // Make sure enum signature is correct. "
      public enum "
                       + "Coin\n"
      @@ -110,7 +110,7 @@ public class TestNewLanguageFeatures extends JavadocTester {
           void checkTypeParameters() {
               checkOutput("pkg/TypeParameters.html", true,
                       // Make sure the header is correct.
      -                "Class TypeParameters<E>",
      +                "Class TypeParameters<E>",
                       // Check class type parameters section.
                       "
      Type Parameters:
      \n" + "
      E - " diff --git a/test/langtools/jdk/javadoc/doclet/testOptions/TestOptions.java b/test/langtools/jdk/javadoc/doclet/testOptions/TestOptions.java index 572929f3f15..93b0e21fb7e 100644 --- a/test/langtools/jdk/javadoc/doclet/testOptions/TestOptions.java +++ b/test/langtools/jdk/javadoc/doclet/testOptions/TestOptions.java @@ -193,10 +193,10 @@ public class TestOptions extends JavadocTester { "
      @Documented\npublic @interface "
                       + "AnnotationTypeField
      ", - "

      DEFAULT_NAME

      \n
      static final java.lang.String "
      +                "

      DEFAULT_NAME

      \n
      static final java.lang.String "
                       + ""
                       + "DEFAULT_NAME
      ", - "

      name

      \n
      java.lang.String name\n
      java.lang.String name
      "); checkOutput("src-html/linksource/AnnotationTypeField.html", true, diff --git a/test/langtools/jdk/javadoc/doclet/testOrdering/TestOrdering.java b/test/langtools/jdk/javadoc/doclet/testOrdering/TestOrdering.java index f9038e72bb2..4e73dfdca84 100644 --- a/test/langtools/jdk/javadoc/doclet/testOrdering/TestOrdering.java +++ b/test/langtools/jdk/javadoc/doclet/testOrdering/TestOrdering.java @@ -551,107 +551,107 @@ public class TestOrdering extends JavadocTester { checkExit(Exit.OK); checkOrder("pkg5/AnnoFieldTest.html", - "

      Field Detail

      ", + "

      Field Detail

      ", "
      static final int one
      ", "
      static final int two
      ", "
      static final int three
      ", "
      static final int four
      "); checkOrder("pkg5/AnnoOptionalTest.html", - "

      Optional Element Summary

      ", + "

      Optional Element Summary

      ", "four", "one", "three", "two", - "

      Element Detail

      ", - "

      one

      ", - "

      two

      ", - "

      three

      ", - "

      four

      "); + "

      Element Detail

      ", + "

      one

      ", + "

      two

      ", + "

      three

      ", + "

      four

      "); checkOrder("pkg5/AnnoRequiredTest.html", - "

      Required Element Summary

      ", + "

      Required Element Summary

      ", "four", "one", "three", "two", - "

      Element Detail

      ", - "

      one

      ", - "

      two

      ", - "

      three

      ", - "

      four

      "); + "

      Element Detail

      ", + "

      one

      ", + "

      two

      ", + "

      three

      ", + "

      four

      "); checkOrder("pkg5/CtorTest.html", - "

      Constructor Summary

      ", + "

      Constructor Summary

      ", "Constructor Detail", + "

      Constructor Detail

      ", "
      ", "", "", ""); checkOrder("pkg5/EnumTest.html", - "

      Enum Constant Summary

      ", + "

      Enum Constant Summary

      ", "
      FOUR", "ONE", "THREE", "TWO", - "

      Enum Constant Detail

      ", - "

      ONE

      ", - "

      TWO

      ", - "

      THREE

      ", - "

      FOUR

      "); + "

      Enum Constant Detail

      ", + "

      ONE

      ", + "

      TWO

      ", + "

      THREE

      ", + "

      FOUR

      "); checkOrder("pkg5/FieldTest.html", - "

      Field Summary

      ", + "

      Field Summary

      ", "four", "one", "three", "two", - "

      Field Detail

      ", - "

      one

      ", - "

      two

      ", - "

      three

      ", - "

      four

      "); + "

      Field Detail

      ", + "

      one

      ", + "

      two

      ", + "

      three

      ", + "

      four

      "); checkOrder("pkg5/IntfTest.html", - "

      Method Summary

      ", + "

      Method Summary

      ", "four", "one", "three", "two", - "

      Method Detail

      ", - "

      one

      ", - "

      two

      ", - "

      three

      ", - "

      four

      "); + "

      Method Detail

      ", + "

      one

      ", + "

      two

      ", + "

      three

      ", + "

      four

      "); checkOrder("pkg5/MethodTest.html", - "

      Method Summary

      ", + "

      Method Summary

      ", "four", "one", "three", "two", - "

      Method Detail

      ", - "

      one

      ", - "

      two

      ", - "

      three

      ", - "

      four

      "); + "

      Method Detail

      ", + "

      one

      ", + "

      two

      ", + "

      three

      ", + "

      four

      "); checkOrder("pkg5/PropertyTest.html", - "

      Property Summary

      ", + "

      Property Summary

      ", "four", "one", "three", "two", - "

      Property Detail

      ", - "

      oneProperty

      ", - "

      twoProperty

      ", - "

      threeProperty

      ", - "

      fourProperty

      "); + "

      Property Detail

      ", + "

      oneProperty

      ", + "

      twoProperty

      ", + "

      threeProperty

      ", + "

      fourProperty

      "); } } diff --git a/test/langtools/jdk/javadoc/doclet/testOverriddenMethods/TestBadOverride.java b/test/langtools/jdk/javadoc/doclet/testOverriddenMethods/TestBadOverride.java index b46c2c3342b..d7c346bfa77 100644 --- a/test/langtools/jdk/javadoc/doclet/testOverriddenMethods/TestBadOverride.java +++ b/test/langtools/jdk/javadoc/doclet/testOverriddenMethods/TestBadOverride.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2019, 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 @@ -53,7 +53,7 @@ public class TestBadOverride extends JavadocTester { checkOutput("pkg4/Foo.html", true, "
    • \n" - + "

      toString

      \n" + + "

      toString

      \n" + "
      public void toString()
      \n" + "
      Why can't I do this ?
      \n" + "
    • "); diff --git a/test/langtools/jdk/javadoc/doclet/testSerializedForm/TestSerializedForm.java b/test/langtools/jdk/javadoc/doclet/testSerializedForm/TestSerializedForm.java index 6ffbe096119..46499236cf7 100644 --- a/test/langtools/jdk/javadoc/doclet/testSerializedForm/TestSerializedForm.java +++ b/test/langtools/jdk/javadoc/doclet/testSerializedForm/TestSerializedForm.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2019, 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 4341304 4485668 4966728 8032066 8071982 8192933 + * @bug 4341304 4485668 4966728 8032066 8071982 8192933 8215307 * @summary Test that methods readResolve and writeReplace show * up in serialized-form.html the same way that readObject and writeObject do. * If the doclet includes readResolve and writeReplace in the serialized-form @@ -109,6 +109,8 @@ public class TestSerializedForm extends JavadocTester { testSrc("SerializedForm.java"), testSrc("ExternalizedForm.java"), "pkg1"); checkExit(Exit.OK); + showHeadings("serialized-form.html"); + checkOutput("serialized-form.html", true, "

      Class pkg1.NestedInnerClass.InnerClass.ProNestedInnerClass " @@ -130,15 +132,15 @@ public class TestSerializedForm extends JavadocTester { + "extends java.lang.Object implements Serializable

      "); checkOutput("serialized-form.html", true, - "

      Serialized Fields

      \n" + + "

      Serialized Fields

      \n" + "
        \n" + "
      • \n" + - "

        longs

        \n" + + "
        longs
        \n" + "
        Long[] longs
        \n" + "
        the longs
        \n" + "
      • \n" + "
      • \n" + - "

        name

        \n" + + "
        name
        \n" + "
        java.lang.String name
        \n" + "
        a test
        "); } diff --git a/test/langtools/jdk/javadoc/doclet/testSummaryHeading/TestSummaryHeading.java b/test/langtools/jdk/javadoc/doclet/testSummaryHeading/TestSummaryHeading.java index 828bff1ad51..4a03c499b5a 100644 --- a/test/langtools/jdk/javadoc/doclet/testSummaryHeading/TestSummaryHeading.java +++ b/test/langtools/jdk/javadoc/doclet/testSummaryHeading/TestSummaryHeading.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 2019, 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 @@ -51,6 +51,6 @@ public class TestSummaryHeading extends JavadocTester { checkExit(Exit.OK); checkOutput("C.html", true, - "

        Method Summary

        "); + "

        Method Summary

        "); } } diff --git a/test/langtools/jdk/javadoc/doclet/testSummaryTag/TestSummaryTag.java b/test/langtools/jdk/javadoc/doclet/testSummaryTag/TestSummaryTag.java index 7c1f5da9a13..76d99202311 100644 --- a/test/langtools/jdk/javadoc/doclet/testSummaryTag/TestSummaryTag.java +++ b/test/langtools/jdk/javadoc/doclet/testSummaryTag/TestSummaryTag.java @@ -86,7 +86,7 @@ public class TestSummaryTag extends JavadocTester { // make sure the second @summary's content is displayed correctly checkOutput("p1/A.html", true, "
      • \n" - + "

        m3

        \n" + + "

        m3

        \n" + "
        public void m3()
        \n" + "
        First sentence some text maybe second sentence.
        \n" + "
      • \n" diff --git a/test/langtools/jdk/javadoc/doclet/testSystemPropertyTaglet/TestSystemPropertyTaglet.java b/test/langtools/jdk/javadoc/doclet/testSystemPropertyTaglet/TestSystemPropertyTaglet.java index 551ea5c61f6..e14c348a679 100644 --- a/test/langtools/jdk/javadoc/doclet/testSystemPropertyTaglet/TestSystemPropertyTaglet.java +++ b/test/langtools/jdk/javadoc/doclet/testSystemPropertyTaglet/TestSystemPropertyTaglet.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2018, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2018, 2019, 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 @@ -76,9 +76,9 @@ public class TestSystemPropertyTaglet extends JavadocTester { checkExit(Exit.OK); checkOrder("pkg/A.html", - "

        Class A

        ", + "

        Class A

        ", "test with user.name", - "

        Method Detail

        ", + "

        Method Detail

        ", "test with java.version"); checkOrder("index-all.html", diff --git a/test/langtools/jdk/javadoc/lib/javadoc/tester/JavadocTester.java b/test/langtools/jdk/javadoc/lib/javadoc/tester/JavadocTester.java index c1b2868376d..2a99ab3f7ff 100644 --- a/test/langtools/jdk/javadoc/lib/javadoc/tester/JavadocTester.java +++ b/test/langtools/jdk/javadoc/lib/javadoc/tester/JavadocTester.java @@ -232,7 +232,7 @@ public abstract class JavadocTester { private DirectoryCheck outputDirectoryCheck = DirectoryCheck.EMPTY; - private boolean automaticCheckAccessibility = false; + private boolean automaticCheckAccessibility = true; private boolean automaticCheckLinks = true; /** The current subtest number. Incremented when checking(...) is called. */ @@ -261,7 +261,7 @@ public abstract class JavadocTester { } /** - * Run all methods annotated with @Test, followed by printSummary. + * Runs all methods annotated with @Test, followed by printSummary. * Typically called on a tester object in main() * @param f a function which will be used to provide arguments to each * invoked method @@ -285,7 +285,7 @@ public abstract class JavadocTester { } /** - * Run javadoc. + * Runs javadoc. * The output directory used by this call and the final exit code * will be saved for later use. * To aid the reader, it is recommended that calls to this method @@ -391,7 +391,7 @@ public abstract class JavadocTester { } /** - * Set the kind of check for the initial contents of the output directory + * Sets the kind of check for the initial contents of the output directory * before javadoc is run. * The filter should return true for files that should not appear. * @param c the kind of check to perform @@ -401,7 +401,14 @@ public abstract class JavadocTester { } /** - * Set whether or not to perform an automatic call of checkLinks. + * Sets whether or not to perform an automatic call of checkAccessibility. + */ + public void setAutomaticCheckAccessibility(boolean b) { + automaticCheckAccessibility = b; + } + + /** + * Sets whether or not to perform an automatic call of checkLinks. */ public void setAutomaticCheckLinks(boolean b) { automaticCheckLinks = b; @@ -431,7 +438,7 @@ public abstract class JavadocTester { } /** - * Check the exit code of the most recent call of javadoc. + * Checks the exit code of the most recent call of javadoc. * * @param expected the exit code that is required for the test * to pass. @@ -446,7 +453,7 @@ public abstract class JavadocTester { } /** - * Check for content in (or not in) the generated output. + * Checks for content in (or not in) the generated output. * Within the search strings, the newline character \n * will be translated to the platform newline character sequence. * @param path a path within the most recent output directory @@ -465,7 +472,7 @@ public abstract class JavadocTester { } /** - * Check for content in (or not in) the generated output. + * Checks for content in (or not in) the generated output. * Within the search strings, the newline character \n * will be translated to the platform newline character sequence. * @param path a path within the most recent output directory, identifying @@ -487,7 +494,7 @@ public abstract class JavadocTester { } /** - * Check for content in (or not in) the one of the output streams written by + * Checks for content in (or not in) the one of the output streams written by * javadoc. Within the search strings, the newline character \n * will be translated to the platform newline character sequence. * @param output the output stream to check @@ -519,6 +526,11 @@ public abstract class JavadocTester { } } + /** + * Performs some structural accessibility checks on the files generated by the most + * recent run of javadoc. + * The checks can be run automatically by calling {@link #setAutomaticCheckAccessibility}. + */ public void checkAccessibility() { checking("Check accessibility"); A11yChecker c = new A11yChecker(out, this::readFile); @@ -536,6 +548,11 @@ public abstract class JavadocTester { } } + /** + * Checks all the links within the files generated by the most + * recent run of javadoc. + * The checks can be run automatically by calling {@link #setAutomaticCheckLinks}. + */ public void checkLinks() { checking("Check links"); LinkChecker c = new LinkChecker(out, this::readFile); @@ -554,7 +571,27 @@ public abstract class JavadocTester { } /** - * Get the content of the one of the output streams written by javadoc. + * Shows the heading structure for each of the specified files. + * The structure is is printed in plain text to the main output stream. + * No errors are reported (unless there is a problem reading a file) + * but missing headings are noted within the output. + * @params the files + */ + public void showHeadings(String... paths) { + ShowHeadings s = new ShowHeadings(out, this::readFile); + for (String p : paths) { + try { + File f = new File(outputDir, p); + s.checkFiles(List.of(f.toPath()), false, Collections.emptySet()); + } catch (IOException e) { + checking("Read file"); + failed("Error reading file: " + e); + } + } + } + + /** + * Gets the content of the one of the output streams written by javadoc. * @param output the name of the output stream * @return the content of the output stream */ @@ -563,7 +600,7 @@ public abstract class JavadocTester { } /** - * Get the content of the one of the output streams written by javadoc. + * Gets the content of the one of the output streams written by javadoc. * @param output the name of the output stream * @return the content of the output stream, as a line of lines */ @@ -573,7 +610,7 @@ public abstract class JavadocTester { } /** - * Check for files in (or not in) the generated output. + * Checks for files in (or not in) the generated output. * @param expectedFound true if all of the files are expected * to be found, or false if all of the files are expected to be * not found @@ -584,7 +621,7 @@ public abstract class JavadocTester { } /** - * Check for files in (or not in) the generated output. + * Checks for files in (or not in) the generated output. * @param expectedFound true if all of the files are expected * to be found, or false if all of the files are expected to be * not found @@ -605,7 +642,7 @@ public abstract class JavadocTester { } /** - * Check that a series of strings are found in order in a file in + * Checks that a series of strings are found in order in a file in * the generated output. * @param path the file to check * @param strings the strings whose order to check @@ -658,7 +695,7 @@ public abstract class JavadocTester { } /** - * Compare a set of files in each of two directories. + * Compares a set of files in each of two directories. * * @param baseDir1 the directory containing the first set of files * @param baseDir2 the directory containing the second set of files @@ -673,7 +710,7 @@ public abstract class JavadocTester { } /** - * A utility to copy a directory from one place to another. + * Copies a directory from one place to another. * * @param targetDir the directory to copy. * @param destDir the destination to copy the directory to. @@ -707,7 +744,7 @@ public abstract class JavadocTester { } /** - * Copy source file to destination file. + * Copies a file. * * @param destfile the destination file * @param srcfile the source file @@ -749,7 +786,7 @@ public abstract class JavadocTester { } /** - * Read the file and return it as a string. + * Reads the file and return it as a string. * * @param baseDir the directory in which to locate the file * @param fileName the name of the file to read @@ -825,7 +862,7 @@ public abstract class JavadocTester { } /** - * Print a summary of the test results. + * Prints a summary of the test results. */ protected void printSummary() { String javadocRuns = (javadocRunNum <= 1) ? "" @@ -845,7 +882,7 @@ public abstract class JavadocTester { } /** - * Search for the string in the given file and return true + * Searches for the string in the given file and return true * if the string was found. * * @param fileString the contents of the file to search through @@ -861,7 +898,7 @@ public abstract class JavadocTester { } /** - * Compare the two given files. + * Compares the two given files. * * @param baseDir1 the directory in which to locate the first file * @param baseDir2 the directory in which to locate the second file diff --git a/test/langtools/jdk/javadoc/lib/javadoc/tester/ShowHeadings.java b/test/langtools/jdk/javadoc/lib/javadoc/tester/ShowHeadings.java new file mode 100644 index 00000000000..c18186d06d3 --- /dev/null +++ b/test/langtools/jdk/javadoc/lib/javadoc/tester/ShowHeadings.java @@ -0,0 +1,102 @@ +/* + * Copyright (c) 2019, 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 javadoc.tester; + +import java.io.PrintStream; +import java.nio.file.Path; +import java.util.Map; +import java.util.function.Function; + +public class ShowHeadings extends HtmlChecker { + + private int currLevel; + + private boolean copyContent; + + ShowHeadings(PrintStream out, Function fileReader) { + super(out, fileReader); + } + + @Override + public void report() { + } + + @Override + public void startFile(Path path) { + out.println("Headings: " + path); + currLevel = 0; + } + + @Override + public void endFile() { + } + + @Override + public void docType(String doctype) { + } + + @Override + public void startElement(String name, Map attrs, boolean selfClosing) { + switch (name) { + case "h1": case "h2": case "h3": case "h4": case "h5": case "h6": + startHeading(name); + break; + } + } + + @Override + public void endElement(String name) { + switch (name) { + case "h1": case "h2": case "h3": case "h4": case "h5": case "h6": + out.println(); + copyContent = false; + break; + } + + } + + private void startHeading(String h) { + int level = Character.digit(h.charAt(1), 10); + while (level > currLevel + 1) { + currLevel++; + out.println("* ".repeat(currLevel - 1) + "H" + currLevel + ": *** MISSING ***"); + } + currLevel = level; + out.print("* ".repeat(currLevel - 1) + "H" + currLevel + ": "); + copyContent = true; + } + + @Override + public void content(String s) { + if (copyContent) { + out.print(s.replace(" ", " ") + .replace("<", "<") + .replace(">", ">") + .replace("&", "&") + .replaceAll("\\s+", " ") + ); + } + } +} +