8320458: Improve structural navigation in API documentation
Reviewed-by: erikj, jjg
This commit is contained in:
parent
a6c0b10704
commit
81df265e41
@ -139,11 +139,6 @@ ifeq ($(IS_DRAFT), true)
|
|||||||
endif
|
endif
|
||||||
DRAFT_TEXT := This specification is not final and is subject to change. \
|
DRAFT_TEXT := This specification is not final and is subject to change. \
|
||||||
Use is subject to <a href="$(LICENSE_URL)">license terms</a>.
|
Use is subject to <a href="$(LICENSE_URL)">license terms</a>.
|
||||||
|
|
||||||
# Workaround stylesheet bug
|
|
||||||
HEADER_STYLE := style="margin-top: 9px;"
|
|
||||||
else
|
|
||||||
HEADER_STYLE := style="margin-top: 14px;"
|
|
||||||
endif
|
endif
|
||||||
|
|
||||||
# $1 - Relative prefix to COPYRIGHT_URL
|
# $1 - Relative prefix to COPYRIGHT_URL
|
||||||
@ -339,7 +334,7 @@ define SetupApiDocsGenerationBody
|
|||||||
$1_DOC_TITLE := $$($1_LONG_NAME)<br>Version $$(VERSION_SPECIFICATION) API \
|
$1_DOC_TITLE := $$($1_LONG_NAME)<br>Version $$(VERSION_SPECIFICATION) API \
|
||||||
Specification
|
Specification
|
||||||
$1_WINDOW_TITLE := $$(subst &,&,$$($1_SHORT_NAME))$$(DRAFT_MARKER_TITLE)
|
$1_WINDOW_TITLE := $$(subst &,&,$$($1_SHORT_NAME))$$(DRAFT_MARKER_TITLE)
|
||||||
$1_HEADER_TITLE := <div $$(HEADER_STYLE)><strong>$$($1_SHORT_NAME)</strong> \
|
$1_HEADER_TITLE := <div><strong>$$($1_SHORT_NAME)</strong> \
|
||||||
$$(DRAFT_MARKER_STR)</div>
|
$$(DRAFT_MARKER_STR)</div>
|
||||||
ifneq ($$($1_OTHER_VERSIONS), )
|
ifneq ($$($1_OTHER_VERSIONS), )
|
||||||
$1_JAVADOC_BOTTOM := $$(call JAVADOC_BOTTOM, <a href="$$($1_OTHER_VERSIONS)">Other versions.</a>)
|
$1_JAVADOC_BOTTOM := $$(call JAVADOC_BOTTOM, <a href="$$($1_OTHER_VERSIONS)">Other versions.</a>)
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -220,6 +220,7 @@ public abstract class AbstractMemberWriter {
|
|||||||
Content member = getMemberSummaryHeader(target);
|
Content member = getMemberSummaryHeader(target);
|
||||||
summaryTreeList.forEach(member::add);
|
summaryTreeList.forEach(member::add);
|
||||||
buildSummary(target, member);
|
buildSummary(target, member);
|
||||||
|
writer.tableOfContents.addLink(HtmlIds.forMemberSummary(kind), getSummaryLabel());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -306,6 +307,20 @@ public abstract class AbstractMemberWriter {
|
|||||||
return out;
|
return out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private Content getSummaryLabel() {
|
||||||
|
return switch (kind) {
|
||||||
|
case FIELDS -> contents.fieldSummaryLabel;
|
||||||
|
case METHODS -> contents.methodSummary;
|
||||||
|
case CONSTRUCTORS -> contents.constructorSummaryLabel;
|
||||||
|
case ENUM_CONSTANTS -> contents.enumConstantSummary;
|
||||||
|
case NESTED_CLASSES -> contents.nestedClassSummary;
|
||||||
|
case PROPERTIES -> contents.propertySummaryLabel;
|
||||||
|
case ANNOTATION_TYPE_MEMBER_OPTIONAL -> contents.annotateTypeOptionalMemberSummaryLabel;
|
||||||
|
case ANNOTATION_TYPE_MEMBER_REQUIRED -> contents.annotateTypeRequiredMemberSummaryLabel;
|
||||||
|
default -> throw new IllegalArgumentException(kind.toString());
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the member summary header for the given class.
|
* Returns the member summary header for the given class.
|
||||||
*
|
*
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -90,6 +90,8 @@ public class AnnotationTypeMemberWriter extends AbstractMemberWriter {
|
|||||||
addAnnotationDetailsMarker(target);
|
addAnnotationDetailsMarker(target);
|
||||||
Content annotationDetailsHeader = getAnnotationDetailsHeader();
|
Content annotationDetailsHeader = getAnnotationDetailsHeader();
|
||||||
Content memberList = getMemberList();
|
Content memberList = getMemberList();
|
||||||
|
writer.tableOfContents.addLink(HtmlIds.ANNOTATION_TYPE_ELEMENT_DETAIL, contents.annotationTypeDetailsLabel);
|
||||||
|
writer.tableOfContents.pushNestedList();
|
||||||
|
|
||||||
for (Element member : members) {
|
for (Element member : members) {
|
||||||
currentMember = member;
|
currentMember = member;
|
||||||
@ -98,9 +100,12 @@ public class AnnotationTypeMemberWriter extends AbstractMemberWriter {
|
|||||||
buildAnnotationTypeMemberChildren(div);
|
buildAnnotationTypeMemberChildren(div);
|
||||||
annotationContent.add(div);
|
annotationContent.add(div);
|
||||||
memberList.add(writer.getMemberListItem(annotationContent));
|
memberList.add(writer.getMemberListItem(annotationContent));
|
||||||
|
writer.tableOfContents.addLink(htmlIds.forMember(typeElement, (ExecutableElement) member),
|
||||||
|
Text.of(name(member)));
|
||||||
}
|
}
|
||||||
Content annotationDetails = getAnnotationDetails(annotationDetailsHeader, memberList);
|
Content annotationDetails = getAnnotationDetails(annotationDetailsHeader, memberList);
|
||||||
target.add(annotationDetails);
|
target.add(annotationDetails);
|
||||||
|
writer.tableOfContents.popNestedList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -34,6 +34,7 @@ import java.util.SortedSet;
|
|||||||
import java.util.TreeSet;
|
import java.util.TreeSet;
|
||||||
|
|
||||||
import javax.lang.model.element.Element;
|
import javax.lang.model.element.Element;
|
||||||
|
import javax.lang.model.element.ModuleElement;
|
||||||
import javax.lang.model.element.PackageElement;
|
import javax.lang.model.element.PackageElement;
|
||||||
import javax.lang.model.element.TypeElement;
|
import javax.lang.model.element.TypeElement;
|
||||||
import javax.tools.Diagnostic;
|
import javax.tools.Diagnostic;
|
||||||
@ -42,6 +43,7 @@ import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder;
|
|||||||
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle;
|
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.TagName;
|
import jdk.javadoc.internal.doclets.formats.html.markup.TagName;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree;
|
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree;
|
||||||
|
import jdk.javadoc.internal.doclets.formats.html.markup.Text;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.Navigation.PageMode;
|
import jdk.javadoc.internal.doclets.formats.html.Navigation.PageMode;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.DocletException;
|
import jdk.javadoc.internal.doclets.toolkit.DocletException;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.ClassTree;
|
import jdk.javadoc.internal.doclets.toolkit.util.ClassTree;
|
||||||
@ -418,14 +420,19 @@ public class ClassUseWriter extends SubWriterHolderWriter {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
||||||
Content mdleLinkContent = getModuleLink(utils.elementUtils.getModuleOf(typeElement),
|
List<Content> subnavLinks = new ArrayList<>();
|
||||||
contents.moduleLabel);
|
if (configuration.showModules) {
|
||||||
Content classLinkContent = getLink(new HtmlLinkInfo(
|
ModuleElement mdle = utils.elementUtils.getModuleOf(typeElement);
|
||||||
configuration, HtmlLinkInfo.Kind.PLAIN, typeElement)
|
subnavLinks.add(getModuleLink(mdle, Text.of(mdle.getQualifiedName())));
|
||||||
.label(resources.getText("doclet.Class"))
|
}
|
||||||
.skipPreview(true));
|
PackageElement pkg = utils.containingPackage(typeElement);
|
||||||
return super.getNavBar(pageMode, element)
|
subnavLinks.add(getPackageLink(pkg, getLocalizedPackageName(pkg)));
|
||||||
.setNavLinkModule(mdleLinkContent)
|
subnavLinks.add(getLink(
|
||||||
.setNavLinkClass(classLinkContent);
|
new HtmlLinkInfo(configuration, HtmlLinkInfo.Kind.PLAIN, typeElement)
|
||||||
|
.style(HtmlStyle.currentSelection)
|
||||||
|
.skipPreview(true)));
|
||||||
|
|
||||||
|
return super.getNavBar(pageMode, element).setSubNavLinks(subnavLinks);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -48,7 +48,6 @@ import com.sun.source.doctree.DocTree;
|
|||||||
|
|
||||||
import jdk.javadoc.internal.doclets.formats.html.Navigation.PageMode;
|
import jdk.javadoc.internal.doclets.formats.html.Navigation.PageMode;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder;
|
import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.Entity;
|
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlAttr;
|
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlAttr;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle;
|
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.HtmlTree;
|
||||||
@ -61,7 +60,6 @@ import jdk.javadoc.internal.doclets.toolkit.util.ClassTree;
|
|||||||
import jdk.javadoc.internal.doclets.toolkit.util.CommentHelper;
|
import jdk.javadoc.internal.doclets.toolkit.util.CommentHelper;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocFileIOException;
|
import jdk.javadoc.internal.doclets.toolkit.util.DocFileIOException;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocPath;
|
import jdk.javadoc.internal.doclets.toolkit.util.DocPath;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.VisibleMemberTable;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Generate the Class Information Page.
|
* Generate the Class Information Page.
|
||||||
@ -435,24 +433,6 @@ public class ClassWriter extends SubWriterHolderWriter {
|
|||||||
protected Content getHeader(String header) {
|
protected Content getHeader(String header) {
|
||||||
HtmlTree body = getBody(getWindowTitle(utils.getSimpleName(typeElement)));
|
HtmlTree body = getBody(getWindowTitle(utils.getSimpleName(typeElement)));
|
||||||
var div = HtmlTree.DIV(HtmlStyle.header);
|
var div = HtmlTree.DIV(HtmlStyle.header);
|
||||||
if (configuration.showModules) {
|
|
||||||
ModuleElement mdle = configuration.docEnv.getElementUtils().getModuleOf(typeElement);
|
|
||||||
var classModuleLabel = HtmlTree.SPAN(HtmlStyle.moduleLabelInType, contents.moduleLabel);
|
|
||||||
var moduleNameDiv = HtmlTree.DIV(HtmlStyle.subTitle, classModuleLabel);
|
|
||||||
moduleNameDiv.add(Entity.NO_BREAK_SPACE);
|
|
||||||
moduleNameDiv.add(getModuleLink(mdle,
|
|
||||||
Text.of(mdle.getQualifiedName())));
|
|
||||||
div.add(moduleNameDiv);
|
|
||||||
}
|
|
||||||
PackageElement pkg = utils.containingPackage(typeElement);
|
|
||||||
if (!pkg.isUnnamed()) {
|
|
||||||
var classPackageLabel = HtmlTree.SPAN(HtmlStyle.packageLabelInType, contents.packageLabel);
|
|
||||||
var pkgNameDiv = HtmlTree.DIV(HtmlStyle.subTitle, classPackageLabel);
|
|
||||||
pkgNameDiv.add(Entity.NO_BREAK_SPACE);
|
|
||||||
Content pkgNameContent = getPackageLink(pkg, getLocalizedPackageName(pkg));
|
|
||||||
pkgNameDiv.add(pkgNameContent);
|
|
||||||
div.add(pkgNameDiv);
|
|
||||||
}
|
|
||||||
HtmlLinkInfo linkInfo = new HtmlLinkInfo(configuration,
|
HtmlLinkInfo linkInfo = new HtmlLinkInfo(configuration,
|
||||||
HtmlLinkInfo.Kind.SHOW_TYPE_PARAMS_AND_BOUNDS, typeElement)
|
HtmlLinkInfo.Kind.SHOW_TYPE_PARAMS_AND_BOUNDS, typeElement)
|
||||||
.linkToSelf(false); // Let's not link to ourselves in the header
|
.linkToSelf(false); // Let's not link to ourselves in the header
|
||||||
@ -472,21 +452,17 @@ public class ClassWriter extends SubWriterHolderWriter {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
||||||
Content linkContent = getModuleLink(utils.elementUtils.getModuleOf(element),
|
List<Content> subnavLinks = new ArrayList<>();
|
||||||
contents.moduleLabel);
|
if (configuration.showModules) {
|
||||||
return super.getNavBar(pageMode, element)
|
ModuleElement mdle = configuration.docEnv.getElementUtils().getModuleOf(typeElement);
|
||||||
.setNavLinkModule(linkContent)
|
subnavLinks.add(getModuleLink(mdle, Text.of(mdle.getQualifiedName())));
|
||||||
.setSubNavLinks(() -> {
|
}
|
||||||
List<Content> list = new ArrayList<>();
|
PackageElement pkg = utils.containingPackage(typeElement);
|
||||||
VisibleMemberTable vmt = configuration.getVisibleMemberTable(typeElement);
|
subnavLinks.add(getPackageLink(pkg, getLocalizedPackageName(pkg)));
|
||||||
Set<VisibleMemberTable.Kind> summarySet =
|
subnavLinks.add(getLink(new HtmlLinkInfo(configuration, HtmlLinkInfo.Kind.PLAIN, typeElement)
|
||||||
VisibleMemberTable.Kind.forSummariesOf(element.getKind());
|
.style(HtmlStyle.currentSelection)
|
||||||
for (VisibleMemberTable.Kind kind : summarySet) {
|
.skipPreview(true)));
|
||||||
list.add(links.createLink(HtmlIds.forMemberSummary(kind),
|
return super.getNavBar(pageMode, element).setSubNavLinks(subnavLinks);
|
||||||
contents.getNavLinkLabelContent(kind), vmt.hasVisibleMembers(kind)));
|
|
||||||
}
|
|
||||||
return list;
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void addFooter() {
|
protected void addFooter() {
|
||||||
@ -520,10 +496,13 @@ public class ClassWriter extends SubWriterHolderWriter {
|
|||||||
|
|
||||||
protected void addClassDescription(Content classInfo) {
|
protected void addClassDescription(Content classInfo) {
|
||||||
addPreviewInfo(classInfo);
|
addPreviewInfo(classInfo);
|
||||||
|
tableOfContents.addLink(HtmlIds.TOP_OF_PAGE, contents.descriptionLabel);
|
||||||
if (!options.noComment()) {
|
if (!options.noComment()) {
|
||||||
// generate documentation for the class.
|
// generate documentation for the class.
|
||||||
if (!utils.getFullBody(typeElement).isEmpty()) {
|
if (!utils.getFullBody(typeElement).isEmpty()) {
|
||||||
|
tableOfContents.pushNestedList();
|
||||||
addInlineComment(typeElement, classInfo);
|
addInlineComment(typeElement, classInfo);
|
||||||
|
tableOfContents.popNestedList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -535,7 +514,9 @@ public class ClassWriter extends SubWriterHolderWriter {
|
|||||||
protected void addClassTagInfo(Content classInfo) {
|
protected void addClassTagInfo(Content classInfo) {
|
||||||
if (!options.noComment()) {
|
if (!options.noComment()) {
|
||||||
// Print Information about all the tags here
|
// Print Information about all the tags here
|
||||||
|
tableOfContents.pushNestedList();
|
||||||
addTagsInfo(typeElement, classInfo);
|
addTagsInfo(typeElement, classInfo);
|
||||||
|
tableOfContents.popNestedList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2001, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2001, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -50,7 +50,6 @@ import jdk.javadoc.internal.doclets.formats.html.Navigation.PageMode;
|
|||||||
import jdk.javadoc.internal.doclets.formats.html.markup.Text;
|
import jdk.javadoc.internal.doclets.formats.html.markup.Text;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.DocletException;
|
import jdk.javadoc.internal.doclets.toolkit.DocletException;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocFileIOException;
|
import jdk.javadoc.internal.doclets.toolkit.util.DocFileIOException;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocLink;
|
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocPaths;
|
import jdk.javadoc.internal.doclets.toolkit.util.DocPaths;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.IndexItem;
|
import jdk.javadoc.internal.doclets.toolkit.util.IndexItem;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.VisibleMemberTable;
|
import jdk.javadoc.internal.doclets.toolkit.util.VisibleMemberTable;
|
||||||
@ -144,16 +143,18 @@ public class ConstantsSummaryWriter extends HtmlDocletWriter {
|
|||||||
* Builds the list of contents for the groups of packages appearing in the constants summary page.
|
* Builds the list of contents for the groups of packages appearing in the constants summary page.
|
||||||
*/
|
*/
|
||||||
protected void buildContents() {
|
protected void buildContents() {
|
||||||
Content contentList = getContentsHeader();
|
tableOfContents.addLink(HtmlIds.TOP_OF_PAGE, Text.of(resources.getText("doclet.Constants_Summary")))
|
||||||
|
.pushNestedList();
|
||||||
packageGroupHeadings.clear();
|
packageGroupHeadings.clear();
|
||||||
for (PackageElement pkg : configuration.packages) {
|
for (PackageElement pkg : configuration.packages) {
|
||||||
String abbrevPackageName = getAbbrevPackageName(pkg);
|
String abbrevPackageName = getAbbrevPackageName(pkg);
|
||||||
if (hasConstantField(pkg) && !packageGroupHeadings.contains(abbrevPackageName)) {
|
if (hasConstantField(pkg) && !packageGroupHeadings.contains(abbrevPackageName)) {
|
||||||
addLinkToPackageContent(abbrevPackageName, contentList);
|
addLinkToTableOfContents(abbrevPackageName);
|
||||||
packageGroupHeadings.add(abbrevPackageName);
|
packageGroupHeadings.add(abbrevPackageName);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
addContentsList(contentList);
|
tableOfContents.popNestedList();
|
||||||
|
bodyContents.setSideContent(tableOfContents.toContent(true));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -322,42 +323,27 @@ public class ConstantsSummaryWriter extends HtmlDocletWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Content getHeader() {
|
Content getHeader() {
|
||||||
String label = resources.getText("doclet.Constants_Summary");
|
String label = resources.getText("doclet.Constants_Summary");
|
||||||
HtmlTree body = getBody(getWindowTitle(label));
|
HtmlTree body = getBody(getWindowTitle(label));
|
||||||
bodyContents.setHeader(getHeader(PageMode.CONSTANT_VALUES));
|
bodyContents.setHeader(getHeader(PageMode.CONSTANT_VALUES));
|
||||||
return body;
|
Content titleContent = contents.constantsSummaryTitle;
|
||||||
|
var pHeading = HtmlTree.HEADING_TITLE(Headings.PAGE_TITLE_HEADING,
|
||||||
|
HtmlStyle.title, titleContent);
|
||||||
|
var div = HtmlTree.DIV(HtmlStyle.header, pHeading);
|
||||||
|
bodyContents.addMainContent(div);
|
||||||
|
return body;
|
||||||
}
|
}
|
||||||
|
|
||||||
Content getContentsHeader() {
|
Content getContentsHeader() {
|
||||||
return HtmlTree.UL(HtmlStyle.contentsList);
|
return HtmlTree.UL(HtmlStyle.contentsList);
|
||||||
}
|
}
|
||||||
|
|
||||||
void addLinkToPackageContent(String abbrevPackageName, Content content) {
|
void addLinkToTableOfContents(String abbrevPackageName) {
|
||||||
//add link to summary
|
|
||||||
Content link;
|
|
||||||
if (abbrevPackageName.isEmpty()) {
|
if (abbrevPackageName.isEmpty()) {
|
||||||
link = links.createLink(HtmlIds.UNNAMED_PACKAGE_ANCHOR,
|
tableOfContents.addLink(HtmlIds.UNNAMED_PACKAGE_ANCHOR, contents.defaultPackageLabel);
|
||||||
contents.defaultPackageLabel, "");
|
|
||||||
} else {
|
} else {
|
||||||
Content packageNameContent = Text.of(abbrevPackageName + ".*");
|
tableOfContents.addLink(HtmlId.of(abbrevPackageName), Text.of(abbrevPackageName + ".*"));
|
||||||
link = links.createLink(DocLink.fragment(abbrevPackageName),
|
|
||||||
packageNameContent, "");
|
|
||||||
}
|
}
|
||||||
content.add(HtmlTree.LI(link));
|
|
||||||
}
|
|
||||||
|
|
||||||
void addContentsList(Content content) {
|
|
||||||
Content titleContent = contents.constantsSummaryTitle;
|
|
||||||
var pHeading = HtmlTree.HEADING_TITLE(Headings.PAGE_TITLE_HEADING,
|
|
||||||
HtmlStyle.title, titleContent);
|
|
||||||
var div = HtmlTree.DIV(HtmlStyle.header, pHeading);
|
|
||||||
bodyContents.addMainContent(div);
|
|
||||||
Content headingContent = contents.contentsHeading;
|
|
||||||
var heading = HtmlTree.HEADING_TITLE(Headings.CONTENT_HEADING,
|
|
||||||
headingContent);
|
|
||||||
var section = HtmlTree.SECTION(HtmlStyle.packages, heading);
|
|
||||||
section.add(content);
|
|
||||||
bodyContents.addMainContent(section);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void addPackageGroup(String abbrevPackageName, Content toContent) {
|
void addPackageGroup(String abbrevPackageName, Content toContent) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -102,6 +102,8 @@ public class ConstructorWriter extends AbstractExecutableMemberWriter {
|
|||||||
|
|
||||||
Content constructorDetailsHeader = getConstructorDetailsHeader(target);
|
Content constructorDetailsHeader = getConstructorDetailsHeader(target);
|
||||||
Content memberList = getMemberList();
|
Content memberList = getMemberList();
|
||||||
|
writer.tableOfContents.addLink(HtmlIds.CONSTRUCTOR_DETAIL, contents.constructorDetailsLabel);
|
||||||
|
writer.tableOfContents.pushNestedList();
|
||||||
|
|
||||||
for (Element constructor : constructors) {
|
for (Element constructor : constructors) {
|
||||||
currentConstructor = (ExecutableElement)constructor;
|
currentConstructor = (ExecutableElement)constructor;
|
||||||
@ -114,9 +116,13 @@ public class ConstructorWriter extends AbstractExecutableMemberWriter {
|
|||||||
buildTagInfo(div);
|
buildTagInfo(div);
|
||||||
constructorContent.add(div);
|
constructorContent.add(div);
|
||||||
memberList.add(getMemberListItem(constructorContent));
|
memberList.add(getMemberListItem(constructorContent));
|
||||||
|
writer.tableOfContents.addLink(htmlIds.forMember(currentConstructor),
|
||||||
|
Text.of(utils.getSimpleName(constructor)
|
||||||
|
+ utils.makeSignature(currentConstructor, typeElement, false, true)));
|
||||||
}
|
}
|
||||||
Content constructorDetails = getConstructorDetails(constructorDetailsHeader, memberList);
|
Content constructorDetails = getConstructorDetails(constructorDetailsHeader, memberList);
|
||||||
target.add(constructorDetails);
|
target.add(constructorDetails);
|
||||||
|
writer.tableOfContents.popNestedList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -104,6 +104,7 @@ public class Contents {
|
|||||||
public final Content functionalInterfaceMessage;
|
public final Content functionalInterfaceMessage;
|
||||||
public final Content helpLabel;
|
public final Content helpLabel;
|
||||||
public final Content helpSubNavLabel;
|
public final Content helpSubNavLabel;
|
||||||
|
public final Content hideSidebar;
|
||||||
public final Content hierarchyForAllPackages;
|
public final Content hierarchyForAllPackages;
|
||||||
public final Content implementation;
|
public final Content implementation;
|
||||||
public final Content implementingClassesLabel;
|
public final Content implementingClassesLabel;
|
||||||
@ -169,9 +170,11 @@ public class Contents {
|
|||||||
public final Content referencedIn;
|
public final Content referencedIn;
|
||||||
public final Content relatedPackages;
|
public final Content relatedPackages;
|
||||||
public final Content returns;
|
public final Content returns;
|
||||||
|
public final Content searchLabel;
|
||||||
public final Content seeAlso;
|
public final Content seeAlso;
|
||||||
public final Content serializedForm;
|
public final Content serializedForm;
|
||||||
public final Content servicesLabel;
|
public final Content servicesLabel;
|
||||||
|
public final Content showSidebar;
|
||||||
public final Content specificationLabel;
|
public final Content specificationLabel;
|
||||||
public final Content specifiedByLabel;
|
public final Content specifiedByLabel;
|
||||||
public final Content subclassesLabel;
|
public final Content subclassesLabel;
|
||||||
@ -179,6 +182,7 @@ public class Contents {
|
|||||||
public final Content summaryLabel;
|
public final Content summaryLabel;
|
||||||
public final Content systemPropertiesLabel;
|
public final Content systemPropertiesLabel;
|
||||||
public final Content systemPropertiesSummaryLabel;
|
public final Content systemPropertiesSummaryLabel;
|
||||||
|
public final Content tableOfContentsLabel;
|
||||||
public final Content throws_;
|
public final Content throws_;
|
||||||
public final Content treeLabel;
|
public final Content treeLabel;
|
||||||
public final Content typeLabel;
|
public final Content typeLabel;
|
||||||
@ -253,6 +257,7 @@ public class Contents {
|
|||||||
functionalInterfaceMessage = getContent("doclet.Functional_Interface_Message");
|
functionalInterfaceMessage = getContent("doclet.Functional_Interface_Message");
|
||||||
helpLabel = getContent("doclet.Help");
|
helpLabel = getContent("doclet.Help");
|
||||||
helpSubNavLabel = getContent("doclet.Help_Sub_Nav");
|
helpSubNavLabel = getContent("doclet.Help_Sub_Nav");
|
||||||
|
hideSidebar = getContent("doclet.hide_sidebar");
|
||||||
hierarchyForAllPackages = getContent("doclet.Hierarchy_For_All_Packages");
|
hierarchyForAllPackages = getContent("doclet.Hierarchy_For_All_Packages");
|
||||||
implementation = getContent("doclet.Implementation");
|
implementation = getContent("doclet.Implementation");
|
||||||
implementingClassesLabel = getContent("doclet.Implementing_Classes");
|
implementingClassesLabel = getContent("doclet.Implementing_Classes");
|
||||||
@ -318,9 +323,11 @@ public class Contents {
|
|||||||
referencedIn = getContent("doclet.ReferencedIn");
|
referencedIn = getContent("doclet.ReferencedIn");
|
||||||
relatedPackages = getContent("doclet.Related_Packages");
|
relatedPackages = getContent("doclet.Related_Packages");
|
||||||
returns = getContent("doclet.Returns");
|
returns = getContent("doclet.Returns");
|
||||||
|
searchLabel = getContent("doclet.search");
|
||||||
seeAlso = getContent("doclet.See_Also");
|
seeAlso = getContent("doclet.See_Also");
|
||||||
serializedForm = getContent("doclet.Serialized_Form");
|
serializedForm = getContent("doclet.Serialized_Form");
|
||||||
servicesLabel = getContent("doclet.Services");
|
servicesLabel = getContent("doclet.Services");
|
||||||
|
showSidebar = getContent("doclet.show_sidebar");
|
||||||
specificationLabel = getContent("doclet.Specification");
|
specificationLabel = getContent("doclet.Specification");
|
||||||
specifiedByLabel = getContent("doclet.Specified_By");
|
specifiedByLabel = getContent("doclet.Specified_By");
|
||||||
subclassesLabel = getContent("doclet.Subclasses");
|
subclassesLabel = getContent("doclet.Subclasses");
|
||||||
@ -328,6 +335,7 @@ public class Contents {
|
|||||||
summaryLabel = getContent("doclet.Summary");
|
summaryLabel = getContent("doclet.Summary");
|
||||||
systemPropertiesLabel = getContent("doclet.systemProperties");
|
systemPropertiesLabel = getContent("doclet.systemProperties");
|
||||||
systemPropertiesSummaryLabel = getContent("doclet.systemPropertiesSummary");
|
systemPropertiesSummaryLabel = getContent("doclet.systemPropertiesSummary");
|
||||||
|
tableOfContentsLabel = getContent("doclet.table_of_contents");
|
||||||
throws_ = getContent("doclet.Throws");
|
throws_ = getContent("doclet.Throws");
|
||||||
treeLabel = getContent("doclet.Tree");
|
treeLabel = getContent("doclet.Tree");
|
||||||
typeLabel = getContent("doclet.Type");
|
typeLabel = getContent("doclet.Type");
|
||||||
@ -434,7 +442,7 @@ public class Contents {
|
|||||||
* @param items the items
|
* @param items the items
|
||||||
* @return the composition
|
* @return the composition
|
||||||
*/
|
*/
|
||||||
public Content join(Content separator, Collection<Content> items) {
|
public Content join(Content separator, Collection<? extends Content> items) {
|
||||||
Content result = new ContentBuilder();
|
Content result = new ContentBuilder();
|
||||||
boolean first = true;
|
boolean first = true;
|
||||||
for (Content c : items) {
|
for (Content c : items) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -107,7 +107,7 @@ public class DeprecatedListWriter extends SummaryListWriter<DeprecatedAPIListBui
|
|||||||
HtmlId htmlId = HtmlId.of("release-" + index);
|
HtmlId htmlId = HtmlId.of("release-" + index);
|
||||||
String releaseId = isOtherReleases ? "" : Integer.toString(index);
|
String releaseId = isOtherReleases ? "" : Integer.toString(index);
|
||||||
return HtmlTree.LABEL(htmlId.name(),
|
return HtmlTree.LABEL(htmlId.name(),
|
||||||
HtmlTree.INPUT("checkbox", htmlId)
|
HtmlTree.INPUT(HtmlAttr.InputType.CHECKBOX, htmlId)
|
||||||
.put(HtmlAttr.CHECKED, "")
|
.put(HtmlAttr.CHECKED, "")
|
||||||
.put(HtmlAttr.ONCLICK,
|
.put(HtmlAttr.ONCLICK,
|
||||||
"toggleGlobal(this, '" + releaseId + "', 3)"))
|
"toggleGlobal(this, '" + releaseId + "', 3)"))
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2017, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -30,7 +30,9 @@ import com.sun.source.doctree.EndElementTree;
|
|||||||
import com.sun.source.doctree.StartElementTree;
|
import com.sun.source.doctree.StartElementTree;
|
||||||
import com.sun.source.util.DocTreeFactory;
|
import com.sun.source.util.DocTreeFactory;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.BodyContents;
|
import jdk.javadoc.internal.doclets.formats.html.markup.BodyContents;
|
||||||
|
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.HtmlTree;
|
||||||
|
import jdk.javadoc.internal.doclets.formats.html.markup.Text;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.DocFileElement;
|
import jdk.javadoc.internal.doclets.toolkit.DocFileElement;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.DocletException;
|
import jdk.javadoc.internal.doclets.toolkit.DocletException;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocFile;
|
import jdk.javadoc.internal.doclets.toolkit.util.DocFile;
|
||||||
@ -215,13 +217,19 @@ public class DocFilesHandler {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
||||||
|
List<Content> subnavLinks = new ArrayList<>();
|
||||||
var pkg = dfElement.getPackageElement();
|
var pkg = dfElement.getPackageElement();
|
||||||
Content mdleLinkContent = getModuleLink(utils.elementUtils.getModuleOf(element),
|
if (configuration.showModules) {
|
||||||
contents.moduleLabel);
|
var mdle = utils.elementUtils.getModuleOf(element);
|
||||||
Content pkgLinkContent = getPackageLink(pkg, contents.packageLabel);
|
subnavLinks.add(links.createLink(pathToRoot.resolve(docPaths.moduleSummary(mdle)),
|
||||||
return super.getNavBar(pageMode, element)
|
Text.of(mdle.getQualifiedName()),
|
||||||
.setNavLinkModule(mdleLinkContent)
|
pkg.isUnnamed() ? HtmlStyle.currentSelection : null, ""));
|
||||||
.setNavLinkPackage(pkgLinkContent);
|
}
|
||||||
|
if (!pkg.isUnnamed()) {
|
||||||
|
subnavLinks.add(links.createLink(pathString(pkg, DocPaths.PACKAGE_SUMMARY),
|
||||||
|
getLocalizedPackageName(pkg), HtmlStyle.currentSelection, ""));
|
||||||
|
}
|
||||||
|
return super.getNavBar(pageMode, element).setSubNavLinks(subnavLinks);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -69,6 +69,8 @@ public class EnumConstantWriter extends AbstractMemberWriter {
|
|||||||
if (!enumConstants.isEmpty()) {
|
if (!enumConstants.isEmpty()) {
|
||||||
Content enumConstantsDetailsHeader = getEnumConstantsDetailsHeader(target);
|
Content enumConstantsDetailsHeader = getEnumConstantsDetailsHeader(target);
|
||||||
Content memberList = getMemberList();
|
Content memberList = getMemberList();
|
||||||
|
writer.tableOfContents.addLink(HtmlIds.ENUM_CONSTANT_DETAIL, contents.enumConstantDetailLabel);
|
||||||
|
writer.tableOfContents.pushNestedList();
|
||||||
|
|
||||||
for (Element enumConstant : enumConstants) {
|
for (Element enumConstant : enumConstants) {
|
||||||
currentElement = (VariableElement)enumConstant;
|
currentElement = (VariableElement)enumConstant;
|
||||||
@ -81,10 +83,12 @@ public class EnumConstantWriter extends AbstractMemberWriter {
|
|||||||
buildTagInfo(div);
|
buildTagInfo(div);
|
||||||
enumConstantContent.add(div);
|
enumConstantContent.add(div);
|
||||||
memberList.add(getMemberListItem(enumConstantContent));
|
memberList.add(getMemberListItem(enumConstantContent));
|
||||||
|
writer.tableOfContents.addLink(htmlIds.forMember(currentElement), Text.of(name(currentElement)));
|
||||||
}
|
}
|
||||||
Content enumConstantDetails = getEnumConstantsDetails(
|
Content enumConstantDetails = getEnumConstantsDetails(
|
||||||
enumConstantsDetailsHeader, memberList);
|
enumConstantsDetailsHeader, memberList);
|
||||||
target.add(enumConstantDetails);
|
target.add(enumConstantDetails);
|
||||||
|
writer.tableOfContents.popNestedList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -79,6 +79,8 @@ public class FieldWriter extends AbstractMemberWriter {
|
|||||||
if (!fields.isEmpty()) {
|
if (!fields.isEmpty()) {
|
||||||
Content fieldDetailsHeader = getFieldDetailsHeader(target);
|
Content fieldDetailsHeader = getFieldDetailsHeader(target);
|
||||||
Content memberList = getMemberList();
|
Content memberList = getMemberList();
|
||||||
|
writer.tableOfContents.addLink(HtmlIds.FIELD_DETAIL, contents.fieldDetailsLabel);
|
||||||
|
writer.tableOfContents.pushNestedList();
|
||||||
|
|
||||||
for (Element element : fields) {
|
for (Element element : fields) {
|
||||||
currentElement = (VariableElement)element;
|
currentElement = (VariableElement)element;
|
||||||
@ -91,9 +93,11 @@ public class FieldWriter extends AbstractMemberWriter {
|
|||||||
buildTagInfo(div);
|
buildTagInfo(div);
|
||||||
fieldContent.add(div);
|
fieldContent.add(div);
|
||||||
memberList.add(getMemberListItem(fieldContent));
|
memberList.add(getMemberListItem(fieldContent));
|
||||||
|
writer.tableOfContents.addLink(htmlIds.forMember(currentElement), Text.of(name(element)));
|
||||||
}
|
}
|
||||||
Content fieldDetails = getFieldDetails(fieldDetailsHeader, memberList);
|
Content fieldDetails = getFieldDetails(fieldDetailsHeader, memberList);
|
||||||
target.add(fieldDetails);
|
target.add(fieldDetails);
|
||||||
|
writer.tableOfContents.popNestedList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -122,14 +122,4 @@ class Headings {
|
|||||||
static class TypeUse {
|
static class TypeUse {
|
||||||
static final TagName SUMMARY_HEADING = TagName.H2;
|
static final TagName SUMMARY_HEADING = TagName.H2;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Headings for index frames pages.
|
|
||||||
*/
|
|
||||||
static class IndexFrames {
|
|
||||||
/** Heading for a list of module names in an index frame. */
|
|
||||||
static final TagName MODULE_HEADING = TagName.H2;
|
|
||||||
/** Heading for a list of package names in an index frame. */
|
|
||||||
static final TagName PACKAGE_HEADING = TagName.H2;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -26,7 +26,6 @@
|
|||||||
package jdk.javadoc.internal.doclets.formats.html;
|
package jdk.javadoc.internal.doclets.formats.html;
|
||||||
|
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import javax.lang.model.element.Element;
|
|
||||||
|
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.BodyContents;
|
import jdk.javadoc.internal.doclets.formats.html.markup.BodyContents;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder;
|
import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder;
|
||||||
@ -37,7 +36,6 @@ import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree;
|
|||||||
import jdk.javadoc.internal.doclets.formats.html.Navigation.PageMode;
|
import jdk.javadoc.internal.doclets.formats.html.Navigation.PageMode;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.Text;
|
import jdk.javadoc.internal.doclets.formats.html.markup.Text;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocFileIOException;
|
import jdk.javadoc.internal.doclets.toolkit.util.DocFileIOException;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocLink;
|
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocPath;
|
import jdk.javadoc.internal.doclets.toolkit.util.DocPath;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocPaths;
|
import jdk.javadoc.internal.doclets.toolkit.util.DocPaths;
|
||||||
|
|
||||||
@ -85,6 +83,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
body.add(new BodyContents()
|
body.add(new BodyContents()
|
||||||
.setHeader(getHeader(PageMode.HELP))
|
.setHeader(getHeader(PageMode.HELP))
|
||||||
.addMainContent(helpFileContent)
|
.addMainContent(helpFileContent)
|
||||||
|
.setSideContent(tableOfContents.toContent(false))
|
||||||
.setFooter(getFooter()));
|
.setFooter(getFooter()));
|
||||||
printHtmlDocument(null, "help", body);
|
printHtmlDocument(null, "help", body);
|
||||||
}
|
}
|
||||||
@ -101,27 +100,18 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
* </ul>
|
* </ul>
|
||||||
*/
|
*/
|
||||||
protected void addHelpFileContents(Content content) {
|
protected void addHelpFileContents(Content content) {
|
||||||
var mainTOC = HtmlTree.UL(HtmlStyle.helpTOC);
|
var mainHeading = getContent("doclet.help.main_heading");
|
||||||
|
tableOfContents.addLink(HtmlIds.TOP_OF_PAGE, mainHeading);
|
||||||
content.add(HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, HtmlStyle.title,
|
tableOfContents.pushNestedList();
|
||||||
getContent("doclet.help.main_heading")))
|
content.add(HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, HtmlStyle.title, mainHeading))
|
||||||
.add(mainTOC)
|
|
||||||
.add(new HtmlTree(TagName.HR))
|
.add(new HtmlTree(TagName.HR))
|
||||||
.add(getNavigationSection(mainTOC))
|
.add(getNavigationSection())
|
||||||
.add(new HtmlTree(TagName.HR))
|
.add(new HtmlTree(TagName.HR))
|
||||||
.add(getPageKindSection(mainTOC))
|
.add(getPageKindSection())
|
||||||
.add(new HtmlTree(TagName.HR))
|
.add(new HtmlTree(TagName.HR))
|
||||||
.add(HtmlTree.SPAN(HtmlStyle.helpFootnote,
|
.add(HtmlTree.SPAN(HtmlStyle.helpFootnote,
|
||||||
getContent("doclet.help.footnote")));
|
getContent("doclet.help.footnote")));
|
||||||
}
|
tableOfContents.popNestedList();
|
||||||
|
|
||||||
@Override
|
|
||||||
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
|
||||||
return super.getNavBar(pageMode, element)
|
|
||||||
.setSubNavLinks(() -> List.of(
|
|
||||||
links.createLink(HtmlIds.HELP_NAVIGATION, contents.navHelpNavigation),
|
|
||||||
links.createLink(HtmlIds.HELP_PAGES, contents.navHelpPages))
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -133,11 +123,9 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
* <li>Search
|
* <li>Search
|
||||||
* </ul>
|
* </ul>
|
||||||
*
|
*
|
||||||
* @param mainTOC the main table-of-contents
|
|
||||||
*
|
|
||||||
* @return the content containing the help
|
* @return the content containing the help
|
||||||
*/
|
*/
|
||||||
private Content getNavigationSection(HtmlTree mainTOC) {
|
private Content getNavigationSection() {
|
||||||
Content content = new ContentBuilder();
|
Content content = new ContentBuilder();
|
||||||
|
|
||||||
Content navHeading = contents.getContent("doclet.help.navigation.head");
|
Content navHeading = contents.getContent("doclet.help.navigation.head");
|
||||||
@ -156,15 +144,16 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
}
|
}
|
||||||
content.add(navSection);
|
content.add(navSection);
|
||||||
|
|
||||||
var subTOC = HtmlTree.UL(HtmlStyle.helpSubTOC);
|
tableOfContents.addLink(HtmlIds.HELP_NAVIGATION, navHeading);
|
||||||
|
tableOfContents.pushNestedList();
|
||||||
|
|
||||||
HtmlTree section;
|
HtmlTree section;
|
||||||
|
|
||||||
// Search
|
// Search
|
||||||
if (options.createIndex()) {
|
if (options.createIndex()) {
|
||||||
section = newHelpSection(getContent("doclet.help.search.head"), PageMode.SEARCH, subTOC);
|
section = newHelpSection(getContent("doclet.help.search.head"), PageMode.SEARCH);
|
||||||
var searchIntro = HtmlTree.P(getContent("doclet.help.search.intro"));
|
var searchIntro = HtmlTree.P(getContent("doclet.help.search.intro"));
|
||||||
var searchExamples = HtmlTree.UL(HtmlStyle.helpSectionList);
|
var searchExamples = HtmlTree.OL(HtmlStyle.tocList);
|
||||||
for (String[] example : SEARCH_EXAMPLES) {
|
for (String[] example : SEARCH_EXAMPLES) {
|
||||||
searchExamples.add(HtmlTree.LI(
|
searchExamples.add(HtmlTree.LI(
|
||||||
getContent("doclet.help.search.example",
|
getContent("doclet.help.search.example",
|
||||||
@ -179,10 +168,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
.add(searchRefer);
|
.add(searchRefer);
|
||||||
navSection.add(section);
|
navSection.add(section);
|
||||||
}
|
}
|
||||||
|
tableOfContents.popNestedList();
|
||||||
mainTOC.add(HtmlTree.LI(new ContentBuilder(
|
|
||||||
links.createLink(DocLink.fragment(HtmlIds.HELP_NAVIGATION.name()), navHeading),
|
|
||||||
Text.of(": "), subTOC)));
|
|
||||||
|
|
||||||
return content;
|
return content;
|
||||||
}
|
}
|
||||||
@ -200,23 +186,22 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
* <li>Index info: all packages, all classes, full index
|
* <li>Index info: all packages, all classes, full index
|
||||||
* </ul>
|
* </ul>
|
||||||
*
|
*
|
||||||
* @param mainTOC the main table-of-contents
|
|
||||||
*
|
|
||||||
* @return the content containing the help
|
* @return the content containing the help
|
||||||
*/
|
*/
|
||||||
private Content getPageKindSection(HtmlTree mainTOC) {
|
private Content getPageKindSection() {
|
||||||
Content pageKindsHeading = contents.getContent("doclet.help.page_kinds.head");
|
Content pageKindsHeading = contents.getContent("doclet.help.page_kinds.head");
|
||||||
var pageKindsSection = HtmlTree.DIV(HtmlStyle.subTitle)
|
var pageKindsSection = HtmlTree.DIV(HtmlStyle.subTitle)
|
||||||
.add(HtmlTree.HEADING(Headings.CONTENT_HEADING, pageKindsHeading).setId(HtmlIds.HELP_PAGES))
|
.add(HtmlTree.HEADING(Headings.CONTENT_HEADING, pageKindsHeading).setId(HtmlIds.HELP_PAGES))
|
||||||
.add(contents.getContent("doclet.help.page_kinds.intro"));
|
.add(contents.getContent("doclet.help.page_kinds.intro"));
|
||||||
|
|
||||||
var subTOC = HtmlTree.UL(HtmlStyle.helpSubTOC);
|
tableOfContents.addLink(HtmlIds.HELP_PAGES, pageKindsHeading);
|
||||||
|
tableOfContents.pushNestedList();
|
||||||
|
|
||||||
HtmlTree section;
|
HtmlTree section;
|
||||||
|
|
||||||
// Overview
|
// Overview
|
||||||
if (options.createOverview()) {
|
if (options.createOverview()) {
|
||||||
section = newHelpSection(contents.overviewLabel, PageMode.OVERVIEW, subTOC);
|
section = newHelpSection(contents.overviewLabel, PageMode.OVERVIEW);
|
||||||
String overviewKey = configuration.showModules
|
String overviewKey = configuration.showModules
|
||||||
? "doclet.help.overview.modules.body"
|
? "doclet.help.overview.modules.body"
|
||||||
: "doclet.help.overview.packages.body";
|
: "doclet.help.overview.packages.body";
|
||||||
@ -226,7 +211,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
// Module
|
// Module
|
||||||
if (configuration.showModules) {
|
if (configuration.showModules) {
|
||||||
section = newHelpSection(contents.moduleLabel, PageMode.MODULE, subTOC);
|
section = newHelpSection(contents.moduleLabel, PageMode.MODULE);
|
||||||
Content moduleIntro = getContent("doclet.help.module.intro");
|
Content moduleIntro = getContent("doclet.help.module.intro");
|
||||||
var modulePara = HtmlTree.P(moduleIntro);
|
var modulePara = HtmlTree.P(moduleIntro);
|
||||||
section.add(modulePara)
|
section.add(modulePara)
|
||||||
@ -238,7 +223,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Package
|
// Package
|
||||||
section = newHelpSection(contents.packageLabel, PageMode.PACKAGE, subTOC)
|
section = newHelpSection(contents.packageLabel, PageMode.PACKAGE)
|
||||||
.add(HtmlTree.P(getContent("doclet.help.package.intro")))
|
.add(HtmlTree.P(getContent("doclet.help.package.intro")))
|
||||||
.add(newHelpSectionList(
|
.add(newHelpSectionList(
|
||||||
contents.interfaces,
|
contents.interfaces,
|
||||||
@ -260,7 +245,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
Text.of(" "),
|
Text.of(" "),
|
||||||
getContent("doclet.help.class_interface.property"));
|
getContent("doclet.help.class_interface.property"));
|
||||||
|
|
||||||
section = newHelpSection(getContent("doclet.help.class_interface.head"), PageMode.CLASS, subTOC)
|
section = newHelpSection(getContent("doclet.help.class_interface.head"), PageMode.CLASS)
|
||||||
.add(HtmlTree.P(getContent("doclet.help.class_interface.intro")))
|
.add(HtmlTree.P(getContent("doclet.help.class_interface.intro")))
|
||||||
.add(newHelpSectionList(
|
.add(newHelpSectionList(
|
||||||
getContent("doclet.help.class_interface.inheritance_diagram"),
|
getContent("doclet.help.class_interface.inheritance_diagram"),
|
||||||
@ -291,20 +276,20 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
.add(HtmlTree.P(getContent("doclet.help.class_interface.member_order")));
|
.add(HtmlTree.P(getContent("doclet.help.class_interface.member_order")));
|
||||||
pageKindsSection.add(section);
|
pageKindsSection.add(section);
|
||||||
|
|
||||||
section = newHelpSection(getContent("doclet.help.other_files.head"), PageMode.DOC_FILE, subTOC)
|
section = newHelpSection(getContent("doclet.help.other_files.head"), PageMode.DOC_FILE)
|
||||||
.add(HtmlTree.P(getContent("doclet.help.other_files.body")));
|
.add(HtmlTree.P(getContent("doclet.help.other_files.body")));
|
||||||
pageKindsSection.add(section);
|
pageKindsSection.add(section);
|
||||||
|
|
||||||
// Class Use
|
// Class Use
|
||||||
if (options.classUse()) {
|
if (options.classUse()) {
|
||||||
section = newHelpSection(getContent("doclet.help.use.head"), PageMode.USE, subTOC)
|
section = newHelpSection(getContent("doclet.help.use.head"), PageMode.USE)
|
||||||
.add(HtmlTree.P(getContent("doclet.help.use.body")));
|
.add(HtmlTree.P(getContent("doclet.help.use.body")));
|
||||||
pageKindsSection.add(section);
|
pageKindsSection.add(section);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Tree
|
// Tree
|
||||||
if (options.createTree()) {
|
if (options.createTree()) {
|
||||||
section = newHelpSection(getContent("doclet.help.tree.head"), PageMode.TREE, subTOC);
|
section = newHelpSection(getContent("doclet.help.tree.head"), PageMode.TREE);
|
||||||
Content treeIntro = getContent("doclet.help.tree.intro",
|
Content treeIntro = getContent("doclet.help.tree.intro",
|
||||||
links.createLink(DocPaths.OVERVIEW_TREE, resources.getText("doclet.Class_Hierarchy")),
|
links.createLink(DocPaths.OVERVIEW_TREE, resources.getText("doclet.Class_Hierarchy")),
|
||||||
HtmlTree.CODE(Text.of("java.lang.Object")));
|
HtmlTree.CODE(Text.of("java.lang.Object")));
|
||||||
@ -317,7 +302,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
// Preview
|
// Preview
|
||||||
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.PREVIEW)) {
|
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.PREVIEW)) {
|
||||||
section = newHelpSection(contents.previewAPI, PageMode.PREVIEW, subTOC);
|
section = newHelpSection(contents.previewAPI, PageMode.PREVIEW);
|
||||||
Content previewBody = getContent("doclet.help.preview.body",
|
Content previewBody = getContent("doclet.help.preview.body",
|
||||||
links.createLink(DocPaths.PREVIEW_LIST, contents.previewAPI));
|
links.createLink(DocPaths.PREVIEW_LIST, contents.previewAPI));
|
||||||
section.add(HtmlTree.P(previewBody));
|
section.add(HtmlTree.P(previewBody));
|
||||||
@ -326,7 +311,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
// New
|
// New
|
||||||
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.NEW)) {
|
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.NEW)) {
|
||||||
section = newHelpSection(contents.newAPI, PageMode.NEW, subTOC);
|
section = newHelpSection(contents.newAPI, PageMode.NEW);
|
||||||
Content newBody = getContent("doclet.help.new.body",
|
Content newBody = getContent("doclet.help.new.body",
|
||||||
links.createLink(DocPaths.NEW_LIST, contents.newAPI));
|
links.createLink(DocPaths.NEW_LIST, contents.newAPI));
|
||||||
section.add(HtmlTree.P(newBody));
|
section.add(HtmlTree.P(newBody));
|
||||||
@ -335,7 +320,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
// Deprecated
|
// Deprecated
|
||||||
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.DEPRECATED)) {
|
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.DEPRECATED)) {
|
||||||
section = newHelpSection(contents.deprecatedAPI, PageMode.DEPRECATED, subTOC);
|
section = newHelpSection(contents.deprecatedAPI, PageMode.DEPRECATED);
|
||||||
Content deprBody = getContent("doclet.help.deprecated.body",
|
Content deprBody = getContent("doclet.help.deprecated.body",
|
||||||
links.createLink(DocPaths.DEPRECATED_LIST, resources.getText("doclet.Deprecated_API")));
|
links.createLink(DocPaths.DEPRECATED_LIST, resources.getText("doclet.Deprecated_API")));
|
||||||
section.add(HtmlTree.P(deprBody));
|
section.add(HtmlTree.P(deprBody));
|
||||||
@ -344,7 +329,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
// Restricted
|
// Restricted
|
||||||
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.RESTRICTED)) {
|
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.RESTRICTED)) {
|
||||||
section = newHelpSection(contents.restrictedMethods, PageMode.RESTRICTED, subTOC);
|
section = newHelpSection(contents.restrictedMethods, PageMode.RESTRICTED);
|
||||||
Content restrictedBody = getContent("doclet.help.restricted.body",
|
Content restrictedBody = getContent("doclet.help.restricted.body",
|
||||||
links.createLink(DocPaths.RESTRICTED_LIST, resources.getText("doclet.Restricted_Methods")));
|
links.createLink(DocPaths.RESTRICTED_LIST, resources.getText("doclet.Restricted_Methods")));
|
||||||
section.add(HtmlTree.P(restrictedBody));
|
section.add(HtmlTree.P(restrictedBody));
|
||||||
@ -353,7 +338,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
// Constant Field Values
|
// Constant Field Values
|
||||||
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.CONSTANT_VALUES)) {
|
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.CONSTANT_VALUES)) {
|
||||||
section = newHelpSection(contents.constantsSummaryTitle, PageMode.CONSTANT_VALUES, subTOC);
|
section = newHelpSection(contents.constantsSummaryTitle, PageMode.CONSTANT_VALUES);
|
||||||
Content constantsBody = getContent("doclet.help.constants.body",
|
Content constantsBody = getContent("doclet.help.constants.body",
|
||||||
links.createLink(DocPaths.CONSTANT_VALUES, resources.getText("doclet.Constants_Summary")));
|
links.createLink(DocPaths.CONSTANT_VALUES, resources.getText("doclet.Constants_Summary")));
|
||||||
section.add(HtmlTree.P(constantsBody));
|
section.add(HtmlTree.P(constantsBody));
|
||||||
@ -362,14 +347,14 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
// Serialized Form
|
// Serialized Form
|
||||||
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.SERIALIZED_FORM)) {
|
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.SERIALIZED_FORM)) {
|
||||||
section = newHelpSection(contents.serializedForm, PageMode.SERIALIZED_FORM, subTOC)
|
section = newHelpSection(contents.serializedForm, PageMode.SERIALIZED_FORM)
|
||||||
.add(HtmlTree.P(getContent("doclet.help.serial_form.body")));
|
.add(HtmlTree.P(getContent("doclet.help.serial_form.body")));
|
||||||
pageKindsSection.add(section);
|
pageKindsSection.add(section);
|
||||||
}
|
}
|
||||||
|
|
||||||
// System Properties
|
// System Properties
|
||||||
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.SYSTEM_PROPERTIES)) {
|
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.SYSTEM_PROPERTIES)) {
|
||||||
section = newHelpSection(contents.systemPropertiesLabel, PageMode.SYSTEM_PROPERTIES, subTOC);
|
section = newHelpSection(contents.systemPropertiesLabel, PageMode.SYSTEM_PROPERTIES);
|
||||||
Content sysPropsBody = getContent("doclet.help.systemProperties.body",
|
Content sysPropsBody = getContent("doclet.help.systemProperties.body",
|
||||||
links.createLink(DocPaths.SYSTEM_PROPERTIES, resources.getText("doclet.systemProperties")));
|
links.createLink(DocPaths.SYSTEM_PROPERTIES, resources.getText("doclet.systemProperties")));
|
||||||
section.add(HtmlTree.P(sysPropsBody));
|
section.add(HtmlTree.P(sysPropsBody));
|
||||||
@ -378,7 +363,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
// External Specification
|
// External Specification
|
||||||
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.EXTERNAL_SPECS)) {
|
if (configuration.conditionalPages.contains(HtmlConfiguration.ConditionalPage.EXTERNAL_SPECS)) {
|
||||||
section = newHelpSection(contents.externalSpecifications, PageMode.EXTERNAL_SPECS, subTOC);
|
section = newHelpSection(contents.externalSpecifications, PageMode.EXTERNAL_SPECS);
|
||||||
Content extSpecsBody = getContent("doclet.help.externalSpecifications.body",
|
Content extSpecsBody = getContent("doclet.help.externalSpecifications.body",
|
||||||
links.createLink(DocPaths.EXTERNAL_SPECS, resources.getText("doclet.External_Specifications")));
|
links.createLink(DocPaths.EXTERNAL_SPECS, resources.getText("doclet.External_Specifications")));
|
||||||
section.add(HtmlTree.P(extSpecsBody));
|
section.add(HtmlTree.P(extSpecsBody));
|
||||||
@ -388,12 +373,12 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
// Index
|
// Index
|
||||||
if (options.createIndex()) {
|
if (options.createIndex()) {
|
||||||
if (!configuration.packages.isEmpty()) {
|
if (!configuration.packages.isEmpty()) {
|
||||||
section = newHelpSection(getContent("doclet.help.all_packages.head"), PageMode.ALL_PACKAGES, subTOC)
|
section = newHelpSection(getContent("doclet.help.all_packages.head"), PageMode.ALL_PACKAGES)
|
||||||
.add(HtmlTree.P(getContent("doclet.help.all_packages.body", allPackagesLink)));
|
.add(HtmlTree.P(getContent("doclet.help.all_packages.body", allPackagesLink)));
|
||||||
pageKindsSection.add(section);
|
pageKindsSection.add(section);
|
||||||
}
|
}
|
||||||
|
|
||||||
section = newHelpSection(getContent("doclet.help.all_classes.head"), PageMode.ALL_CLASSES, subTOC)
|
section = newHelpSection(getContent("doclet.help.all_classes.head"), PageMode.ALL_CLASSES)
|
||||||
.add(HtmlTree.P(getContent("doclet.help.all_classes.body", allClassesLink)));
|
.add(HtmlTree.P(getContent("doclet.help.all_classes.body", allClassesLink)));
|
||||||
pageKindsSection.add(section);
|
pageKindsSection.add(section);
|
||||||
|
|
||||||
@ -403,14 +388,11 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
links.add(", ");
|
links.add(", ");
|
||||||
}
|
}
|
||||||
links.add(allClassesLink);
|
links.add(allClassesLink);
|
||||||
section = newHelpSection(getContent("doclet.help.index.head"), PageMode.INDEX, subTOC)
|
section = newHelpSection(getContent("doclet.help.index.head"), PageMode.INDEX)
|
||||||
.add(HtmlTree.P(getContent("doclet.help.index.body", indexLink, links)));
|
.add(HtmlTree.P(getContent("doclet.help.index.body", indexLink, links)));
|
||||||
pageKindsSection.add(section);
|
pageKindsSection.add(section);
|
||||||
}
|
}
|
||||||
|
tableOfContents.popNestedList();
|
||||||
mainTOC.add(HtmlTree.LI(new ContentBuilder(
|
|
||||||
links.createLink(DocLink.fragment(HtmlIds.HELP_PAGES.name()), pageKindsHeading),
|
|
||||||
Text.of(": "), subTOC)));
|
|
||||||
|
|
||||||
return pageKindsSection;
|
return pageKindsSection;
|
||||||
}
|
}
|
||||||
@ -427,17 +409,16 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
return contents.getContent(key, arg1, arg2);
|
return contents.getContent(key, arg1, arg2);
|
||||||
}
|
}
|
||||||
|
|
||||||
private HtmlTree newHelpSection(Content headingContent, HtmlTree toc, HtmlId id) {
|
private HtmlTree newHelpSection(Content headingContent, HtmlId id) {
|
||||||
Content link = links.createLink(DocLink.fragment(id.name()), headingContent);
|
tableOfContents.addLink(id, headingContent);
|
||||||
toc.add(HtmlTree.LI(link));
|
|
||||||
|
|
||||||
return HtmlTree.SECTION(HtmlStyle.helpSection,
|
return HtmlTree.SECTION(HtmlStyle.helpSection,
|
||||||
HtmlTree.HEADING(Headings.SUB_HEADING, headingContent))
|
HtmlTree.HEADING(Headings.SUB_HEADING, headingContent))
|
||||||
.setId(id);
|
.setId(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
private HtmlTree newHelpSection(Content headingContent, Navigation.PageMode pm, HtmlTree toc) {
|
private HtmlTree newHelpSection(Content headingContent, Navigation.PageMode pm) {
|
||||||
return newHelpSection(headingContent, toc, htmlIds.forPage(pm));
|
return newHelpSection(headingContent, htmlIds.forPage(pm));
|
||||||
}
|
}
|
||||||
|
|
||||||
private HtmlTree newHelpSectionList(Content first, Content... rest) {
|
private HtmlTree newHelpSectionList(Content first, Content... rest) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -233,7 +233,6 @@ public class HtmlDoclet extends AbstractDoclet {
|
|||||||
messages.error("doclet.No_Non_Deprecated_Classes_To_Document");
|
messages.error("doclet.No_Non_Deprecated_Classes_To_Document");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
boolean nodeprecated = options.noDeprecated();
|
|
||||||
copyFile(options.helpFile(), DocPath.empty);
|
copyFile(options.helpFile(), DocPath.empty);
|
||||||
copyFile(options.stylesheetFile(), DocPaths.RESOURCE_FILES);
|
copyFile(options.stylesheetFile(), DocPaths.RESOURCE_FILES);
|
||||||
for (String stylesheet : options.additionalStylesheets()) {
|
for (String stylesheet : options.additionalStylesheets()) {
|
||||||
@ -309,7 +308,7 @@ public class HtmlDoclet extends AbstractDoclet {
|
|||||||
if (options.stylesheetFile().length() == 0) {
|
if (options.stylesheetFile().length() == 0) {
|
||||||
copyResource(DocPaths.STYLESHEET, DocPaths.RESOURCE_FILES.resolve(DocPaths.STYLESHEET), true);
|
copyResource(DocPaths.STYLESHEET, DocPaths.RESOURCE_FILES.resolve(DocPaths.STYLESHEET), true);
|
||||||
}
|
}
|
||||||
copyResource(DocPaths.SCRIPT_JS, DocPaths.SCRIPT_FILES.resolve(DocPaths.SCRIPT_JS), true);
|
copyResource(DocPaths.SCRIPT_JS_TEMPLATE, DocPaths.SCRIPT_FILES.resolve(DocPaths.SCRIPT_JS), true);
|
||||||
copyResource(DocPaths.CLIPBOARD_SVG, DocPaths.RESOURCE_FILES.resolve(DocPaths.CLIPBOARD_SVG), true);
|
copyResource(DocPaths.CLIPBOARD_SVG, DocPaths.RESOURCE_FILES.resolve(DocPaths.CLIPBOARD_SVG), true);
|
||||||
copyResource(DocPaths.LINK_SVG, DocPaths.RESOURCE_FILES.resolve(DocPaths.LINK_SVG), true);
|
copyResource(DocPaths.LINK_SVG, DocPaths.RESOURCE_FILES.resolve(DocPaths.LINK_SVG), true);
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,6 +31,7 @@ import java.util.Comparator;
|
|||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
import java.util.LinkedList;
|
import java.util.LinkedList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.ListIterator;
|
import java.util.ListIterator;
|
||||||
@ -70,6 +71,7 @@ import com.sun.source.doctree.EndElementTree;
|
|||||||
import com.sun.source.doctree.EntityTree;
|
import com.sun.source.doctree.EntityTree;
|
||||||
import com.sun.source.doctree.ErroneousTree;
|
import com.sun.source.doctree.ErroneousTree;
|
||||||
import com.sun.source.doctree.EscapeTree;
|
import com.sun.source.doctree.EscapeTree;
|
||||||
|
import com.sun.source.doctree.IndexTree;
|
||||||
import com.sun.source.doctree.InheritDocTree;
|
import com.sun.source.doctree.InheritDocTree;
|
||||||
import com.sun.source.doctree.InlineTagTree;
|
import com.sun.source.doctree.InlineTagTree;
|
||||||
import com.sun.source.doctree.LinkTree;
|
import com.sun.source.doctree.LinkTree;
|
||||||
@ -82,11 +84,13 @@ import com.sun.source.util.SimpleDocTreeVisitor;
|
|||||||
import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder;
|
import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.Entity;
|
import jdk.javadoc.internal.doclets.formats.html.markup.Entity;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.Head;
|
import jdk.javadoc.internal.doclets.formats.html.markup.Head;
|
||||||
|
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlAttr;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlDocument;
|
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlDocument;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlId;
|
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlId;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle;
|
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.HtmlTree;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.Links;
|
import jdk.javadoc.internal.doclets.formats.html.markup.Links;
|
||||||
|
import jdk.javadoc.internal.doclets.formats.html.markup.ListBuilder;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.RawHtml;
|
import jdk.javadoc.internal.doclets.formats.html.markup.RawHtml;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.Script;
|
import jdk.javadoc.internal.doclets.formats.html.markup.Script;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.TagName;
|
import jdk.javadoc.internal.doclets.formats.html.markup.TagName;
|
||||||
@ -162,6 +166,8 @@ public abstract class HtmlDocletWriter {
|
|||||||
|
|
||||||
private final Set<String> headingIds = new HashSet<>();
|
private final Set<String> headingIds = new HashSet<>();
|
||||||
|
|
||||||
|
protected final TableOfContents tableOfContents;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* To check whether the repeated annotations is documented or not.
|
* To check whether the repeated annotations is documented or not.
|
||||||
*/
|
*/
|
||||||
@ -217,6 +223,7 @@ public abstract class HtmlDocletWriter {
|
|||||||
this.pathToRoot = path.parent().invert();
|
this.pathToRoot = path.parent().invert();
|
||||||
this.docPaths = configuration.docPaths;
|
this.docPaths = configuration.docPaths;
|
||||||
this.mainBodyScript = new Script();
|
this.mainBodyScript = new Script();
|
||||||
|
this.tableOfContents = new TableOfContents(this);
|
||||||
|
|
||||||
if (generating) {
|
if (generating) {
|
||||||
writeGenerating();
|
writeGenerating();
|
||||||
@ -1465,6 +1472,15 @@ public abstract class HtmlDocletWriter {
|
|||||||
sb.append(text.getBody());
|
sb.append(text.getBody());
|
||||||
} else if (docTree instanceof LiteralTree literal) {
|
} else if (docTree instanceof LiteralTree literal) {
|
||||||
sb.append(literal.getBody().getBody());
|
sb.append(literal.getBody().getBody());
|
||||||
|
} else if (docTree instanceof IndexTree index) {
|
||||||
|
DocTree searchTerm = index.getSearchTerm();
|
||||||
|
String tagText = (searchTerm instanceof TextTree tt) ? tt.getBody() : "";
|
||||||
|
if (tagText.charAt(0) == '"' && tagText.charAt(tagText.length() - 1) == '"') {
|
||||||
|
tagText = tagText.substring(1, tagText.length() - 1);
|
||||||
|
}
|
||||||
|
sb.append(tagText);
|
||||||
|
} else if (docTree instanceof EntityTree entity) {
|
||||||
|
sb.append(utils.docTrees.getCharacters(entity));
|
||||||
} else if (docTree instanceof LinkTree link) {
|
} else if (docTree instanceof LinkTree link) {
|
||||||
var label = link.getLabel();
|
var label = link.getLabel();
|
||||||
sb.append(label.isEmpty() ? link.getReference().getSignature() : label.toString());
|
sb.append(label.isEmpty() ? link.getReference().getSignature() : label.toString());
|
||||||
@ -1483,6 +1499,8 @@ public abstract class HtmlDocletWriter {
|
|||||||
HtmlId htmlId = htmlIds.forHeading(headingContent, headingIds);
|
HtmlId htmlId = htmlIds.forHeading(headingContent, headingIds);
|
||||||
id = htmlId.name();
|
id = htmlId.name();
|
||||||
attrs.add("id=\"").add(htmlId.name()).add("\"");
|
attrs.add("id=\"").add(htmlId.name()).add("\"");
|
||||||
|
} else {
|
||||||
|
headingIds.add(id);
|
||||||
}
|
}
|
||||||
// Generate index item
|
// Generate index item
|
||||||
if (!headingContent.isEmpty() && configuration.indexBuilder != null) {
|
if (!headingContent.isEmpty() && configuration.indexBuilder != null) {
|
||||||
@ -1493,6 +1511,10 @@ public abstract class HtmlDocletWriter {
|
|||||||
new DocLink(path, id));
|
new DocLink(path, id));
|
||||||
configuration.indexBuilder.add(item);
|
configuration.indexBuilder.add(item);
|
||||||
}
|
}
|
||||||
|
// Record second-level headings for use in table of contents
|
||||||
|
if (tableOfContents != null && node.getName().toString().equalsIgnoreCase("h2")) {
|
||||||
|
tableOfContents.addLink(HtmlId.of(id), Text.of(headingContent));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2021, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2021, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -67,6 +67,7 @@ public class HtmlIds {
|
|||||||
private final HtmlConfiguration configuration;
|
private final HtmlConfiguration configuration;
|
||||||
private final Utils utils;
|
private final Utils utils;
|
||||||
|
|
||||||
|
static final HtmlId TOP_OF_PAGE = HtmlId.of(""); // empty fragment/id indicates top of page
|
||||||
static final HtmlId ALL_CLASSES_TABLE = HtmlId.of("all-classes-table");
|
static final HtmlId ALL_CLASSES_TABLE = HtmlId.of("all-classes-table");
|
||||||
static final HtmlId ALL_MODULES_TABLE = HtmlId.of("all-modules-table");
|
static final HtmlId ALL_MODULES_TABLE = HtmlId.of("all-modules-table");
|
||||||
static final HtmlId ALL_PACKAGES_TABLE = HtmlId.of("all-packages-table");
|
static final HtmlId ALL_PACKAGES_TABLE = HtmlId.of("all-packages-table");
|
||||||
@ -90,7 +91,6 @@ public class HtmlIds {
|
|||||||
static final HtmlId METHOD_SUMMARY_TABLE = HtmlId.of("method-summary-table");
|
static final HtmlId METHOD_SUMMARY_TABLE = HtmlId.of("method-summary-table");
|
||||||
static final HtmlId MODULES = HtmlId.of("modules-summary");
|
static final HtmlId MODULES = HtmlId.of("modules-summary");
|
||||||
static final HtmlId MODULE_DESCRIPTION = HtmlId.of("module-description");
|
static final HtmlId MODULE_DESCRIPTION = HtmlId.of("module-description");
|
||||||
static final HtmlId NAVBAR_SUB_LIST = HtmlId.of("navbar-sub-list");
|
|
||||||
static final HtmlId NAVBAR_TOGGLE_BUTTON = HtmlId.of("navbar-toggle-button");
|
static final HtmlId NAVBAR_TOGGLE_BUTTON = HtmlId.of("navbar-toggle-button");
|
||||||
static final HtmlId NAVBAR_TOP = HtmlId.of("navbar-top");
|
static final HtmlId NAVBAR_TOP = HtmlId.of("navbar-top");
|
||||||
static final HtmlId NAVBAR_TOP_FIRSTROW = HtmlId.of("navbar-top-firstrow");
|
static final HtmlId NAVBAR_TOP_FIRSTROW = HtmlId.of("navbar-top-firstrow");
|
||||||
@ -101,7 +101,7 @@ public class HtmlIds {
|
|||||||
static final HtmlId PROPERTY_DETAIL = HtmlId.of("property-detail");
|
static final HtmlId PROPERTY_DETAIL = HtmlId.of("property-detail");
|
||||||
static final HtmlId PROPERTY_SUMMARY = HtmlId.of("property-summary");
|
static final HtmlId PROPERTY_SUMMARY = HtmlId.of("property-summary");
|
||||||
static final HtmlId RELATED_PACKAGE_SUMMARY = HtmlId.of("related-package-summary");
|
static final HtmlId RELATED_PACKAGE_SUMMARY = HtmlId.of("related-package-summary");
|
||||||
static final HtmlId RESET_BUTTON = HtmlId.of("reset-button");
|
static final HtmlId RESET_SEARCH = HtmlId.of("reset-search");
|
||||||
static final HtmlId SEARCH_INPUT = HtmlId.of("search-input");
|
static final HtmlId SEARCH_INPUT = HtmlId.of("search-input");
|
||||||
static final HtmlId SERVICES = HtmlId.of("services-summary");
|
static final HtmlId SERVICES = HtmlId.of("services-summary");
|
||||||
static final HtmlId SKIP_NAVBAR_TOP = HtmlId.of("skip-navbar-top");
|
static final HtmlId SKIP_NAVBAR_TOP = HtmlId.of("skip-navbar-top");
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -29,7 +29,6 @@ import java.util.ArrayList;
|
|||||||
import java.util.EnumSet;
|
import java.util.EnumSet;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.function.Consumer;
|
|
||||||
|
|
||||||
import javax.lang.model.element.AnnotationMirror;
|
import javax.lang.model.element.AnnotationMirror;
|
||||||
import javax.lang.model.element.Element;
|
import javax.lang.model.element.Element;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -85,7 +85,7 @@ public class HtmlLinkInfo {
|
|||||||
private Kind context = Kind.PLAIN;
|
private Kind context = Kind.PLAIN;
|
||||||
|
|
||||||
// The fragment of the link.
|
// The fragment of the link.
|
||||||
private String fragment = "";
|
private String fragment = null;
|
||||||
|
|
||||||
// The member this link points to (if any).
|
// The member this link points to (if any).
|
||||||
private Element targetMember;
|
private Element targetMember;
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -285,9 +285,9 @@ public class IndexWriter extends HtmlDocletWriter {
|
|||||||
var div = HtmlTree.DIV(HtmlStyle.deprecationBlock);
|
var div = HtmlTree.DIV(HtmlStyle.deprecationBlock);
|
||||||
if (utils.isDeprecated(element)) {
|
if (utils.isDeprecated(element)) {
|
||||||
div.add(span);
|
div.add(span);
|
||||||
List<? extends DeprecatedTree> tags = utils.getDeprecatedTrees(element);
|
var tags = utils.getDeprecatedTrees(element);
|
||||||
if (!tags.isEmpty())
|
if (!tags.isEmpty())
|
||||||
addInlineDeprecatedComment(element, tags.get(0), div);
|
addInlineDeprecatedComment(element, tags.getFirst(), div);
|
||||||
content.add(div);
|
content.add(div);
|
||||||
} else {
|
} else {
|
||||||
TypeElement encl = utils.getEnclosingTypeElement(element);
|
TypeElement encl = utils.getEnclosingTypeElement(element);
|
||||||
@ -350,7 +350,7 @@ public class IndexWriter extends HtmlDocletWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
content.add(new HtmlTree(TagName.BR));
|
content.add(new HtmlTree(TagName.BR));
|
||||||
List<Content> pageLinks = Stream.of(IndexItem.Category.values())
|
var pageLinks = Stream.of(IndexItem.Category.values())
|
||||||
.flatMap(c -> mainIndex.getItems(c).stream())
|
.flatMap(c -> mainIndex.getItems(c).stream())
|
||||||
.filter(i -> !(i.isElementItem() || i.isTagItem()))
|
.filter(i -> !(i.isElementItem() || i.isTagItem()))
|
||||||
.sorted((i1,i2)-> utils.compareStrings(i1.getLabel(), i2.getLabel()))
|
.sorted((i1,i2)-> utils.compareStrings(i1.getLabel(), i2.getLabel()))
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -101,6 +101,8 @@ public class MethodWriter extends AbstractExecutableMemberWriter {
|
|||||||
if (!methods.isEmpty()) {
|
if (!methods.isEmpty()) {
|
||||||
Content methodDetailsHeader = getMethodDetailsHeader(detailsList);
|
Content methodDetailsHeader = getMethodDetailsHeader(detailsList);
|
||||||
Content memberList = writer.getMemberList();
|
Content memberList = writer.getMemberList();
|
||||||
|
writer.tableOfContents.addLink(HtmlIds.METHOD_DETAIL, contents.methodDetailLabel);
|
||||||
|
writer.tableOfContents.pushNestedList();
|
||||||
|
|
||||||
for (Element method : methods) {
|
for (Element method : methods) {
|
||||||
currentMethod = (ExecutableElement)method;
|
currentMethod = (ExecutableElement)method;
|
||||||
@ -114,9 +116,13 @@ public class MethodWriter extends AbstractExecutableMemberWriter {
|
|||||||
buildTagInfo(div);
|
buildTagInfo(div);
|
||||||
methodContent.add(div);
|
methodContent.add(div);
|
||||||
memberList.add(writer.getMemberListItem(methodContent));
|
memberList.add(writer.getMemberListItem(methodContent));
|
||||||
|
writer.tableOfContents.addLink(htmlIds.forMember(currentMethod),
|
||||||
|
Text.of(utils.getSimpleName(method)
|
||||||
|
+ utils.makeSignature(currentMethod, typeElement, false, true)));
|
||||||
}
|
}
|
||||||
Content methodDetails = getMethodDetails(methodDetailsHeader, memberList);
|
Content methodDetails = getMethodDetails(methodDetailsHeader, memberList);
|
||||||
detailsList.add(methodDetails);
|
detailsList.add(methodDetails);
|
||||||
|
writer.tableOfContents.popNestedList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2016, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -251,8 +251,11 @@ public class ModuleWriter extends HtmlDocletWriter {
|
|||||||
* be added
|
* be added
|
||||||
*/
|
*/
|
||||||
protected void buildModuleDescription(Content moduleContent) {
|
protected void buildModuleDescription(Content moduleContent) {
|
||||||
|
tableOfContents.addLink(HtmlIds.TOP_OF_PAGE, contents.navDescription);
|
||||||
if (!options.noComment()) {
|
if (!options.noComment()) {
|
||||||
|
tableOfContents.pushNestedList();
|
||||||
addModuleDescription(moduleContent);
|
addModuleDescription(moduleContent);
|
||||||
|
tableOfContents.popNestedList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -274,16 +277,10 @@ public class ModuleWriter extends HtmlDocletWriter {
|
|||||||
@Override
|
@Override
|
||||||
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
||||||
return super.getNavBar(pageMode, element)
|
return super.getNavBar(pageMode, element)
|
||||||
.setSubNavLinks(() -> List.of(
|
.setSubNavLinks(List.of(
|
||||||
links.createLink(HtmlIds.MODULE_DESCRIPTION, contents.navDescription,
|
links.createLink(pathToRoot.resolve(docPaths.moduleSummary(mdle)),
|
||||||
!utils.getFullBody(mdle).isEmpty() && !options.noComment()),
|
Text.of(mdle.getQualifiedName()),
|
||||||
links.createLink(HtmlIds.MODULES, contents.navModules,
|
HtmlStyle.currentSelection, "")));
|
||||||
display(requires) || display(indirectModules)),
|
|
||||||
links.createLink(HtmlIds.PACKAGES, contents.navPackages,
|
|
||||||
display(packages) || display(indirectPackages) || display(indirectOpenPackages)),
|
|
||||||
links.createLink(HtmlIds.SERVICES, contents.navServices,
|
|
||||||
displayServices(uses, usesTrees) || displayServices(provides.keySet(), providesTrees))
|
|
||||||
));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Content getContentHeader() {
|
protected Content getContentHeader() {
|
||||||
@ -536,6 +533,7 @@ public class ModuleWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
protected void addModulesSummary(Content summariesList) {
|
protected void addModulesSummary(Content summariesList) {
|
||||||
if (display(requires) || display(indirectModules)) {
|
if (display(requires) || display(indirectModules)) {
|
||||||
|
tableOfContents.addLink(HtmlIds.MODULES, contents.navModules);
|
||||||
TableHeader requiresTableHeader =
|
TableHeader requiresTableHeader =
|
||||||
new TableHeader(contents.modifierLabel, contents.moduleLabel,
|
new TableHeader(contents.modifierLabel, contents.moduleLabel,
|
||||||
contents.descriptionLabel);
|
contents.descriptionLabel);
|
||||||
@ -580,6 +578,7 @@ public class ModuleWriter extends HtmlDocletWriter {
|
|||||||
protected void addPackagesSummary(Content summariesList) {
|
protected void addPackagesSummary(Content summariesList) {
|
||||||
if (display(packages)
|
if (display(packages)
|
||||||
|| display(indirectPackages) || display(indirectOpenPackages)) {
|
|| display(indirectPackages) || display(indirectOpenPackages)) {
|
||||||
|
tableOfContents.addLink(HtmlIds.PACKAGES, contents.navPackages);
|
||||||
var section = HtmlTree.SECTION(HtmlStyle.packagesSummary)
|
var section = HtmlTree.SECTION(HtmlStyle.packagesSummary)
|
||||||
.setId(HtmlIds.PACKAGES);
|
.setId(HtmlIds.PACKAGES);
|
||||||
addSummaryHeader(MarkerComments.START_OF_PACKAGES_SUMMARY, contents.navPackages, section);
|
addSummaryHeader(MarkerComments.START_OF_PACKAGES_SUMMARY, contents.navPackages, section);
|
||||||
@ -750,6 +749,7 @@ public class ModuleWriter extends HtmlDocletWriter {
|
|||||||
boolean haveProvides = displayServices(provides.keySet(), providesTrees);
|
boolean haveProvides = displayServices(provides.keySet(), providesTrees);
|
||||||
|
|
||||||
if (haveProvides || haveUses) {
|
if (haveProvides || haveUses) {
|
||||||
|
tableOfContents.addLink(HtmlIds.SERVICES, contents.navServices);
|
||||||
var section = HtmlTree.SECTION(HtmlStyle.servicesSummary)
|
var section = HtmlTree.SECTION(HtmlStyle.servicesSummary)
|
||||||
.setId(HtmlIds.SERVICES);
|
.setId(HtmlIds.SERVICES);
|
||||||
addSummaryHeader(MarkerComments.START_OF_SERVICES_SUMMARY, contents.navServices, section);
|
addSummaryHeader(MarkerComments.START_OF_SERVICES_SUMMARY, contents.navServices, section);
|
||||||
@ -889,6 +889,7 @@ public class ModuleWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
protected void addModuleContent(Content source) {
|
protected void addModuleContent(Content source) {
|
||||||
bodyContents.addMainContent(source);
|
bodyContents.addMainContent(source);
|
||||||
|
bodyContents.setSideContent(tableOfContents.toContent(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void addModuleFooter() {
|
protected void addModuleFooter() {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2018, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -27,7 +27,6 @@ package jdk.javadoc.internal.doclets.formats.html;
|
|||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
import javax.lang.model.element.Element;
|
import javax.lang.model.element.Element;
|
||||||
import javax.lang.model.element.ModuleElement;
|
import javax.lang.model.element.ModuleElement;
|
||||||
@ -67,14 +66,9 @@ public class Navigation {
|
|||||||
private final DocPath pathToRoot;
|
private final DocPath pathToRoot;
|
||||||
private final Links links;
|
private final Links links;
|
||||||
private final PageMode documentedPage;
|
private final PageMode documentedPage;
|
||||||
private Content navLinkModule;
|
|
||||||
private Content navLinkPackage;
|
|
||||||
private Content navLinkClass;
|
|
||||||
private Content userHeader;
|
private Content userHeader;
|
||||||
private final String rowListTitle;
|
private final String rowListTitle;
|
||||||
private final Content searchLabel;
|
private List<Content> subNavLinks = List.of();
|
||||||
private final String searchPlaceholder;
|
|
||||||
private SubNavLinks subNavLinks;
|
|
||||||
|
|
||||||
public enum PageMode {
|
public enum PageMode {
|
||||||
ALL_CLASSES,
|
ALL_CLASSES,
|
||||||
@ -99,18 +93,6 @@ public class Navigation {
|
|||||||
USE
|
USE
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* An interface to provide links for the subnavigation area.
|
|
||||||
*/
|
|
||||||
public interface SubNavLinks {
|
|
||||||
/**
|
|
||||||
* {@return a list of links to display in the subnavigation area}
|
|
||||||
* Links should be wrapped in {@code HtmlTree.LI} elements as they are
|
|
||||||
* displayed within an unordered list.
|
|
||||||
*/
|
|
||||||
List<Content> getSubNavLinks();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a {@code Navigation} object for a specific file, to be written in a specific HTML
|
* Creates a {@code Navigation} object for a specific file, to be written in a specific HTML
|
||||||
* version.
|
* version.
|
||||||
@ -131,23 +113,6 @@ public class Navigation {
|
|||||||
this.pathToRoot = path.parent().invert();
|
this.pathToRoot = path.parent().invert();
|
||||||
this.links = new Links(path);
|
this.links = new Links(path);
|
||||||
this.rowListTitle = configuration.getDocResources().getText("doclet.Navigation");
|
this.rowListTitle = configuration.getDocResources().getText("doclet.Navigation");
|
||||||
this.searchLabel = contents.getContent("doclet.search");
|
|
||||||
this.searchPlaceholder = configuration.getDocResources().getText("doclet.search_placeholder");
|
|
||||||
}
|
|
||||||
|
|
||||||
public Navigation setNavLinkModule(Content navLinkModule) {
|
|
||||||
this.navLinkModule = navLinkModule;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Navigation setNavLinkPackage(Content navLinkPackage) {
|
|
||||||
this.navLinkPackage = navLinkPackage;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Navigation setNavLinkClass(Content navLinkClass) {
|
|
||||||
this.navLinkClass = navLinkClass;
|
|
||||||
return this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Navigation setUserHeader(Content userHeader) {
|
public Navigation setUserHeader(Content userHeader) {
|
||||||
@ -155,7 +120,7 @@ public class Navigation {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Navigation setSubNavLinks(SubNavLinks subNavLinks) {
|
public Navigation setSubNavLinks(List<Content> subNavLinks) {
|
||||||
this.subNavLinks = subNavLinks;
|
this.subNavLinks = subNavLinks;
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
@ -169,35 +134,28 @@ public class Navigation {
|
|||||||
switch (documentedPage) {
|
switch (documentedPage) {
|
||||||
case OVERVIEW:
|
case OVERVIEW:
|
||||||
addActivePageLink(target, contents.overviewLabel, options.createOverview());
|
addActivePageLink(target, contents.overviewLabel, options.createOverview());
|
||||||
addModuleLink(target);
|
|
||||||
addPackageLink(target);
|
|
||||||
addPageLabel(target, contents.classLabel, true);
|
|
||||||
addPageLabel(target, contents.useLabel, options.classUse());
|
|
||||||
addTreeLink(target);
|
addTreeLink(target);
|
||||||
addPreviewLink(target);
|
addPreviewLink(target);
|
||||||
addNewLink(target);
|
addNewLink(target);
|
||||||
addDeprecatedLink(target);
|
addDeprecatedLink(target);
|
||||||
addIndexLink(target);
|
addIndexLink(target);
|
||||||
|
addSearchLink(target);
|
||||||
addHelpLink(target);
|
addHelpLink(target);
|
||||||
break;
|
break;
|
||||||
case MODULE:
|
case MODULE:
|
||||||
addOverviewLink(target);
|
addOverviewLink(target);
|
||||||
addActivePageLink(target, contents.moduleLabel, configuration.showModules);
|
addActivePageLink(target, contents.moduleLabel, configuration.showModules);
|
||||||
addPackageLink(target);
|
|
||||||
addPageLabel(target, contents.classLabel, true);
|
|
||||||
addPageLabel(target, contents.useLabel, options.classUse());
|
|
||||||
addTreeLink(target);
|
addTreeLink(target);
|
||||||
addPreviewLink(target);
|
addPreviewLink(target);
|
||||||
addNewLink(target);
|
addNewLink(target);
|
||||||
addDeprecatedLink(target);
|
addDeprecatedLink(target);
|
||||||
addIndexLink(target);
|
addIndexLink(target);
|
||||||
|
addSearchLink(target);
|
||||||
addHelpLink(target);
|
addHelpLink(target);
|
||||||
break;
|
break;
|
||||||
case PACKAGE:
|
case PACKAGE:
|
||||||
addOverviewLink(target);
|
addOverviewLink(target);
|
||||||
addModuleOfElementLink(target);
|
|
||||||
addActivePageLink(target, contents.packageLabel, true);
|
addActivePageLink(target, contents.packageLabel, true);
|
||||||
addPageLabel(target, contents.classLabel, true);
|
|
||||||
if (options.classUse()) {
|
if (options.classUse()) {
|
||||||
addItemToList(target, links.createLink(DocPaths.PACKAGE_USE,
|
addItemToList(target, links.createLink(DocPaths.PACKAGE_USE,
|
||||||
contents.useLabel, ""));
|
contents.useLabel, ""));
|
||||||
@ -210,12 +168,11 @@ public class Navigation {
|
|||||||
addNewLink(target);
|
addNewLink(target);
|
||||||
addDeprecatedLink(target);
|
addDeprecatedLink(target);
|
||||||
addIndexLink(target);
|
addIndexLink(target);
|
||||||
|
addSearchLink(target);
|
||||||
addHelpLink(target);
|
addHelpLink(target);
|
||||||
break;
|
break;
|
||||||
case CLASS:
|
case CLASS:
|
||||||
addOverviewLink(target);
|
addOverviewLink(target);
|
||||||
addModuleOfElementLink(target);
|
|
||||||
addPackageSummaryLink(target);
|
|
||||||
addActivePageLink(target, contents.classLabel, true);
|
addActivePageLink(target, contents.classLabel, true);
|
||||||
if (options.classUse()) {
|
if (options.classUse()) {
|
||||||
addItemToList(target, links.createLink(DocPaths.CLASS_USE.resolve(path.basename()),
|
addItemToList(target, links.createLink(DocPaths.CLASS_USE.resolve(path.basename()),
|
||||||
@ -229,48 +186,49 @@ public class Navigation {
|
|||||||
addNewLink(target);
|
addNewLink(target);
|
||||||
addDeprecatedLink(target);
|
addDeprecatedLink(target);
|
||||||
addIndexLink(target);
|
addIndexLink(target);
|
||||||
|
addSearchLink(target);
|
||||||
addHelpLink(target);
|
addHelpLink(target);
|
||||||
break;
|
break;
|
||||||
case USE:
|
case USE:
|
||||||
addOverviewLink(target);
|
addOverviewLink(target);
|
||||||
addModuleOfElementLink(target);
|
// Class-use page is still generated for deprecated classes with
|
||||||
if (element instanceof PackageElement) {
|
// -nodeprecated option, make sure not to link to non-existent page.
|
||||||
addPackageSummaryLink(target);
|
if (!options.noDeprecated() || !configuration.utils.isDeprecated(element)) {
|
||||||
addPageLabel(target, contents.classLabel, true);
|
addPageElementLink(target);
|
||||||
} else {
|
|
||||||
addPackageOfElementLink(target);
|
|
||||||
addItemToList(target, navLinkClass);
|
|
||||||
}
|
}
|
||||||
addActivePageLink(target, contents.useLabel, options.classUse());
|
addActivePageLink(target, contents.useLabel, options.classUse());
|
||||||
if (element instanceof PackageElement) {
|
if (options.createTree()) {
|
||||||
addItemToList(target, links.createLink(DocPaths.PACKAGE_TREE, contents.treeLabel));
|
if (configuration.utils.isPackage(element)) {
|
||||||
} else {
|
addItemToList(target, links.createLink(DocPaths.PACKAGE_TREE, contents.treeLabel));
|
||||||
addItemToList(target, configuration.utils.isEnclosingPackageIncluded((TypeElement) element)
|
} else {
|
||||||
? links.createLink(DocPath.parent.resolve(DocPaths.PACKAGE_TREE), contents.treeLabel)
|
addItemToList(target, configuration.utils.isEnclosingPackageIncluded((TypeElement) element)
|
||||||
: links.createLink(pathToRoot.resolve(DocPaths.OVERVIEW_TREE), contents.treeLabel));
|
? links.createLink(DocPath.parent.resolve(DocPaths.PACKAGE_TREE), contents.treeLabel)
|
||||||
|
: links.createLink(pathToRoot.resolve(DocPaths.OVERVIEW_TREE), contents.treeLabel));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
addPreviewLink(target);
|
addPreviewLink(target);
|
||||||
addNewLink(target);
|
addNewLink(target);
|
||||||
addDeprecatedLink(target);
|
addDeprecatedLink(target);
|
||||||
addIndexLink(target);
|
addIndexLink(target);
|
||||||
|
addSearchLink(target);
|
||||||
addHelpLink(target);
|
addHelpLink(target);
|
||||||
break;
|
break;
|
||||||
case TREE:
|
case TREE:
|
||||||
addOverviewLink(target);
|
addOverviewLink(target);
|
||||||
if (element == null) {
|
if (element != null && !configuration.utils.isModule(element)) {
|
||||||
addPageLabel(target, contents.moduleLabel, configuration.showModules);
|
addPageElementLink(target);
|
||||||
addPageLabel(target, contents.packageLabel, true);
|
if (options.classUse()) {
|
||||||
} else {
|
if (configuration.utils.isPackage(element) || configuration.utils.isTypeElement(element)) {
|
||||||
addModuleOfElementLink(target);
|
addItemToList(target, links.createLink(DocPaths.PACKAGE_USE, contents.useLabel));
|
||||||
addPackageSummaryLink(target);
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
addPageLabel(target, contents.classLabel, true);
|
|
||||||
addPageLabel(target, contents.useLabel, options.classUse());
|
|
||||||
addActivePageLink(target, contents.treeLabel, options.createTree());
|
addActivePageLink(target, contents.treeLabel, options.createTree());
|
||||||
addPreviewLink(target);
|
addPreviewLink(target);
|
||||||
addNewLink(target);
|
addNewLink(target);
|
||||||
addDeprecatedLink(target);
|
addDeprecatedLink(target);
|
||||||
addIndexLink(target);
|
addIndexLink(target);
|
||||||
|
addSearchLink(target);
|
||||||
addHelpLink(target);
|
addHelpLink(target);
|
||||||
break;
|
break;
|
||||||
case DEPRECATED:
|
case DEPRECATED:
|
||||||
@ -278,11 +236,8 @@ public class Navigation {
|
|||||||
case HELP:
|
case HELP:
|
||||||
case PREVIEW:
|
case PREVIEW:
|
||||||
case NEW:
|
case NEW:
|
||||||
|
case SEARCH:
|
||||||
addOverviewLink(target);
|
addOverviewLink(target);
|
||||||
addModuleLink(target);
|
|
||||||
addPackageLink(target);
|
|
||||||
addPageLabel(target, contents.classLabel, true);
|
|
||||||
addPageLabel(target, contents.useLabel, options.classUse());
|
|
||||||
addTreeLink(target);
|
addTreeLink(target);
|
||||||
if (documentedPage == PageMode.PREVIEW) {
|
if (documentedPage == PageMode.PREVIEW) {
|
||||||
addActivePageLink(target, contents.previewLabel,
|
addActivePageLink(target, contents.previewLabel,
|
||||||
@ -307,6 +262,11 @@ public class Navigation {
|
|||||||
} else {
|
} else {
|
||||||
addIndexLink(target);
|
addIndexLink(target);
|
||||||
}
|
}
|
||||||
|
if (documentedPage == PageMode.SEARCH) {
|
||||||
|
addActivePageLink(target, contents.searchLabel, options.createIndex());
|
||||||
|
} else {
|
||||||
|
addSearchLink(target);
|
||||||
|
}
|
||||||
if (documentedPage == PageMode.HELP) {
|
if (documentedPage == PageMode.HELP) {
|
||||||
addActivePageLink(target, contents.helpLabel, !options.noHelp());
|
addActivePageLink(target, contents.helpLabel, !options.noHelp());
|
||||||
} else {
|
} else {
|
||||||
@ -319,31 +279,40 @@ public class Navigation {
|
|||||||
case EXTERNAL_SPECS:
|
case EXTERNAL_SPECS:
|
||||||
case RESTRICTED:
|
case RESTRICTED:
|
||||||
case SERIALIZED_FORM:
|
case SERIALIZED_FORM:
|
||||||
case SEARCH:
|
|
||||||
case SYSTEM_PROPERTIES:
|
case SYSTEM_PROPERTIES:
|
||||||
addOverviewLink(target);
|
addOverviewLink(target);
|
||||||
addModuleLink(target);
|
|
||||||
addPackageLink(target);
|
|
||||||
addPageLabel(target, contents.classLabel, true);
|
|
||||||
addPageLabel(target, contents.useLabel, options.classUse());
|
|
||||||
addTreeLink(target);
|
addTreeLink(target);
|
||||||
addPreviewLink(target);
|
addPreviewLink(target);
|
||||||
addNewLink(target);
|
addNewLink(target);
|
||||||
addDeprecatedLink(target);
|
addDeprecatedLink(target);
|
||||||
addIndexLink(target);
|
addIndexLink(target);
|
||||||
|
addSearchLink(target);
|
||||||
addHelpLink(target);
|
addHelpLink(target);
|
||||||
break;
|
break;
|
||||||
case DOC_FILE:
|
case DOC_FILE:
|
||||||
addOverviewLink(target);
|
addOverviewLink(target);
|
||||||
addModuleOfElementLink(target);
|
if (element != null) {
|
||||||
addItemToList(target, navLinkPackage);
|
addPageElementLink(target);
|
||||||
addPageLabel(target, contents.classLabel, true);
|
if (options.classUse()) {
|
||||||
addPageLabel(target, contents.useLabel, options.classUse());
|
if (configuration.utils.isPackage(element)) {
|
||||||
addTreeLink(target);
|
addItemToList(target, links.createLink(pathToRoot.resolve(
|
||||||
|
configuration.docPaths.forPackage((PackageElement) element)
|
||||||
|
.resolve(DocPaths.PACKAGE_USE)), contents.useLabel));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (options.createTree() && configuration.utils.isPackage(element)) {
|
||||||
|
addItemToList(target, links.createLink(pathToRoot.resolve(
|
||||||
|
configuration.docPaths.forPackage((PackageElement) element)
|
||||||
|
.resolve(DocPaths.PACKAGE_TREE)), contents.treeLabel));
|
||||||
|
} else {
|
||||||
|
addTreeLink(target);
|
||||||
|
}
|
||||||
|
}
|
||||||
addPreviewLink(target);
|
addPreviewLink(target);
|
||||||
addNewLink(target);
|
addNewLink(target);
|
||||||
addDeprecatedLink(target);
|
addDeprecatedLink(target);
|
||||||
addIndexLink(target);
|
addIndexLink(target);
|
||||||
|
addSearchLink(target);
|
||||||
addHelpLink(target);
|
addHelpLink(target);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -355,59 +324,11 @@ public class Navigation {
|
|||||||
* Adds the summary links to the subnavigation.
|
* Adds the summary links to the subnavigation.
|
||||||
*
|
*
|
||||||
* @param target the content to which the subnavigation will be added
|
* @param target the content to which the subnavigation will be added
|
||||||
* @param nested whether to create a flat or nested list
|
|
||||||
*/
|
*/
|
||||||
private void addSummaryLinks(Content target, boolean nested) {
|
private void addSummaryLinks(Content target) {
|
||||||
switch (documentedPage) {
|
List<? extends Content> listContents = subNavLinks.stream().map(HtmlTree::LI).toList();
|
||||||
case MODULE, PACKAGE, CLASS, HELP -> {
|
if (!listContents.isEmpty()) {
|
||||||
List<? extends Content> listContents = subNavLinks.getSubNavLinks()
|
addListToNav(listContents, target);
|
||||||
.stream().map(HtmlTree::LI).toList();
|
|
||||||
if (!listContents.isEmpty()) {
|
|
||||||
Content label = switch (documentedPage) {
|
|
||||||
case MODULE -> contents.moduleSubNavLabel;
|
|
||||||
case PACKAGE -> contents.packageSubNavLabel;
|
|
||||||
case CLASS -> contents.summaryLabel;
|
|
||||||
case HELP -> contents.helpSubNavLabel;
|
|
||||||
default -> Text.EMPTY;
|
|
||||||
};
|
|
||||||
if (nested) {
|
|
||||||
target.add(HtmlTree.LI(HtmlTree.P(label))
|
|
||||||
.add(new HtmlTree(TagName.UL).add(listContents)));
|
|
||||||
} else {
|
|
||||||
target.add(HtmlTree.LI(label).add(Entity.NO_BREAK_SPACE));
|
|
||||||
addListToNav(listContents, target);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Adds the detail links to subnavigation.
|
|
||||||
*
|
|
||||||
* @param target the content to which the links will be added
|
|
||||||
* @param nested whether to create a flat or nested list
|
|
||||||
*/
|
|
||||||
private void addDetailLinks(Content target, boolean nested) {
|
|
||||||
if (documentedPage == PageMode.CLASS) {
|
|
||||||
List<Content> listContents = new ArrayList<>();
|
|
||||||
VisibleMemberTable vmt = configuration.getVisibleMemberTable((TypeElement) element);
|
|
||||||
Set<VisibleMemberTable.Kind> detailSet = VisibleMemberTable.Kind.forDetailsOf(element.getKind());
|
|
||||||
for (VisibleMemberTable.Kind kind : detailSet) {
|
|
||||||
addTypeDetailLink(kind, !vmt.getVisibleMembers(kind).isEmpty(), listContents);
|
|
||||||
}
|
|
||||||
if (!listContents.isEmpty()) {
|
|
||||||
if (nested) {
|
|
||||||
var li = HtmlTree.LI(HtmlTree.P(contents.detailLabel));
|
|
||||||
li.add(new HtmlTree(TagName.UL).add(listContents));
|
|
||||||
target.add(li);
|
|
||||||
} else {
|
|
||||||
var li = HtmlTree.LI(contents.detailLabel);
|
|
||||||
li.add(Entity.NO_BREAK_SPACE);
|
|
||||||
target.add(li);
|
|
||||||
addListToNav(listContents, target);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -420,12 +341,12 @@ public class Navigation {
|
|||||||
*/
|
*/
|
||||||
protected void addTypeDetailLink(VisibleMemberTable.Kind kind, boolean link, List<Content> listContents) {
|
protected void addTypeDetailLink(VisibleMemberTable.Kind kind, boolean link, List<Content> listContents) {
|
||||||
addContentToList(listContents, switch (kind) {
|
addContentToList(listContents, switch (kind) {
|
||||||
case CONSTRUCTORS -> links.createLink(HtmlIds.CONSTRUCTOR_DETAIL, contents.navConstructor, link);
|
case CONSTRUCTORS -> links.createLinkOrLabel(HtmlIds.CONSTRUCTOR_DETAIL, contents.navConstructor, link);
|
||||||
case ENUM_CONSTANTS -> links.createLink(HtmlIds.ENUM_CONSTANT_DETAIL, contents.navEnum, link);
|
case ENUM_CONSTANTS -> links.createLinkOrLabel(HtmlIds.ENUM_CONSTANT_DETAIL, contents.navEnum, link);
|
||||||
case FIELDS -> links.createLink(HtmlIds.FIELD_DETAIL, contents.navField, link);
|
case FIELDS -> links.createLinkOrLabel(HtmlIds.FIELD_DETAIL, contents.navField, link);
|
||||||
case METHODS -> links.createLink(HtmlIds.METHOD_DETAIL, contents.navMethod, link);
|
case METHODS -> links.createLinkOrLabel(HtmlIds.METHOD_DETAIL, contents.navMethod, link);
|
||||||
case PROPERTIES -> links.createLink(HtmlIds.PROPERTY_DETAIL, contents.navProperty, link);
|
case PROPERTIES -> links.createLinkOrLabel(HtmlIds.PROPERTY_DETAIL, contents.navProperty, link);
|
||||||
case ANNOTATION_TYPE_MEMBER -> links.createLink(HtmlIds.ANNOTATION_TYPE_ELEMENT_DETAIL,
|
case ANNOTATION_TYPE_MEMBER -> links.createLinkOrLabel(HtmlIds.ANNOTATION_TYPE_ELEMENT_DETAIL,
|
||||||
contents.navAnnotationTypeMember, link);
|
contents.navAnnotationTypeMember, link);
|
||||||
default -> Text.EMPTY;
|
default -> Text.EMPTY;
|
||||||
});
|
});
|
||||||
@ -441,14 +362,11 @@ public class Navigation {
|
|||||||
|
|
||||||
private void addListToNav(List<? extends Content> listContents, Content target) {
|
private void addListToNav(List<? extends Content> listContents, Content target) {
|
||||||
int count = 0;
|
int count = 0;
|
||||||
for (Content liContent : listContents) {
|
for (Content item : listContents) {
|
||||||
if (count < listContents.size() - 1) {
|
target.add(item);
|
||||||
liContent.add(Entity.NO_BREAK_SPACE);
|
if (count++ < listContents.size() - 1) {
|
||||||
liContent.add("|");
|
target.add(Entity.NO_BREAK_SPACE).add(Entity.of("gt")).add(Entity.NO_BREAK_SPACE);
|
||||||
liContent.add(Entity.NO_BREAK_SPACE);
|
|
||||||
}
|
}
|
||||||
target.add(liContent);
|
|
||||||
count++;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -458,41 +376,25 @@ public class Navigation {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addPageLabel(Content target, Content label, boolean display) {
|
/**
|
||||||
if (display) {
|
* Adds a link to the overview page if indicated by the configuration.
|
||||||
target.add(HtmlTree.LI(label));
|
* Otherwise a link to the first module or package is added.
|
||||||
}
|
*
|
||||||
}
|
* @param target content to add the link to
|
||||||
|
*/
|
||||||
private void addOverviewLink(Content target) {
|
private void addOverviewLink(Content target) {
|
||||||
if (options.createOverview()) {
|
if (options.createOverview()) {
|
||||||
target.add(HtmlTree.LI(links.createLink(pathToRoot.resolve(DocPaths.INDEX),
|
target.add(HtmlTree.LI(links.createLink(pathToRoot.resolve(DocPaths.INDEX),
|
||||||
contents.overviewLabel, "")));
|
contents.overviewLabel, "")));
|
||||||
}
|
} else if (configuration.showModules && configuration.modules.size() > 0) {
|
||||||
}
|
ModuleElement mdle = configuration.modules.first();
|
||||||
|
if (!mdle.equals(element)) {
|
||||||
private void addModuleLink(Content target) {
|
|
||||||
if (configuration.showModules) {
|
|
||||||
if (configuration.modules.size() == 1) {
|
|
||||||
ModuleElement mdle = configuration.modules.first();
|
|
||||||
boolean included = configuration.utils.isIncluded(mdle);
|
boolean included = configuration.utils.isIncluded(mdle);
|
||||||
target.add(HtmlTree.LI((included)
|
target.add(HtmlTree.LI((included)
|
||||||
? links.createLink(pathToRoot.resolve(configuration.docPaths.moduleSummary(mdle)), contents.moduleLabel, "")
|
? links.createLink(pathToRoot.resolve(configuration.docPaths.moduleSummary(mdle)), contents.moduleLabel, "")
|
||||||
: contents.moduleLabel));
|
: contents.moduleLabel));
|
||||||
} else if (!configuration.modules.isEmpty()) {
|
|
||||||
addPageLabel(target, contents.moduleLabel, true);
|
|
||||||
}
|
}
|
||||||
}
|
} else if (configuration.packages.size() > 0 && !(element instanceof PackageElement)) {
|
||||||
}
|
|
||||||
|
|
||||||
private void addModuleOfElementLink(Content target) {
|
|
||||||
if (configuration.showModules) {
|
|
||||||
target.add(HtmlTree.LI(navLinkModule));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private void addPackageLink(Content target) {
|
|
||||||
if (configuration.packages.size() == 1) {
|
|
||||||
PackageElement packageElement = configuration.packages.first();
|
PackageElement packageElement = configuration.packages.first();
|
||||||
boolean included = packageElement != null && configuration.utils.isIncluded(packageElement);
|
boolean included = packageElement != null && configuration.utils.isIncluded(packageElement);
|
||||||
if (!included) {
|
if (!included) {
|
||||||
@ -512,22 +414,23 @@ public class Navigation {
|
|||||||
packageElement, pathToRoot, DocPaths.PACKAGE_SUMMARY.getPath());
|
packageElement, pathToRoot, DocPaths.PACKAGE_SUMMARY.getPath());
|
||||||
if (crossPkgLink != null) {
|
if (crossPkgLink != null) {
|
||||||
target.add(HtmlTree.LI(links.createLink(crossPkgLink, contents.packageLabel)));
|
target.add(HtmlTree.LI(links.createLink(crossPkgLink, contents.packageLabel)));
|
||||||
} else {
|
|
||||||
target.add(HtmlTree.LI(contents.packageLabel));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (!configuration.packages.isEmpty()) {
|
|
||||||
addPageLabel(target, contents.packageLabel, true);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addPackageOfElementLink(Content target) {
|
|
||||||
target.add(HtmlTree.LI(links.createLink(DocPath.parent.resolve(DocPaths.PACKAGE_SUMMARY),
|
|
||||||
contents.packageLabel)));
|
|
||||||
}
|
|
||||||
|
|
||||||
private void addPackageSummaryLink(Content target) {
|
private void addPageElementLink(Content list) {
|
||||||
target.add(HtmlTree.LI(links.createLink(DocPaths.PACKAGE_SUMMARY, contents.packageLabel)));
|
Content link = switch (element) {
|
||||||
|
case ModuleElement mdle -> links.createLink(pathToRoot.resolve(
|
||||||
|
configuration.docPaths.moduleSummary(mdle)), contents.moduleLabel);
|
||||||
|
case PackageElement pkg -> links.createLink(pathToRoot.resolve(
|
||||||
|
configuration.docPaths.forPackage(pkg).resolve(DocPaths.PACKAGE_SUMMARY)), contents.packageLabel);
|
||||||
|
case TypeElement type -> links.createLink(pathToRoot.resolve(
|
||||||
|
configuration.docPaths.forClass(type)), contents.classLabel);
|
||||||
|
default -> throw new RuntimeException();
|
||||||
|
};
|
||||||
|
list.add(HtmlTree.LI(link));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void addTreeLink(Content target) {
|
private void addTreeLink(Content target) {
|
||||||
@ -571,6 +474,13 @@ public class Navigation {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void addSearchLink(Content target) {
|
||||||
|
if (options.createIndex()) {
|
||||||
|
target.add(HtmlTree.LI(links.createLink(
|
||||||
|
pathToRoot.resolve(DocPaths.SEARCH_PAGE), contents.searchLabel, "")));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void addHelpLink(Content target) {
|
private void addHelpLink(Content target) {
|
||||||
if (!options.noHelp()) {
|
if (!options.noHelp()) {
|
||||||
String helpfile = options.helpFile();
|
String helpfile = options.helpFile();
|
||||||
@ -588,16 +498,17 @@ public class Navigation {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void addSearch(Content target) {
|
private void addSearch(Content target) {
|
||||||
String reset = "reset";
|
var resources = configuration.getDocResources();
|
||||||
var inputText = HtmlTree.INPUT("text", HtmlIds.SEARCH_INPUT)
|
var inputText = HtmlTree.INPUT(HtmlAttr.InputType.TEXT, HtmlIds.SEARCH_INPUT)
|
||||||
.put(HtmlAttr.PLACEHOLDER, searchPlaceholder);
|
.put(HtmlAttr.PLACEHOLDER, resources.getText("doclet.search_placeholder"))
|
||||||
var inputReset = HtmlTree.INPUT(reset, HtmlIds.RESET_BUTTON)
|
.put(HtmlAttr.ARIA_LABEL, resources.getText("doclet.search_in_documentation"))
|
||||||
.put(HtmlAttr.VALUE, reset);
|
.put(HtmlAttr.AUTOCOMPLETE, "off")
|
||||||
var searchDiv = HtmlTree.DIV(HtmlStyle.navListSearch,
|
.put(HtmlAttr.AUTOCAPITALIZE, "off");
|
||||||
links.createLink(pathToRoot.resolve(DocPaths.SEARCH_PAGE),
|
var inputReset = HtmlTree.INPUT(HtmlAttr.InputType.RESET, HtmlIds.RESET_SEARCH)
|
||||||
searchLabel, ""));
|
.put(HtmlAttr.VALUE, resources.getText("doclet.search_reset"));
|
||||||
searchDiv.add(inputText);
|
var searchDiv = HtmlTree.DIV(HtmlStyle.navListSearch)
|
||||||
searchDiv.add(inputReset);
|
.add(inputText)
|
||||||
|
.add(inputReset);
|
||||||
target.add(searchDiv);
|
target.add(searchDiv);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -612,58 +523,46 @@ public class Navigation {
|
|||||||
}
|
}
|
||||||
var navigationBar = HtmlTree.NAV();
|
var navigationBar = HtmlTree.NAV();
|
||||||
|
|
||||||
var navDiv = new HtmlTree(TagName.DIV);
|
var navContent = new HtmlTree(TagName.DIV);
|
||||||
Content skipNavLinks = contents.getContent("doclet.Skip_navigation_links");
|
Content skipNavLinks = contents.getContent("doclet.Skip_navigation_links");
|
||||||
String toggleNavLinks = configuration.getDocResources().getText("doclet.Toggle_navigation_links");
|
String toggleNavLinks = configuration.getDocResources().getText("doclet.Toggle_navigation_links");
|
||||||
navigationBar.add(MarkerComments.START_OF_TOP_NAVBAR);
|
navigationBar.add(MarkerComments.START_OF_TOP_NAVBAR);
|
||||||
// The mobile menu button uses three empty spans to produce its animated icon
|
// The mobile menu button uses three empty spans to produce its animated icon
|
||||||
HtmlTree iconSpan = HtmlTree.SPAN(HtmlStyle.navBarToggleIcon).add(Entity.NO_BREAK_SPACE);
|
HtmlTree iconSpan = HtmlTree.SPAN(HtmlStyle.navBarToggleIcon).add(Entity.NO_BREAK_SPACE);
|
||||||
navDiv.setStyle(HtmlStyle.topNav)
|
navContent.setStyle(HtmlStyle.navContent).add(HtmlTree.DIV(HtmlStyle.navMenuButton,
|
||||||
.setId(HtmlIds.NAVBAR_TOP)
|
new HtmlTree(TagName.BUTTON).setId(HtmlIds.NAVBAR_TOGGLE_BUTTON)
|
||||||
.add(new HtmlTree(TagName.BUTTON).setId(HtmlIds.NAVBAR_TOGGLE_BUTTON)
|
.put(HtmlAttr.ARIA_CONTROLS, HtmlIds.NAVBAR_TOP.name())
|
||||||
.put(HtmlAttr.ARIA_CONTROLS, HtmlIds.NAVBAR_TOP.name())
|
.put(HtmlAttr.ARIA_EXPANDED, String.valueOf(false))
|
||||||
.put(HtmlAttr.ARIA_EXPANDED, String.valueOf(false))
|
.put(HtmlAttr.ARIA_LABEL, toggleNavLinks)
|
||||||
.put(HtmlAttr.ARIA_LABEL, toggleNavLinks)
|
.add(iconSpan)
|
||||||
.add(iconSpan)
|
.add(iconSpan)
|
||||||
.add(iconSpan)
|
.add(iconSpan)))
|
||||||
.add(iconSpan))
|
|
||||||
.add(HtmlTree.DIV(HtmlStyle.skipNav,
|
.add(HtmlTree.DIV(HtmlStyle.skipNav,
|
||||||
links.createLink(HtmlIds.SKIP_NAVBAR_TOP, skipNavLinks,
|
links.createLink(HtmlIds.SKIP_NAVBAR_TOP, skipNavLinks,
|
||||||
skipNavLinks.toString())));
|
skipNavLinks.toString())));
|
||||||
Content aboutContent = userHeader;
|
Content aboutContent = userHeader;
|
||||||
boolean addSearch = options.createIndex() && documentedPage != PageMode.SEARCH;
|
|
||||||
|
|
||||||
var aboutDiv = HtmlTree.DIV(HtmlStyle.aboutLanguage, aboutContent);
|
|
||||||
navDiv.add(aboutDiv);
|
|
||||||
var navList = new HtmlTree(TagName.UL)
|
var navList = new HtmlTree(TagName.UL)
|
||||||
.setId(HtmlIds.NAVBAR_TOP_FIRSTROW)
|
.setId(HtmlIds.NAVBAR_TOP_FIRSTROW)
|
||||||
.setStyle(HtmlStyle.navList)
|
.setStyle(HtmlStyle.navList)
|
||||||
.put(HtmlAttr.TITLE, rowListTitle);
|
.put(HtmlAttr.TITLE, rowListTitle);
|
||||||
addMainNavLinks(navList);
|
addMainNavLinks(navList);
|
||||||
navDiv.add(navList);
|
navContent.add(navList);
|
||||||
var ulNavSummaryRight = HtmlTree.UL(HtmlStyle.subNavListSmall);
|
var aboutDiv = HtmlTree.DIV(HtmlStyle.aboutLanguage, aboutContent);
|
||||||
addSummaryLinks(ulNavSummaryRight, true);
|
navContent.add(aboutDiv);
|
||||||
addDetailLinks(ulNavSummaryRight, true);
|
navigationBar.add(HtmlTree.DIV(HtmlStyle.topNav, navContent).setId(HtmlIds.NAVBAR_TOP));
|
||||||
navDiv.add(ulNavSummaryRight);
|
|
||||||
navigationBar.add(navDiv);
|
|
||||||
|
|
||||||
var subDiv = HtmlTree.DIV(HtmlStyle.subNav);
|
var subNavContent = HtmlTree.DIV(HtmlStyle.navContent);
|
||||||
|
|
||||||
var div = new HtmlTree(TagName.DIV).setId(HtmlIds.NAVBAR_SUB_LIST);
|
// Add the breadcrumb navigation links if present.
|
||||||
// Add the summary links if present.
|
var ulBreadcrumbNav = HtmlTree.OL(HtmlStyle.subNavList);
|
||||||
var ulNavSummary = HtmlTree.UL(HtmlStyle.subNavList);
|
addSummaryLinks(ulBreadcrumbNav);
|
||||||
addSummaryLinks(ulNavSummary, false);
|
subNavContent.addUnchecked(ulBreadcrumbNav);
|
||||||
div.add(ulNavSummary);
|
|
||||||
// Add the detail links if present.
|
|
||||||
var ulNavDetail = HtmlTree.UL(HtmlStyle.subNavList);
|
|
||||||
addDetailLinks(ulNavDetail, false);
|
|
||||||
div.add(ulNavDetail);
|
|
||||||
subDiv.add(div);
|
|
||||||
|
|
||||||
if (addSearch) {
|
if (options.createIndex() && documentedPage != PageMode.SEARCH) {
|
||||||
addSearch(subDiv);
|
addSearch(subNavContent);
|
||||||
}
|
}
|
||||||
navigationBar.add(subDiv);
|
navigationBar.add(HtmlTree.DIV(HtmlStyle.subNav, subNavContent));
|
||||||
|
|
||||||
navigationBar.add(MarkerComments.END_OF_TOP_NAVBAR);
|
navigationBar.add(MarkerComments.END_OF_TOP_NAVBAR);
|
||||||
navigationBar.add(HtmlTree.SPAN(HtmlStyle.skipNav)
|
navigationBar.add(HtmlTree.SPAN(HtmlStyle.skipNav)
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2021, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2021, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -88,7 +88,7 @@ public class NewAPIListWriter extends SummaryListWriter<NewAPIBuilder> {
|
|||||||
String release = releases.get(i);
|
String release = releases.get(i);
|
||||||
HtmlId htmlId = HtmlId.of("release-" + releaseIndex);
|
HtmlId htmlId = HtmlId.of("release-" + releaseIndex);
|
||||||
tabs.add(Text.of(" ")).add(HtmlTree.LABEL(htmlId.name(),
|
tabs.add(Text.of(" ")).add(HtmlTree.LABEL(htmlId.name(),
|
||||||
HtmlTree.INPUT("checkbox", htmlId)
|
HtmlTree.INPUT(HtmlAttr.InputType.CHECKBOX, htmlId)
|
||||||
.put(HtmlAttr.CHECKED, "")
|
.put(HtmlAttr.CHECKED, "")
|
||||||
.put(HtmlAttr.ONCLICK,
|
.put(HtmlAttr.ONCLICK,
|
||||||
"toggleGlobal(this, '" + releaseIndex + "', 3)"))
|
"toggleGlobal(this, '" + releaseIndex + "', 3)"))
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -33,10 +33,14 @@ import jdk.javadoc.internal.doclets.formats.html.markup.BodyContents;
|
|||||||
import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder;
|
import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle;
|
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.HtmlTree;
|
||||||
|
import jdk.javadoc.internal.doclets.formats.html.markup.Text;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.ClassTree;
|
import jdk.javadoc.internal.doclets.toolkit.util.ClassTree;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocFileIOException;
|
import jdk.javadoc.internal.doclets.toolkit.util.DocFileIOException;
|
||||||
import jdk.javadoc.internal.doclets.toolkit.util.DocPaths;
|
import jdk.javadoc.internal.doclets.toolkit.util.DocPaths;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Class to generate Tree page for a package. The name of the file generated is
|
* Class to generate Tree page for a package. The name of the file generated is
|
||||||
@ -128,10 +132,14 @@ public class PackageTreeWriter extends AbstractTreeWriter {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
||||||
Content linkContent = getModuleLink(utils.elementUtils.getModuleOf(packageElement),
|
List<Content> subnavLinks = new ArrayList<>();
|
||||||
contents.moduleLabel);
|
if (configuration.showModules) {
|
||||||
return super.getNavBar(pageMode, element)
|
var mdle = utils.elementUtils.getModuleOf(packageElement);
|
||||||
.setNavLinkModule(linkContent);
|
subnavLinks.add(getModuleLink(mdle, Text.of(mdle.getQualifiedName())));
|
||||||
|
}
|
||||||
|
subnavLinks.add(links.createLink(pathString(packageElement, DocPaths.PACKAGE_SUMMARY),
|
||||||
|
getLocalizedPackageName(packageElement), HtmlStyle.currentSelection, ""));
|
||||||
|
return super.getNavBar(pageMode, element).setSubNavLinks(subnavLinks);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -25,6 +25,8 @@
|
|||||||
|
|
||||||
package jdk.javadoc.internal.doclets.formats.html;
|
package jdk.javadoc.internal.doclets.formats.html;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import java.util.SortedMap;
|
import java.util.SortedMap;
|
||||||
import java.util.TreeMap;
|
import java.util.TreeMap;
|
||||||
@ -216,9 +218,13 @@ public class PackageUseWriter extends SubWriterHolderWriter {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
||||||
Content linkContent = getModuleLink(utils.elementUtils.getModuleOf(element),
|
List<Content> subnavLinks = new ArrayList<>();
|
||||||
contents.moduleLabel);
|
if (configuration.showModules) {
|
||||||
return super.getNavBar(pageMode, element)
|
var mdle = utils.elementUtils.getModuleOf(packageElement);
|
||||||
.setNavLinkModule(linkContent);
|
subnavLinks.add(getModuleLink(mdle, Text.of(mdle.getQualifiedName())));
|
||||||
|
}
|
||||||
|
subnavLinks.add(links.createLink(pathString(packageElement, DocPaths.PACKAGE_SUMMARY),
|
||||||
|
getLocalizedPackageName(packageElement), HtmlStyle.currentSelection, ""));
|
||||||
|
return super.getNavBar(pageMode, element).setSubNavLinks(subnavLinks);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -42,7 +42,6 @@ import com.sun.source.doctree.DeprecatedTree;
|
|||||||
import com.sun.source.doctree.DocTree;
|
import com.sun.source.doctree.DocTree;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.BodyContents;
|
import jdk.javadoc.internal.doclets.formats.html.markup.BodyContents;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder;
|
import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.Entity;
|
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle;
|
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlStyle;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.TagName;
|
import jdk.javadoc.internal.doclets.formats.html.markup.TagName;
|
||||||
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree;
|
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlTree;
|
||||||
@ -72,7 +71,7 @@ public class PackageWriter extends HtmlDocletWriter {
|
|||||||
/**
|
/**
|
||||||
* The HTML element for the section tag being written.
|
* The HTML element for the section tag being written.
|
||||||
*/
|
*/
|
||||||
private final HtmlTree section = HtmlTree.SECTION(HtmlStyle.packageDescription);
|
private final HtmlTree section = HtmlTree.SECTION(HtmlStyle.packageDescription, new ContentBuilder());
|
||||||
|
|
||||||
private final BodyContents bodyContents = new BodyContents();
|
private final BodyContents bodyContents = new BodyContents();
|
||||||
|
|
||||||
@ -179,9 +178,13 @@ public class PackageWriter extends HtmlDocletWriter {
|
|||||||
* be added
|
* be added
|
||||||
*/
|
*/
|
||||||
protected void buildPackageDescription(Content packageContent) {
|
protected void buildPackageDescription(Content packageContent) {
|
||||||
if (!options.noComment()) {
|
tableOfContents.addLink(HtmlIds.TOP_OF_PAGE, contents.navDescription);
|
||||||
addPackageDescription(packageContent);
|
if (options.noComment()) {
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
tableOfContents.pushNestedList();
|
||||||
|
addPackageDescription(packageContent);
|
||||||
|
tableOfContents.popNestedList();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -190,24 +193,16 @@ public class PackageWriter extends HtmlDocletWriter {
|
|||||||
* @param packageContent the content to which the package tags will be added
|
* @param packageContent the content to which the package tags will be added
|
||||||
*/
|
*/
|
||||||
protected void buildPackageTags(Content packageContent) {
|
protected void buildPackageTags(Content packageContent) {
|
||||||
if (!options.noComment()) {
|
if (options.noComment()) {
|
||||||
addPackageTags(packageContent);
|
return;
|
||||||
}
|
}
|
||||||
|
addPackageTags(packageContent);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Content getPackageHeader() {
|
protected Content getPackageHeader() {
|
||||||
String packageName = getLocalizedPackageName(packageElement).toString();
|
String packageName = getLocalizedPackageName(packageElement).toString();
|
||||||
HtmlTree body = getBody(getWindowTitle(packageName));
|
HtmlTree body = getBody(getWindowTitle(packageName));
|
||||||
var div = HtmlTree.DIV(HtmlStyle.header);
|
var div = HtmlTree.DIV(HtmlStyle.header);
|
||||||
if (configuration.showModules) {
|
|
||||||
ModuleElement mdle = configuration.docEnv.getElementUtils().getModuleOf(packageElement);
|
|
||||||
var classModuleLabel = HtmlTree.SPAN(HtmlStyle.moduleLabelInPackage, contents.moduleLabel);
|
|
||||||
var moduleNameDiv = HtmlTree.DIV(HtmlStyle.subTitle, classModuleLabel);
|
|
||||||
moduleNameDiv.add(Entity.NO_BREAK_SPACE);
|
|
||||||
moduleNameDiv.add(getModuleLink(mdle,
|
|
||||||
Text.of(mdle.getQualifiedName().toString())));
|
|
||||||
div.add(moduleNameDiv);
|
|
||||||
}
|
|
||||||
Content packageHead = new ContentBuilder();
|
Content packageHead = new ContentBuilder();
|
||||||
if (!packageElement.isUnnamed()) {
|
if (!packageElement.isUnnamed()) {
|
||||||
packageHead.add(contents.packageLabel).add(" ");
|
packageHead.add(contents.packageLabel).add(" ");
|
||||||
@ -275,17 +270,15 @@ public class PackageWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
protected Navigation getNavBar(PageMode pageMode, Element element) {
|
||||||
Content linkContent = getModuleLink(utils.elementUtils.getModuleOf(packageElement),
|
List<Content> subnavLinks = new ArrayList<>();
|
||||||
contents.moduleLabel);
|
if (configuration.showModules) {
|
||||||
return super.getNavBar(pageMode, element)
|
ModuleElement mdle = configuration.docEnv.getElementUtils().getModuleOf(packageElement);
|
||||||
.setNavLinkModule(linkContent)
|
subnavLinks.add(links.createLink(pathToRoot.resolve(docPaths.moduleSummary(mdle)),
|
||||||
.setSubNavLinks(() -> List.of(
|
Text.of(mdle.getQualifiedName())));
|
||||||
links.createLink(HtmlIds.PACKAGE_DESCRIPTION, contents.navDescription,
|
}
|
||||||
!utils.getFullBody(packageElement).isEmpty() && !options.noComment()),
|
subnavLinks.add(links.createLink(pathString(packageElement, DocPaths.PACKAGE_SUMMARY),
|
||||||
links.createLink(HtmlIds.RELATED_PACKAGE_SUMMARY, contents.relatedPackages,
|
getLocalizedPackageName(packageElement), HtmlStyle.currentSelection, ""));
|
||||||
relatedPackages != null && !relatedPackages.isEmpty()),
|
return super.getNavBar(pageMode, element).setSubNavLinks(subnavLinks);
|
||||||
links.createLink(HtmlIds.CLASS_SUMMARY, contents.navClassesAndInterfaces,
|
|
||||||
allClasses != null && !allClasses.isEmpty())));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -319,8 +312,7 @@ public class PackageWriter extends HtmlDocletWriter {
|
|||||||
TableHeader tableHeader= showModules
|
TableHeader tableHeader= showModules
|
||||||
? new TableHeader(contents.moduleLabel, contents.packageLabel, contents.descriptionLabel)
|
? new TableHeader(contents.moduleLabel, contents.packageLabel, contents.descriptionLabel)
|
||||||
: new TableHeader(contents.packageLabel, contents.descriptionLabel);
|
: new TableHeader(contents.packageLabel, contents.descriptionLabel);
|
||||||
addPackageSummary(relatedPackages, contents.relatedPackages, tableHeader,
|
addRelatedPackageSummary(tableHeader, summaryContent, showModules);
|
||||||
summaryContent, showModules);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -359,17 +351,18 @@ public class PackageWriter extends HtmlDocletWriter {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (!table.isEmpty()) {
|
if (!table.isEmpty()) {
|
||||||
|
tableOfContents.addLink(HtmlIds.CLASS_SUMMARY, contents.navClassesAndInterfaces);
|
||||||
target.add(HtmlTree.LI(table));
|
target.add(HtmlTree.LI(table));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void addPackageSummary(List<PackageElement> packages, Content label,
|
protected void addRelatedPackageSummary(TableHeader tableHeader, Content summaryContent,
|
||||||
TableHeader tableHeader, Content summaryContent,
|
boolean showModules) {
|
||||||
boolean showModules) {
|
if (!relatedPackages.isEmpty()) {
|
||||||
if (!packages.isEmpty()) {
|
tableOfContents.addLink(HtmlIds.RELATED_PACKAGE_SUMMARY, contents.relatedPackages);
|
||||||
var table = new Table<Void>(HtmlStyle.summaryTable)
|
var table = new Table<Void>(HtmlStyle.summaryTable)
|
||||||
.setId(HtmlIds.RELATED_PACKAGE_SUMMARY)
|
.setId(HtmlIds.RELATED_PACKAGE_SUMMARY)
|
||||||
.setCaption(label)
|
.setCaption(contents.relatedPackages)
|
||||||
.setHeader(tableHeader);
|
.setHeader(tableHeader);
|
||||||
if (showModules) {
|
if (showModules) {
|
||||||
table.setColumnStyles(HtmlStyle.colPlain, HtmlStyle.colFirst, HtmlStyle.colLast);
|
table.setColumnStyles(HtmlStyle.colPlain, HtmlStyle.colFirst, HtmlStyle.colLast);
|
||||||
@ -377,7 +370,7 @@ public class PackageWriter extends HtmlDocletWriter {
|
|||||||
table.setColumnStyles(HtmlStyle.colFirst, HtmlStyle.colLast);
|
table.setColumnStyles(HtmlStyle.colFirst, HtmlStyle.colLast);
|
||||||
}
|
}
|
||||||
|
|
||||||
for (PackageElement pkg : packages) {
|
for (PackageElement pkg : relatedPackages) {
|
||||||
Content packageLink = getPackageLink(pkg, Text.of(pkg.getQualifiedName()));
|
Content packageLink = getPackageLink(pkg, Text.of(pkg.getQualifiedName()));
|
||||||
Content moduleLink = Text.EMPTY;
|
Content moduleLink = Text.EMPTY;
|
||||||
if (showModules) {
|
if (showModules) {
|
||||||
@ -427,6 +420,7 @@ public class PackageWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
protected void addPackageContent(Content packageContent) {
|
protected void addPackageContent(Content packageContent) {
|
||||||
bodyContents.addMainContent(packageContent);
|
bodyContents.addMainContent(packageContent);
|
||||||
|
bodyContents.setSideContent(tableOfContents.toContent(false));
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void addPackageFooter() {
|
protected void addPackageFooter() {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -88,7 +88,7 @@ public class PreviewListWriter extends SummaryListWriter<PreviewAPIListBuilder>
|
|||||||
HtmlId htmlId = HtmlId.of("feature-" + index);
|
HtmlId htmlId = HtmlId.of("feature-" + index);
|
||||||
String jepUrl = resources.getText("doclet.Preview_JEP_URL", jep.number());
|
String jepUrl = resources.getText("doclet.Preview_JEP_URL", jep.number());
|
||||||
list.add(HtmlTree.LI(HtmlTree.LABEL(htmlId.name(),
|
list.add(HtmlTree.LI(HtmlTree.LABEL(htmlId.name(),
|
||||||
HtmlTree.INPUT("checkbox", htmlId)
|
HtmlTree.INPUT(HtmlAttr.InputType.CHECKBOX, htmlId)
|
||||||
.put(HtmlAttr.CHECKED, "")
|
.put(HtmlAttr.CHECKED, "")
|
||||||
.put(HtmlAttr.ONCLICK,
|
.put(HtmlAttr.ONCLICK,
|
||||||
"toggleGlobal(this, '" + index + "', 3)"))
|
"toggleGlobal(this, '" + index + "', 3)"))
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -74,6 +74,8 @@ public class PropertyWriter extends AbstractMemberWriter {
|
|||||||
if (!properties.isEmpty()) {
|
if (!properties.isEmpty()) {
|
||||||
Content propertyDetailsHeader = getPropertyDetailsHeader(detailsList);
|
Content propertyDetailsHeader = getPropertyDetailsHeader(detailsList);
|
||||||
Content memberList = getMemberList();
|
Content memberList = getMemberList();
|
||||||
|
writer.tableOfContents.addLink(HtmlIds.PROPERTY_DETAIL, contents.propertyDetailsLabel);
|
||||||
|
writer.tableOfContents.pushNestedList();
|
||||||
|
|
||||||
for (Element property : properties) {
|
for (Element property : properties) {
|
||||||
currentProperty = (ExecutableElement)property;
|
currentProperty = (ExecutableElement)property;
|
||||||
@ -86,9 +88,12 @@ public class PropertyWriter extends AbstractMemberWriter {
|
|||||||
buildTagInfo(div);
|
buildTagInfo(div);
|
||||||
propertyContent.add(div);
|
propertyContent.add(div);
|
||||||
memberList.add(getMemberListItem(propertyContent));
|
memberList.add(getMemberListItem(propertyContent));
|
||||||
|
writer.tableOfContents.addLink(htmlIds.forProperty(currentProperty),
|
||||||
|
Text.of(utils.getPropertyLabel(name(property))));
|
||||||
}
|
}
|
||||||
Content propertyDetails = getPropertyDetails(propertyDetailsHeader, memberList);
|
Content propertyDetails = getPropertyDetails(propertyDetailsHeader, memberList);
|
||||||
detailsList.add(propertyDetails);
|
detailsList.add(propertyDetails);
|
||||||
|
writer.tableOfContents.popNestedList();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2022, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2022, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -81,9 +81,12 @@ public class SearchWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
contentTree.add(HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, HtmlStyle.title,
|
contentTree.add(HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, HtmlStyle.title,
|
||||||
contents.getContent("doclet.search.main_heading")))
|
contents.getContent("doclet.search.main_heading")))
|
||||||
.add(HtmlTree.DIV(HtmlTree.INPUT("text", HtmlId.of("page-search-input"))
|
.add(HtmlTree.DIV(HtmlTree.INPUT(HtmlAttr.InputType.TEXT, HtmlId.of("page-search-input"))
|
||||||
.put(HtmlAttr.PLACEHOLDER, resources.getText("doclet.search_placeholder")))
|
.put(HtmlAttr.PLACEHOLDER, resources.getText("doclet.search_placeholder"))
|
||||||
.add(HtmlTree.INPUT("reset", HtmlId.of("page-search-reset"))
|
.put(HtmlAttr.ARIA_LABEL, resources.getText("doclet.search_in_documentation"))
|
||||||
|
.put(HtmlAttr.AUTOCOMPLETE, "off")
|
||||||
|
.put(HtmlAttr.AUTOCAPITALIZE, "off"))
|
||||||
|
.add(HtmlTree.INPUT(HtmlAttr.InputType.RESET, HtmlId.of("page-search-reset"))
|
||||||
.put(HtmlAttr.VALUE, resources.getText("doclet.search_reset"))
|
.put(HtmlAttr.VALUE, resources.getText("doclet.search_reset"))
|
||||||
.put(HtmlAttr.STYLE, "margin: 6px;"))
|
.put(HtmlAttr.STYLE, "margin: 6px;"))
|
||||||
.add(HtmlTree.DETAILS(HtmlStyle.pageSearchDetails)
|
.add(HtmlTree.DETAILS(HtmlStyle.pageSearchDetails)
|
||||||
@ -104,7 +107,7 @@ public class SearchWriter extends HtmlDocletWriter {
|
|||||||
.addStyle(HtmlStyle.copy)
|
.addStyle(HtmlStyle.copy)
|
||||||
.put(HtmlAttr.ARIA_LABEL, copyUrlText)
|
.put(HtmlAttr.ARIA_LABEL, copyUrlText)
|
||||||
.setId(HtmlId.of("page-search-copy")))
|
.setId(HtmlId.of("page-search-copy")))
|
||||||
.add(HtmlTree.P(HtmlTree.INPUT("checkbox", HtmlId.of("search-redirect")))
|
.add(HtmlTree.P(HtmlTree.INPUT(HtmlAttr.InputType.CHECKBOX, HtmlId.of("search-redirect")))
|
||||||
.add(HtmlTree.LABEL("search-redirect",
|
.add(HtmlTree.LABEL("search-redirect",
|
||||||
contents.getContent("doclet.search.redirect")))))
|
contents.getContent("doclet.search.redirect")))))
|
||||||
.add(new HtmlTree(TagName.P)
|
.add(new HtmlTree(TagName.P)
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -187,10 +187,11 @@ public abstract class SubWriterHolderWriter extends HtmlDocletWriter {
|
|||||||
/**
|
/**
|
||||||
* Add the class content.
|
* Add the class content.
|
||||||
*
|
*
|
||||||
* @param source class content which will be added to the documentation
|
* @param classContent class content which will be added to the documentation
|
||||||
*/
|
*/
|
||||||
public void addClassContent(Content source) {
|
public void addClassContent(Content classContent) {
|
||||||
bodyContents.addMainContent(source);
|
bodyContents.addMainContent(classContent);
|
||||||
|
bodyContents.setSideContent(tableOfContents.toContent(true));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -25,7 +25,6 @@
|
|||||||
|
|
||||||
package jdk.javadoc.internal.doclets.formats.html;
|
package jdk.javadoc.internal.doclets.formats.html;
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.SortedSet;
|
import java.util.SortedSet;
|
||||||
|
|
||||||
import javax.lang.model.element.Element;
|
import javax.lang.model.element.Element;
|
||||||
@ -154,16 +153,14 @@ public abstract class SummaryListWriter<B extends SummaryAPIListBuilder> extends
|
|||||||
// The script below enables checkboxes in the page and invokes their click handler
|
// The script below enables checkboxes in the page and invokes their click handler
|
||||||
// to restore any previous state when the page is loaded via back/forward button.
|
// to restore any previous state when the page is loaded via back/forward button.
|
||||||
bodyContents.addMainContent(new Script("""
|
bodyContents.addMainContent(new Script("""
|
||||||
document.addEventListener("DOMContentLoaded", function(e) {
|
document.addEventListener("DOMContentLoaded", (e) => {
|
||||||
document.querySelectorAll('input[type="checkbox"]').forEach(
|
document.querySelectorAll('main input[type="checkbox"]').forEach((c) => {
|
||||||
function(c) {
|
|
||||||
c.disabled = false;
|
c.disabled = false;
|
||||||
c.onclick();
|
c.onclick();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
window.addEventListener("load", function(e) {
|
window.addEventListener("load", function(e) {
|
||||||
document.querySelectorAll('input[type="checkbox"]').forEach(
|
document.querySelectorAll('main input[type="checkbox"]').forEach((c) => {
|
||||||
function(c) {
|
|
||||||
c.onclick();
|
c.onclick();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
@ -0,0 +1,113 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2024, 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.Entity;
|
||||||
|
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlAttr;
|
||||||
|
import jdk.javadoc.internal.doclets.formats.html.markup.HtmlId;
|
||||||
|
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.ListBuilder;
|
||||||
|
import jdk.javadoc.internal.doclets.formats.html.markup.TagName;
|
||||||
|
import jdk.javadoc.internal.doclets.formats.html.markup.Text;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A class used by various {@link HtmlDocletWriter} subclasses to build tables of contents.
|
||||||
|
*/
|
||||||
|
public class TableOfContents {
|
||||||
|
private final ListBuilder listBuilder;
|
||||||
|
private final HtmlDocletWriter writer;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
* @param writer the writer
|
||||||
|
*/
|
||||||
|
public TableOfContents(HtmlDocletWriter writer) {
|
||||||
|
this.writer = writer;
|
||||||
|
listBuilder = new ListBuilder(HtmlTree.OL(HtmlStyle.tocList));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds a link to the table of contents.
|
||||||
|
* @param id the link fragment
|
||||||
|
* @param label the link label
|
||||||
|
* @return this object
|
||||||
|
*/
|
||||||
|
public TableOfContents addLink(HtmlId id, Content label) {
|
||||||
|
listBuilder.add(writer.links.createLink(id, label).put(HtmlAttr.TABINDEX, "0"));
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds a new nested list to add new items to.
|
||||||
|
*/
|
||||||
|
public void pushNestedList() {
|
||||||
|
listBuilder.pushNestedList(HtmlTree.OL(HtmlStyle.tocList));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Closes the current nested list and go back to the parent list.
|
||||||
|
*/
|
||||||
|
public void popNestedList() {
|
||||||
|
listBuilder.popNestedList();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a content object containing the table of contents, consisting
|
||||||
|
* of a header and the contents list itself. If the contents list is empty,
|
||||||
|
* an empty content object is returned.
|
||||||
|
*
|
||||||
|
* @param hasFilterInput whether to add a filter text input
|
||||||
|
* @return a content object
|
||||||
|
*/
|
||||||
|
protected Content toContent(boolean hasFilterInput) {
|
||||||
|
if (listBuilder.isEmpty()) {
|
||||||
|
return Text.EMPTY;
|
||||||
|
}
|
||||||
|
var content = HtmlTree.NAV()
|
||||||
|
.setStyle(HtmlStyle.toc)
|
||||||
|
.put(HtmlAttr.ARIA_LABEL, writer.resources.getText("doclet.table_of_contents"));
|
||||||
|
var header = HtmlTree.DIV(HtmlStyle.tocHeader, writer.contents.contentsHeading);
|
||||||
|
if (hasFilterInput) {
|
||||||
|
header.add(Entity.NO_BREAK_SPACE)
|
||||||
|
.add(HtmlTree.INPUT(HtmlAttr.InputType.TEXT, HtmlStyle.filterInput)
|
||||||
|
.put(HtmlAttr.PLACEHOLDER, writer.resources.getText("doclet.filter_label"))
|
||||||
|
.put(HtmlAttr.ARIA_LABEL, writer.resources.getText("doclet.filter_table_of_contents"))
|
||||||
|
.put(HtmlAttr.AUTOCOMPLETE, "off")
|
||||||
|
.put(HtmlAttr.AUTOCAPITALIZE, "off"))
|
||||||
|
.add(HtmlTree.INPUT(HtmlAttr.InputType.RESET, HtmlStyle.resetFilter)
|
||||||
|
.put(HtmlAttr.VALUE, writer.resources.getText("doclet.filter_reset")));
|
||||||
|
}
|
||||||
|
content.add(header);
|
||||||
|
content.add(new HtmlTree(TagName.BUTTON).addStyle(HtmlStyle.hideSidebar)
|
||||||
|
.add(HtmlTree.SPAN(writer.contents.hideSidebar).add(Entity.NO_BREAK_SPACE))
|
||||||
|
.add(Entity.LEFT_POINTING_ANGLE));
|
||||||
|
content.add(new HtmlTree(TagName.BUTTON).addStyle(HtmlStyle.showSidebar)
|
||||||
|
.add(Entity.RIGHT_POINTING_ANGLE)
|
||||||
|
.add(HtmlTree.SPAN(Entity.NO_BREAK_SPACE).add(writer.contents.showSidebar)));
|
||||||
|
return content.add(listBuilder);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2019, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2019, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -37,12 +37,14 @@ import java.util.Objects;
|
|||||||
* Content for the {@code <body>} element.
|
* Content for the {@code <body>} element.
|
||||||
*
|
*
|
||||||
* The content is a {@code <div>} element that contains a
|
* The content is a {@code <div>} element that contains a
|
||||||
* header that is always visible, and main content that
|
* header that is always visible, main content that
|
||||||
* can be scrolled if necessary.
|
* can be scrolled if necessary, and optional side and footer
|
||||||
|
* contents that are only rendered if available.
|
||||||
*/
|
*/
|
||||||
public class BodyContents extends Content {
|
public class BodyContents extends Content {
|
||||||
|
|
||||||
private final List<Content> mainContents = new ArrayList<>();
|
private final List<Content> mainContents = new ArrayList<>();
|
||||||
|
private Content side = null;
|
||||||
private Content header = null;
|
private Content header = null;
|
||||||
private Content footer = null;
|
private Content footer = null;
|
||||||
|
|
||||||
@ -51,6 +53,11 @@ public class BodyContents extends Content {
|
|||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public BodyContents setSideContent(Content side) {
|
||||||
|
this.side = Objects.requireNonNull(side);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
public BodyContents setHeader(Content header) {
|
public BodyContents setHeader(Content header) {
|
||||||
this.header = Objects.requireNonNull(header);
|
this.header = Objects.requireNonNull(header);
|
||||||
return this;
|
return this;
|
||||||
@ -89,7 +96,10 @@ public class BodyContents extends Content {
|
|||||||
|
|
||||||
return new ContentBuilder()
|
return new ContentBuilder()
|
||||||
.add(header)
|
.add(header)
|
||||||
.add(HtmlTree.MAIN().add(mainContents))
|
.add(HtmlTree.DIV(HtmlStyle.mainGrid)
|
||||||
.add(footer == null ? Text.EMPTY : footer);
|
.add(side == null ? Text.EMPTY : side)
|
||||||
|
.add(HtmlTree.MAIN()
|
||||||
|
.add(mainContents)
|
||||||
|
.add(footer == null ? Text.EMPTY : footer)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2019, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2019, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -38,6 +38,8 @@ public class Entity extends Content {
|
|||||||
public static final Entity GREATER_THAN = new Entity(">");
|
public static final Entity GREATER_THAN = new Entity(">");
|
||||||
public static final Entity AMPERSAND = new Entity("&");
|
public static final Entity AMPERSAND = new Entity("&");
|
||||||
public static final Entity NO_BREAK_SPACE = new Entity(" ");
|
public static final Entity NO_BREAK_SPACE = new Entity(" ");
|
||||||
|
public static final Entity LEFT_POINTING_ANGLE = new Entity("❮");
|
||||||
|
public static final Entity RIGHT_POINTING_ANGLE = new Entity("❯");
|
||||||
|
|
||||||
public final String text;
|
public final String text;
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -351,7 +351,7 @@ public class Head extends Content {
|
|||||||
if (index) {
|
if (index) {
|
||||||
if (pathToRoot != null && mainBodyScript != null) {
|
if (pathToRoot != null && mainBodyScript != null) {
|
||||||
String ptrPath = pathToRoot.isEmpty() ? "." : pathToRoot.getPath();
|
String ptrPath = pathToRoot.isEmpty() ? "." : pathToRoot.getPath();
|
||||||
mainBodyScript.append("var pathtoroot = ")
|
mainBodyScript.append("const pathtoroot = ")
|
||||||
.appendStringLiteral(ptrPath + "/")
|
.appendStringLiteral(ptrPath + "/")
|
||||||
.append(";\n")
|
.append(";\n")
|
||||||
.append("loadScripts(document, 'script');");
|
.append("loadScripts(document, 'script');");
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2010, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2010, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -38,6 +38,8 @@ public enum HtmlAttr {
|
|||||||
ARIA_LABELLEDBY("aria-labelledby"),
|
ARIA_LABELLEDBY("aria-labelledby"),
|
||||||
ARIA_ORIENTATION("aria-orientation"),
|
ARIA_ORIENTATION("aria-orientation"),
|
||||||
ARIA_SELECTED("aria-selected"),
|
ARIA_SELECTED("aria-selected"),
|
||||||
|
AUTOCOMPLETE,
|
||||||
|
AUTOCAPITALIZE,
|
||||||
CHECKED,
|
CHECKED,
|
||||||
CLASS,
|
CLASS,
|
||||||
CLEAR,
|
CLEAR,
|
||||||
@ -91,6 +93,23 @@ public enum HtmlAttr {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public enum InputType {
|
||||||
|
|
||||||
|
CHECKBOX,
|
||||||
|
RESET,
|
||||||
|
TEXT;
|
||||||
|
|
||||||
|
private final String type;
|
||||||
|
|
||||||
|
InputType() {
|
||||||
|
type = Utils.toLowerCase(name());
|
||||||
|
}
|
||||||
|
|
||||||
|
public String toString() {
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
HtmlAttr() {
|
HtmlAttr() {
|
||||||
this.value = Utils.toLowerCase(name());
|
this.value = Utils.toLowerCase(name());
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2010, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2010, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -54,7 +54,13 @@ public enum HtmlStyle {
|
|||||||
//<editor-fold desc="navigation bar">
|
//<editor-fold desc="navigation bar">
|
||||||
//
|
//
|
||||||
// The following constants are used for the main navigation bar that appears in the
|
// The following constants are used for the main navigation bar that appears in the
|
||||||
// {@code header} and {@code footer} elements on each page.
|
// {@code header} element on each page, as well as the side navigation bar that displays
|
||||||
|
// the table of contents on some pages.
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The class for the link representing the current element in breadcrumb navigation and table of contents.
|
||||||
|
*/
|
||||||
|
currentSelection,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The class for the overall {@code div} element containing the {@code header} element for the page.
|
* The class for the overall {@code div} element containing the {@code header} element for the page.
|
||||||
@ -67,6 +73,21 @@ public enum HtmlStyle {
|
|||||||
*/
|
*/
|
||||||
aboutLanguage,
|
aboutLanguage,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The class for the {@code input} element to filter items in the table of contents.
|
||||||
|
*/
|
||||||
|
filterInput,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The class for the {@code button} element to hide the sidebar.
|
||||||
|
*/
|
||||||
|
hideSidebar,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The class for the {@code div} element containing the sidebar and main content.
|
||||||
|
*/
|
||||||
|
mainGrid,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The class for the highlighted item in the list of navigation links, indicating
|
* The class for the highlighted item in the list of navigation links, indicating
|
||||||
* the current page.
|
* the current page.
|
||||||
@ -79,6 +100,16 @@ public enum HtmlStyle {
|
|||||||
*/
|
*/
|
||||||
navBarToggleIcon,
|
navBarToggleIcon,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The class for the {@code div} element containing navigation elements.
|
||||||
|
*/
|
||||||
|
navContent,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The class for the {@code div} element containing the button to show or hide the menu.
|
||||||
|
*/
|
||||||
|
navMenuButton,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The class for the primary list of navigation links.
|
* The class for the primary list of navigation links.
|
||||||
*/
|
*/
|
||||||
@ -89,6 +120,16 @@ public enum HtmlStyle {
|
|||||||
*/
|
*/
|
||||||
navListSearch,
|
navListSearch,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The class for the reset button in the sidebar filter input element.
|
||||||
|
*/
|
||||||
|
resetFilter,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The class for the {@code button} element to show the sidebar.
|
||||||
|
*/
|
||||||
|
showSidebar,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The class for a {@code div} element containing a link to skip the navigation header.
|
* The class for a {@code div} element containing a link to skip the navigation header.
|
||||||
* The element is typically invisible, but may be used when navigating the page
|
* The element is typically invisible, but may be used when navigating the page
|
||||||
@ -107,9 +148,19 @@ public enum HtmlStyle {
|
|||||||
subNavList,
|
subNavList,
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The class for the list of subsidiary navigation links for smaller displays.
|
* The class for a {@code nav} element containing a table of contents.
|
||||||
*/
|
*/
|
||||||
subNavListSmall,
|
toc,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The class for the {@code div} element representing the header of the table of contents.
|
||||||
|
*/
|
||||||
|
tocHeader,
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The class used for list elements in the table of contents.
|
||||||
|
*/
|
||||||
|
tocList,
|
||||||
|
|
||||||
//</editor-fold>
|
//</editor-fold>
|
||||||
|
|
||||||
@ -124,21 +175,6 @@ public enum HtmlStyle {
|
|||||||
*/
|
*/
|
||||||
header,
|
header,
|
||||||
|
|
||||||
/**
|
|
||||||
* The class for the "module" label in the heading for a package declaration.
|
|
||||||
*/
|
|
||||||
moduleLabelInPackage,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The class for the "module" label in the heading for a type declaration.
|
|
||||||
*/
|
|
||||||
moduleLabelInType,
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The class for the "package" label in the heading for a type declaration.
|
|
||||||
*/
|
|
||||||
packageLabelInType,
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The class for the element containing the label and name for the module
|
* The class for the element containing the label and name for the module
|
||||||
* or package that precedes the main title for the declaration of a
|
* or package that precedes the main title for the declaration of a
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2010, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2010, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -586,13 +586,26 @@ public class HtmlTree extends Content {
|
|||||||
* @param id the id
|
* @param id the id
|
||||||
* @return the element
|
* @return the element
|
||||||
*/
|
*/
|
||||||
public static HtmlTree INPUT(String type, HtmlId id) {
|
public static HtmlTree INPUT(HtmlAttr.InputType type, HtmlId id) {
|
||||||
return new HtmlTree(TagName.INPUT)
|
return new HtmlTree(TagName.INPUT)
|
||||||
.put(HtmlAttr.TYPE, type)
|
.put(HtmlAttr.TYPE, type.toString())
|
||||||
.setId(id)
|
.setId(id)
|
||||||
.put(HtmlAttr.DISABLED, "");
|
.put(HtmlAttr.DISABLED, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an HTML {@code INPUT} element with the given type
|
||||||
|
* and style. The element is marked as initially disabled.
|
||||||
|
* @param type the input type
|
||||||
|
* @param style the input style
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree INPUT(HtmlAttr.InputType type, HtmlStyle style) {
|
||||||
|
return new HtmlTree(TagName.INPUT)
|
||||||
|
.put(HtmlAttr.TYPE, type.toString())
|
||||||
|
.setStyle(style)
|
||||||
|
.put(HtmlAttr.DISABLED, "");
|
||||||
|
}
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code LABEL} element with the given content.
|
* Creates an HTML {@code LABEL} element with the given content.
|
||||||
*
|
*
|
||||||
@ -718,6 +731,17 @@ public class HtmlTree extends Content {
|
|||||||
.add(body);
|
.add(body);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an HTML {@code OL} element with the given style.
|
||||||
|
*
|
||||||
|
* @param style the style
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree OL(HtmlStyle style) {
|
||||||
|
return new HtmlTree(TagName.OL)
|
||||||
|
.setStyle(style);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code P} element with some content.
|
* Creates an HTML {@code P} element with some content.
|
||||||
*
|
*
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1997, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1997, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -53,7 +53,7 @@ public class Links {
|
|||||||
* @param label the content for the link
|
* @param label the content for the link
|
||||||
* @return the link
|
* @return the link
|
||||||
*/
|
*/
|
||||||
public Content createLink(HtmlId id, Content label) {
|
public HtmlTree createLink(HtmlId id, Content label) {
|
||||||
DocLink l = DocLink.fragment(id.name());
|
DocLink l = DocLink.fragment(id.name());
|
||||||
return createLink(l, label, "");
|
return createLink(l, label, "");
|
||||||
}
|
}
|
||||||
@ -67,7 +67,7 @@ public class Links {
|
|||||||
* @param link whether to create a link or just return the label
|
* @param link whether to create a link or just return the label
|
||||||
* @return the link or just the label
|
* @return the link or just the label
|
||||||
*/
|
*/
|
||||||
public Content createLink(HtmlId id, Content label, boolean link) {
|
public Content createLinkOrLabel(HtmlId id, Content label, boolean link) {
|
||||||
return link ? createLink(id, label) : label;
|
return link ? createLink(id, label) : label;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -80,7 +80,7 @@ public class Links {
|
|||||||
*
|
*
|
||||||
* @return the link
|
* @return the link
|
||||||
*/
|
*/
|
||||||
public Content createLink(HtmlId id, Content label, String title) {
|
public HtmlTree createLink(HtmlId id, Content label, String title) {
|
||||||
DocLink l = DocLink.fragment(id.name());
|
DocLink l = DocLink.fragment(id.name());
|
||||||
return createLink(l, label, title);
|
return createLink(l, label, title);
|
||||||
}
|
}
|
||||||
@ -92,7 +92,7 @@ public class Links {
|
|||||||
* @param label the content for the link
|
* @param label the content for the link
|
||||||
* @return the link
|
* @return the link
|
||||||
*/
|
*/
|
||||||
public Content createLink(DocPath path, String label) {
|
public HtmlTree createLink(DocPath path, String label) {
|
||||||
return createLink(path, Text.of(label), null, "");
|
return createLink(path, Text.of(label), null, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -103,7 +103,7 @@ public class Links {
|
|||||||
* @param label the content for the link
|
* @param label the content for the link
|
||||||
* @return the link
|
* @return the link
|
||||||
*/
|
*/
|
||||||
public Content createLink(DocPath path, Content label) {
|
public HtmlTree createLink(DocPath path, Content label) {
|
||||||
return createLink(path, label, "");
|
return createLink(path, label, "");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -117,7 +117,7 @@ public class Links {
|
|||||||
* @param title the title for the link
|
* @param title the title for the link
|
||||||
* @return the link
|
* @return the link
|
||||||
*/
|
*/
|
||||||
public Content createLink(DocPath path, Content label, HtmlStyle style, String title) {
|
public HtmlTree createLink(DocPath path, Content label, HtmlStyle style, String title) {
|
||||||
return createLink(new DocLink(path), label, style, title);
|
return createLink(new DocLink(path), label, style, title);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -129,7 +129,7 @@ public class Links {
|
|||||||
* @param title the title for the link
|
* @param title the title for the link
|
||||||
* @return the link
|
* @return the link
|
||||||
*/
|
*/
|
||||||
public Content createLink(DocPath path, Content label, String title) {
|
public HtmlTree createLink(DocPath path, Content label, String title) {
|
||||||
return createLink(new DocLink(path), label, title);
|
return createLink(new DocLink(path), label, title);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -152,7 +152,7 @@ public class Links {
|
|||||||
* @param title the title for the link
|
* @param title the title for the link
|
||||||
* @return the link
|
* @return the link
|
||||||
*/
|
*/
|
||||||
public Content createLink(DocLink link, Content label, String title) {
|
public HtmlTree createLink(DocLink link, Content label, String title) {
|
||||||
var anchor = HtmlTree.A(link.relativizeAgainst(file).toString(), label);
|
var anchor = HtmlTree.A(link.relativizeAgainst(file).toString(), label);
|
||||||
if (title != null && title.length() != 0) {
|
if (title != null && title.length() != 0) {
|
||||||
anchor.put(HtmlAttr.TITLE, title);
|
anchor.put(HtmlAttr.TITLE, title);
|
||||||
@ -170,7 +170,7 @@ public class Links {
|
|||||||
* @param title the title for the link
|
* @param title the title for the link
|
||||||
* @return the link
|
* @return the link
|
||||||
*/
|
*/
|
||||||
public Content createLink(DocLink link, Content label, HtmlStyle style,
|
public HtmlTree createLink(DocLink link, Content label, HtmlStyle style,
|
||||||
String title) {
|
String title) {
|
||||||
return createLink(link, label, style, title, false);
|
return createLink(link, label, style, title, false);
|
||||||
}
|
}
|
||||||
@ -186,7 +186,7 @@ public class Links {
|
|||||||
* @param isExternal is the link external to the generated documentation
|
* @param isExternal is the link external to the generated documentation
|
||||||
* @return the link
|
* @return the link
|
||||||
*/
|
*/
|
||||||
public Content createLink(DocLink link, Content label, HtmlStyle style,
|
public HtmlTree createLink(DocLink link, Content label, HtmlStyle style,
|
||||||
String title, boolean isExternal) {
|
String title, boolean isExternal) {
|
||||||
var l = HtmlTree.A(link.relativizeAgainst(file).toString(), label);
|
var l = HtmlTree.A(link.relativizeAgainst(file).toString(), label);
|
||||||
if (style != null) {
|
if (style != null) {
|
||||||
@ -209,7 +209,7 @@ public class Links {
|
|||||||
* @param label the content for the link
|
* @param label the content for the link
|
||||||
* @return the link
|
* @return the link
|
||||||
*/
|
*/
|
||||||
public Content createExternalLink(DocLink link, Content label) {
|
public HtmlTree createExternalLink(DocLink link, Content label) {
|
||||||
return HtmlTree.A(link.relativizeAgainst(file).toString(), label)
|
return HtmlTree.A(link.relativizeAgainst(file).toString(), label)
|
||||||
.setStyle(HtmlStyle.externalLink);
|
.setStyle(HtmlStyle.externalLink);
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,115 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2024, 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.markup;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.Writer;
|
||||||
|
import java.util.ArrayDeque;
|
||||||
|
import java.util.Deque;
|
||||||
|
import java.util.NoSuchElementException;
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
|
import jdk.javadoc.internal.doclets.formats.html.Content;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A utility class for building nested HTML lists. This class is implemented as a
|
||||||
|
* stack of nested list/item pairs where list items are added to the inner-most
|
||||||
|
* list and nested lists are added to the current list item of the inner-most list.
|
||||||
|
* Lists can be added to and removed from the stack using the {@link #pushNestedList}
|
||||||
|
* and {@link #popNestedList} methods.
|
||||||
|
*/
|
||||||
|
public class ListBuilder extends Content {
|
||||||
|
|
||||||
|
private final HtmlTree root;
|
||||||
|
private record Pair(HtmlTree list, HtmlTree item) {}
|
||||||
|
private final Deque<Pair> stack = new ArrayDeque<>();
|
||||||
|
private HtmlTree currentList;
|
||||||
|
private HtmlTree currentItem;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new list builder.
|
||||||
|
*
|
||||||
|
* @param list the root list element
|
||||||
|
*/
|
||||||
|
public ListBuilder(HtmlTree list) {
|
||||||
|
Objects.requireNonNull(list, "Root list element is required");
|
||||||
|
root = currentList = list;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds a new list item with the given content to the current list. The last added list item
|
||||||
|
* will also be used as container when pushing a new nested list.
|
||||||
|
*
|
||||||
|
* @param listItemContent the content for the new list item.
|
||||||
|
* @return this list builder
|
||||||
|
*/
|
||||||
|
public ListBuilder add(Content listItemContent) {
|
||||||
|
currentItem = HtmlTree.LI(listItemContent);
|
||||||
|
currentList.addUnchecked(currentItem);
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds a new nested list to the current list item and makes it the recipient for new list items.
|
||||||
|
* Note that the nested list is added even if empty; use {@code addNested} to avoid adding empty
|
||||||
|
* lists.
|
||||||
|
*
|
||||||
|
* @param list the nested list
|
||||||
|
* @return this list builder
|
||||||
|
*/
|
||||||
|
public ListBuilder pushNestedList(HtmlTree list) {
|
||||||
|
Objects.requireNonNull(currentItem, "List item required for nested list");
|
||||||
|
stack.push(new Pair(currentList, currentItem));
|
||||||
|
currentList = list;
|
||||||
|
currentItem = null;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Pops the current list from the stack and returns to adding list items to the parent list.
|
||||||
|
*
|
||||||
|
* @return this list builder
|
||||||
|
* @throws NoSuchElementException if the stack is empty
|
||||||
|
*/
|
||||||
|
public ListBuilder popNestedList() {
|
||||||
|
Pair pair = stack.pop();
|
||||||
|
// First restore currentItem and add nested list to it before restoring currentList to outer list.
|
||||||
|
currentItem = pair.item;
|
||||||
|
currentItem.add(currentList);
|
||||||
|
currentList = pair.list;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean write(Writer writer, String newline, boolean atNewline) throws IOException {
|
||||||
|
return root.write(writer, newline, atNewline);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isEmpty() {
|
||||||
|
return root.isEmpty();
|
||||||
|
}
|
||||||
|
}
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2010, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2010, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -35,6 +35,7 @@ import jdk.javadoc.internal.doclets.toolkit.util.Utils;
|
|||||||
*/
|
*/
|
||||||
public enum TagName {
|
public enum TagName {
|
||||||
A,
|
A,
|
||||||
|
ASIDE,
|
||||||
BUTTON,
|
BUTTON,
|
||||||
BLOCKQUOTE,
|
BLOCKQUOTE,
|
||||||
BODY,
|
BODY,
|
||||||
|
@ -1,236 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2013, 2023, 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
var moduleSearchIndex;
|
|
||||||
var packageSearchIndex;
|
|
||||||
var typeSearchIndex;
|
|
||||||
var memberSearchIndex;
|
|
||||||
var tagSearchIndex;
|
|
||||||
|
|
||||||
var oddRowColor = "odd-row-color";
|
|
||||||
var evenRowColor = "even-row-color";
|
|
||||||
var sortAsc = "sort-asc";
|
|
||||||
var sortDesc = "sort-desc";
|
|
||||||
var tableTab = "table-tab";
|
|
||||||
var activeTableTab = "active-table-tab";
|
|
||||||
|
|
||||||
function loadScripts(doc, tag) {
|
|
||||||
createElem(doc, tag, 'script-files/search.js');
|
|
||||||
|
|
||||||
createElem(doc, tag, 'module-search-index.js');
|
|
||||||
createElem(doc, tag, 'package-search-index.js');
|
|
||||||
createElem(doc, tag, 'type-search-index.js');
|
|
||||||
createElem(doc, tag, 'member-search-index.js');
|
|
||||||
createElem(doc, tag, 'tag-search-index.js');
|
|
||||||
}
|
|
||||||
|
|
||||||
function createElem(doc, tag, path) {
|
|
||||||
var script = doc.createElement(tag);
|
|
||||||
var scriptElement = doc.getElementsByTagName(tag)[0];
|
|
||||||
script.src = pathtoroot + path;
|
|
||||||
scriptElement.parentNode.insertBefore(script, scriptElement);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Helper for making content containing release names comparable lexicographically
|
|
||||||
function makeComparable(s) {
|
|
||||||
return s.toLowerCase().replace(/(\d+)/g,
|
|
||||||
function(n, m) {
|
|
||||||
return ("000" + m).slice(-4);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
// Switches between two styles depending on a condition
|
|
||||||
function toggleStyle(classList, condition, trueStyle, falseStyle) {
|
|
||||||
if (condition) {
|
|
||||||
classList.remove(falseStyle);
|
|
||||||
classList.add(trueStyle);
|
|
||||||
} else {
|
|
||||||
classList.remove(trueStyle);
|
|
||||||
classList.add(falseStyle);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Sorts the rows in a table lexicographically by the content of a specific column
|
|
||||||
function sortTable(header, columnIndex, columns) {
|
|
||||||
var container = header.parentElement;
|
|
||||||
var descending = header.classList.contains(sortAsc);
|
|
||||||
container.querySelectorAll("div.table-header").forEach(
|
|
||||||
function(header) {
|
|
||||||
header.classList.remove(sortAsc);
|
|
||||||
header.classList.remove(sortDesc);
|
|
||||||
}
|
|
||||||
)
|
|
||||||
var cells = container.children;
|
|
||||||
var rows = [];
|
|
||||||
for (var i = columns; i < cells.length; i += columns) {
|
|
||||||
rows.push(Array.prototype.slice.call(cells, i, i + columns));
|
|
||||||
}
|
|
||||||
var comparator = function(a, b) {
|
|
||||||
var ka = makeComparable(a[columnIndex].textContent);
|
|
||||||
var kb = makeComparable(b[columnIndex].textContent);
|
|
||||||
if (ka < kb)
|
|
||||||
return descending ? 1 : -1;
|
|
||||||
if (ka > kb)
|
|
||||||
return descending ? -1 : 1;
|
|
||||||
return 0;
|
|
||||||
};
|
|
||||||
var sorted = rows.sort(comparator);
|
|
||||||
var visible = 0;
|
|
||||||
sorted.forEach(function(row) {
|
|
||||||
if (row[0].style.display !== 'none') {
|
|
||||||
var isEvenRow = visible++ % 2 === 0;
|
|
||||||
}
|
|
||||||
row.forEach(function(cell) {
|
|
||||||
toggleStyle(cell.classList, isEvenRow, evenRowColor, oddRowColor);
|
|
||||||
container.appendChild(cell);
|
|
||||||
})
|
|
||||||
});
|
|
||||||
toggleStyle(header.classList, descending, sortDesc, sortAsc);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Toggles the visibility of a table category in all tables in a page
|
|
||||||
function toggleGlobal(checkbox, selected, columns) {
|
|
||||||
var display = checkbox.checked ? '' : 'none';
|
|
||||||
document.querySelectorAll("div.table-tabs").forEach(function(t) {
|
|
||||||
var id = t.parentElement.getAttribute("id");
|
|
||||||
var selectedClass = id + "-tab" + selected;
|
|
||||||
// if selected is empty string it selects all uncategorized entries
|
|
||||||
var selectUncategorized = !Boolean(selected);
|
|
||||||
var visible = 0;
|
|
||||||
document.querySelectorAll('div.' + id)
|
|
||||||
.forEach(function(elem) {
|
|
||||||
if (selectUncategorized) {
|
|
||||||
if (elem.className.indexOf(selectedClass) === -1) {
|
|
||||||
elem.style.display = display;
|
|
||||||
}
|
|
||||||
} else if (elem.classList.contains(selectedClass)) {
|
|
||||||
elem.style.display = display;
|
|
||||||
}
|
|
||||||
if (elem.style.display === '') {
|
|
||||||
var isEvenRow = visible++ % (columns * 2) < columns;
|
|
||||||
toggleStyle(elem.classList, isEvenRow, evenRowColor, oddRowColor);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
var displaySection = visible === 0 ? 'none' : '';
|
|
||||||
t.parentElement.style.display = displaySection;
|
|
||||||
document.querySelector("li#contents-" + id).style.display = displaySection;
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
// Shows the elements of a table belonging to a specific category
|
|
||||||
function show(tableId, selected, columns) {
|
|
||||||
if (tableId !== selected) {
|
|
||||||
document.querySelectorAll('div.' + tableId + ':not(.' + selected + ')')
|
|
||||||
.forEach(function(elem) {
|
|
||||||
elem.style.display = 'none';
|
|
||||||
});
|
|
||||||
}
|
|
||||||
document.querySelectorAll('div.' + selected)
|
|
||||||
.forEach(function(elem, index) {
|
|
||||||
elem.style.display = '';
|
|
||||||
var isEvenRow = index % (columns * 2) < columns;
|
|
||||||
toggleStyle(elem.classList, isEvenRow, evenRowColor, oddRowColor);
|
|
||||||
});
|
|
||||||
updateTabs(tableId, selected);
|
|
||||||
}
|
|
||||||
|
|
||||||
function updateTabs(tableId, selected) {
|
|
||||||
document.querySelector('div#' + tableId +' .summary-table')
|
|
||||||
.setAttribute('aria-labelledby', selected);
|
|
||||||
document.querySelectorAll('button[id^="' + tableId + '"]')
|
|
||||||
.forEach(function(tab, index) {
|
|
||||||
if (selected === tab.id || (tableId === selected && index === 0)) {
|
|
||||||
tab.className = activeTableTab;
|
|
||||||
tab.setAttribute('aria-selected', true);
|
|
||||||
tab.setAttribute('tabindex',0);
|
|
||||||
} else {
|
|
||||||
tab.className = tableTab;
|
|
||||||
tab.setAttribute('aria-selected', false);
|
|
||||||
tab.setAttribute('tabindex',-1);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
function switchTab(e) {
|
|
||||||
var selected = document.querySelector('[aria-selected=true]');
|
|
||||||
if (selected) {
|
|
||||||
if ((e.keyCode === 37 || e.keyCode === 38) && selected.previousSibling) {
|
|
||||||
// left or up arrow key pressed: move focus to previous tab
|
|
||||||
selected.previousSibling.click();
|
|
||||||
selected.previousSibling.focus();
|
|
||||||
e.preventDefault();
|
|
||||||
} else if ((e.keyCode === 39 || e.keyCode === 40) && selected.nextSibling) {
|
|
||||||
// right or down arrow key pressed: move focus to next tab
|
|
||||||
selected.nextSibling.click();
|
|
||||||
selected.nextSibling.focus();
|
|
||||||
e.preventDefault();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var updateSearchResults = function() {};
|
|
||||||
|
|
||||||
function indexFilesLoaded() {
|
|
||||||
return moduleSearchIndex
|
|
||||||
&& packageSearchIndex
|
|
||||||
&& typeSearchIndex
|
|
||||||
&& memberSearchIndex
|
|
||||||
&& tagSearchIndex;
|
|
||||||
}
|
|
||||||
// Copy the contents of the local snippet to the clipboard
|
|
||||||
function copySnippet(button) {
|
|
||||||
copyToClipboard(button.nextElementSibling.innerText);
|
|
||||||
switchCopyLabel(button, button.firstElementChild);
|
|
||||||
}
|
|
||||||
function copyToClipboard(content) {
|
|
||||||
var textarea = document.createElement("textarea");
|
|
||||||
textarea.style.height = 0;
|
|
||||||
document.body.appendChild(textarea);
|
|
||||||
textarea.value = content;
|
|
||||||
textarea.select();
|
|
||||||
document.execCommand("copy");
|
|
||||||
document.body.removeChild(textarea);
|
|
||||||
}
|
|
||||||
function switchCopyLabel(button, span) {
|
|
||||||
var copied = span.getAttribute("data-copied");
|
|
||||||
button.classList.add("visible");
|
|
||||||
var initialLabel = span.innerHTML;
|
|
||||||
span.innerHTML = copied;
|
|
||||||
setTimeout(function() {
|
|
||||||
button.classList.remove("visible");
|
|
||||||
setTimeout(function() {
|
|
||||||
if (initialLabel !== copied) {
|
|
||||||
span.innerHTML = initialLabel;
|
|
||||||
}
|
|
||||||
}, 100);
|
|
||||||
}, 1900);
|
|
||||||
}
|
|
||||||
// Dynamically set scroll margin to accomodate for draft header
|
|
||||||
document.addEventListener("DOMContentLoaded", function(e) {
|
|
||||||
document.querySelectorAll(':not(input)[id]').forEach(
|
|
||||||
function(c) {
|
|
||||||
c.style["scroll-margin-top"] = Math.ceil(document.querySelector("header").offsetHeight) + "px"
|
|
||||||
});
|
|
||||||
});
|
|
@ -0,0 +1,481 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2013, 2024, 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
var moduleSearchIndex;
|
||||||
|
var packageSearchIndex;
|
||||||
|
var typeSearchIndex;
|
||||||
|
var memberSearchIndex;
|
||||||
|
var tagSearchIndex;
|
||||||
|
|
||||||
|
var oddRowColor = "odd-row-color";
|
||||||
|
var evenRowColor = "even-row-color";
|
||||||
|
var sortAsc = "sort-asc";
|
||||||
|
var sortDesc = "sort-desc";
|
||||||
|
var tableTab = "table-tab";
|
||||||
|
var activeTableTab = "active-table-tab";
|
||||||
|
|
||||||
|
const linkIcon = "##REPLACE:doclet.Link_icon##";
|
||||||
|
const linkToSection = "##REPLACE:doclet.Link_to_section##";
|
||||||
|
|
||||||
|
function loadScripts(doc, tag) {
|
||||||
|
createElem(doc, tag, 'script-files/search.js');
|
||||||
|
|
||||||
|
createElem(doc, tag, 'module-search-index.js');
|
||||||
|
createElem(doc, tag, 'package-search-index.js');
|
||||||
|
createElem(doc, tag, 'type-search-index.js');
|
||||||
|
createElem(doc, tag, 'member-search-index.js');
|
||||||
|
createElem(doc, tag, 'tag-search-index.js');
|
||||||
|
}
|
||||||
|
|
||||||
|
function createElem(doc, tag, path) {
|
||||||
|
var script = doc.createElement(tag);
|
||||||
|
var scriptElement = doc.getElementsByTagName(tag)[0];
|
||||||
|
script.src = pathtoroot + path;
|
||||||
|
scriptElement.parentNode.insertBefore(script, scriptElement);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Helper for making content containing release names comparable lexicographically
|
||||||
|
function makeComparable(s) {
|
||||||
|
return s.toLowerCase().replace(/(\d+)/g,
|
||||||
|
function(n, m) {
|
||||||
|
return ("000" + m).slice(-4);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// Switches between two styles depending on a condition
|
||||||
|
function toggleStyle(classList, condition, trueStyle, falseStyle) {
|
||||||
|
if (condition) {
|
||||||
|
classList.remove(falseStyle);
|
||||||
|
classList.add(trueStyle);
|
||||||
|
} else {
|
||||||
|
classList.remove(trueStyle);
|
||||||
|
classList.add(falseStyle);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Sorts the rows in a table lexicographically by the content of a specific column
|
||||||
|
function sortTable(header, columnIndex, columns) {
|
||||||
|
var container = header.parentElement;
|
||||||
|
var descending = header.classList.contains(sortAsc);
|
||||||
|
container.querySelectorAll("div.table-header").forEach(
|
||||||
|
function(header) {
|
||||||
|
header.classList.remove(sortAsc);
|
||||||
|
header.classList.remove(sortDesc);
|
||||||
|
}
|
||||||
|
)
|
||||||
|
var cells = container.children;
|
||||||
|
var rows = [];
|
||||||
|
for (var i = columns; i < cells.length; i += columns) {
|
||||||
|
rows.push(Array.prototype.slice.call(cells, i, i + columns));
|
||||||
|
}
|
||||||
|
var comparator = function(a, b) {
|
||||||
|
var ka = makeComparable(a[columnIndex].textContent);
|
||||||
|
var kb = makeComparable(b[columnIndex].textContent);
|
||||||
|
if (ka < kb)
|
||||||
|
return descending ? 1 : -1;
|
||||||
|
if (ka > kb)
|
||||||
|
return descending ? -1 : 1;
|
||||||
|
return 0;
|
||||||
|
};
|
||||||
|
var sorted = rows.sort(comparator);
|
||||||
|
var visible = 0;
|
||||||
|
sorted.forEach(function(row) {
|
||||||
|
if (row[0].style.display !== 'none') {
|
||||||
|
var isEvenRow = visible++ % 2 === 0;
|
||||||
|
}
|
||||||
|
row.forEach(function(cell) {
|
||||||
|
toggleStyle(cell.classList, isEvenRow, evenRowColor, oddRowColor);
|
||||||
|
container.appendChild(cell);
|
||||||
|
})
|
||||||
|
});
|
||||||
|
toggleStyle(header.classList, descending, sortDesc, sortAsc);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Toggles the visibility of a table category in all tables in a page
|
||||||
|
function toggleGlobal(checkbox, selected, columns) {
|
||||||
|
var display = checkbox.checked ? '' : 'none';
|
||||||
|
document.querySelectorAll("div.table-tabs").forEach(function(t) {
|
||||||
|
var id = t.parentElement.getAttribute("id");
|
||||||
|
var selectedClass = id + "-tab" + selected;
|
||||||
|
// if selected is empty string it selects all uncategorized entries
|
||||||
|
var selectUncategorized = !Boolean(selected);
|
||||||
|
var visible = 0;
|
||||||
|
document.querySelectorAll('div.' + id)
|
||||||
|
.forEach(function(elem) {
|
||||||
|
if (selectUncategorized) {
|
||||||
|
if (elem.className.indexOf(selectedClass) === -1) {
|
||||||
|
elem.style.display = display;
|
||||||
|
}
|
||||||
|
} else if (elem.classList.contains(selectedClass)) {
|
||||||
|
elem.style.display = display;
|
||||||
|
}
|
||||||
|
if (elem.style.display === '') {
|
||||||
|
var isEvenRow = visible++ % (columns * 2) < columns;
|
||||||
|
toggleStyle(elem.classList, isEvenRow, evenRowColor, oddRowColor);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
var displaySection = visible === 0 ? 'none' : '';
|
||||||
|
t.parentElement.style.display = displaySection;
|
||||||
|
document.querySelector("li#contents-" + id).style.display = displaySection;
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
// Shows the elements of a table belonging to a specific category
|
||||||
|
function show(tableId, selected, columns) {
|
||||||
|
if (tableId !== selected) {
|
||||||
|
document.querySelectorAll('div.' + tableId + ':not(.' + selected + ')')
|
||||||
|
.forEach(function(elem) {
|
||||||
|
elem.style.display = 'none';
|
||||||
|
});
|
||||||
|
}
|
||||||
|
document.querySelectorAll('div.' + selected)
|
||||||
|
.forEach(function(elem, index) {
|
||||||
|
elem.style.display = '';
|
||||||
|
var isEvenRow = index % (columns * 2) < columns;
|
||||||
|
toggleStyle(elem.classList, isEvenRow, evenRowColor, oddRowColor);
|
||||||
|
});
|
||||||
|
updateTabs(tableId, selected);
|
||||||
|
}
|
||||||
|
|
||||||
|
function updateTabs(tableId, selected) {
|
||||||
|
document.querySelector('div#' + tableId +' .summary-table')
|
||||||
|
.setAttribute('aria-labelledby', selected);
|
||||||
|
document.querySelectorAll('button[id^="' + tableId + '"]')
|
||||||
|
.forEach(function(tab, index) {
|
||||||
|
if (selected === tab.id || (tableId === selected && index === 0)) {
|
||||||
|
tab.className = activeTableTab;
|
||||||
|
tab.setAttribute('aria-selected', true);
|
||||||
|
tab.setAttribute('tabindex',0);
|
||||||
|
} else {
|
||||||
|
tab.className = tableTab;
|
||||||
|
tab.setAttribute('aria-selected', false);
|
||||||
|
tab.setAttribute('tabindex',-1);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function switchTab(e) {
|
||||||
|
var selected = document.querySelector('[aria-selected=true]');
|
||||||
|
if (selected) {
|
||||||
|
if ((e.keyCode === 37 || e.keyCode === 38) && selected.previousSibling) {
|
||||||
|
// left or up arrow key pressed: move focus to previous tab
|
||||||
|
selected.previousSibling.click();
|
||||||
|
selected.previousSibling.focus();
|
||||||
|
e.preventDefault();
|
||||||
|
} else if ((e.keyCode === 39 || e.keyCode === 40) && selected.nextSibling) {
|
||||||
|
// right or down arrow key pressed: move focus to next tab
|
||||||
|
selected.nextSibling.click();
|
||||||
|
selected.nextSibling.focus();
|
||||||
|
e.preventDefault();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var updateSearchResults = function() {};
|
||||||
|
|
||||||
|
function indexFilesLoaded() {
|
||||||
|
return moduleSearchIndex
|
||||||
|
&& packageSearchIndex
|
||||||
|
&& typeSearchIndex
|
||||||
|
&& memberSearchIndex
|
||||||
|
&& tagSearchIndex;
|
||||||
|
}
|
||||||
|
// Copy the contents of the local snippet to the clipboard
|
||||||
|
function copySnippet(button) {
|
||||||
|
copyToClipboard(button.nextElementSibling.innerText);
|
||||||
|
switchCopyLabel(button, button.firstElementChild);
|
||||||
|
}
|
||||||
|
function copyToClipboard(content) {
|
||||||
|
var textarea = document.createElement("textarea");
|
||||||
|
textarea.style.height = 0;
|
||||||
|
document.body.appendChild(textarea);
|
||||||
|
textarea.value = content;
|
||||||
|
textarea.select();
|
||||||
|
document.execCommand("copy");
|
||||||
|
document.body.removeChild(textarea);
|
||||||
|
}
|
||||||
|
function switchCopyLabel(button, span) {
|
||||||
|
var copied = span.getAttribute("data-copied");
|
||||||
|
button.classList.add("visible");
|
||||||
|
var initialLabel = span.innerHTML;
|
||||||
|
span.innerHTML = copied;
|
||||||
|
setTimeout(function() {
|
||||||
|
button.classList.remove("visible");
|
||||||
|
setTimeout(function() {
|
||||||
|
if (initialLabel !== copied) {
|
||||||
|
span.innerHTML = initialLabel;
|
||||||
|
}
|
||||||
|
}, 100);
|
||||||
|
}, 1900);
|
||||||
|
}
|
||||||
|
function setTopMargin() {
|
||||||
|
// Dynamically set scroll margin to accomodate for draft header
|
||||||
|
var headerHeight = Math.ceil(document.querySelector("header").offsetHeight);
|
||||||
|
document.querySelector(":root")
|
||||||
|
.style.setProperty("--nav-height", headerHeight + "px");
|
||||||
|
}
|
||||||
|
document.addEventListener("readystatechange", (e) => {
|
||||||
|
if (document.readyState === "interactive") {
|
||||||
|
setTopMargin();
|
||||||
|
}
|
||||||
|
if (sessionStorage.getItem("sidebar") === "hidden") {
|
||||||
|
const sidebar = document.querySelector(".main-grid nav.toc");
|
||||||
|
if (sidebar) sidebar.classList.add("hide-sidebar");
|
||||||
|
}
|
||||||
|
});
|
||||||
|
document.addEventListener("DOMContentLoaded", function(e) {
|
||||||
|
setTopMargin();
|
||||||
|
// Make sure current element is visible in breadcrumb navigation on small displays
|
||||||
|
const subnav = document.querySelector("ol.sub-nav-list");
|
||||||
|
if (subnav && subnav.lastElementChild) {
|
||||||
|
subnav.lastElementChild.scrollIntoView({ behavior: "instant", inline: "start", block: "nearest" });
|
||||||
|
}
|
||||||
|
// Clone TOC sidebar to header for mobile navigation
|
||||||
|
const navbar = document.querySelector("div#navbar-top");
|
||||||
|
const sidebar = document.querySelector(".main-grid nav.toc");
|
||||||
|
const main = document.querySelector(".main-grid main");
|
||||||
|
const mainnav = navbar.querySelector("ul.nav-list");
|
||||||
|
const toggleButton = document.querySelector("button#navbar-toggle-button");
|
||||||
|
const toc = sidebar ? sidebar.cloneNode(true) : null;
|
||||||
|
if (toc) {
|
||||||
|
navbar.appendChild(toc);
|
||||||
|
}
|
||||||
|
document.querySelectorAll("input.filter-input").forEach(function(input) {
|
||||||
|
input.removeAttribute("disabled");
|
||||||
|
input.value = "";
|
||||||
|
input.addEventListener("input", function(e) {
|
||||||
|
const pattern = input.value ? input.value.trim()
|
||||||
|
.replace(/[\[\]{}()*+?.\\^$|]/g, '\\$&')
|
||||||
|
.replace(/\s+/g, ".*") : "";
|
||||||
|
input.nextElementSibling.style.display = pattern ? "inline" : "none";
|
||||||
|
const filter = new RegExp(pattern, "i");
|
||||||
|
input.parentNode.parentNode.querySelectorAll("ol.toc-list li").forEach((li) => {
|
||||||
|
if (filter.test(li.innerText)) {
|
||||||
|
li.removeAttribute("style");
|
||||||
|
} else {
|
||||||
|
li.style.display = "none";
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if (expanded) {
|
||||||
|
expand();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
document.querySelectorAll("input.reset-filter").forEach((button) => {
|
||||||
|
button.removeAttribute("disabled");
|
||||||
|
button.addEventListener("click", (e) => {
|
||||||
|
const input = button.previousElementSibling;
|
||||||
|
input.value = "";
|
||||||
|
input.dispatchEvent(new InputEvent("input"));
|
||||||
|
input.focus();
|
||||||
|
if (expanded) {
|
||||||
|
expand();
|
||||||
|
} else {
|
||||||
|
prevHash = null;
|
||||||
|
handleScroll();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
});
|
||||||
|
var expanded = false;
|
||||||
|
var windowWidth;
|
||||||
|
function collapse() {
|
||||||
|
if (expanded) {
|
||||||
|
mainnav.removeAttribute("style");
|
||||||
|
if (toc) {
|
||||||
|
toc.removeAttribute("style");
|
||||||
|
}
|
||||||
|
toggleButton.classList.remove("expanded")
|
||||||
|
toggleButton.setAttribute("aria-expanded", "false");
|
||||||
|
expanded = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function expand() {
|
||||||
|
expanded = true;
|
||||||
|
mainnav.style.display = "block";
|
||||||
|
mainnav.style.removeProperty("height");
|
||||||
|
var maxHeight = window.innerHeight - subnav.offsetTop + 4;
|
||||||
|
var expandedHeight = Math.min(maxHeight, mainnav.scrollHeight + 10);
|
||||||
|
if (toc) {
|
||||||
|
toc.style.display = "flex";
|
||||||
|
expandedHeight = Math.min(maxHeight,
|
||||||
|
Math.max(expandedHeight, toc.querySelector("div.toc-header").offsetHeight
|
||||||
|
+ toc.querySelector("ol.toc-list").scrollHeight + 10));
|
||||||
|
toc.style.height = expandedHeight + "px";
|
||||||
|
}
|
||||||
|
mainnav.style.height = expandedHeight + "px";
|
||||||
|
toggleButton.classList.add("expanded");
|
||||||
|
toggleButton.setAttribute("aria-expanded", "true");
|
||||||
|
windowWidth = window.innerWidth;
|
||||||
|
}
|
||||||
|
toggleButton.addEventListener("click", (e) => {
|
||||||
|
if (expanded) {
|
||||||
|
collapse();
|
||||||
|
} else {
|
||||||
|
expand();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if (toc) {
|
||||||
|
toc.querySelectorAll("a").forEach((link) => {
|
||||||
|
link.addEventListener("click", collapse);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
document.addEventListener('keydown', (e) => {
|
||||||
|
if (e.key === "Escape") collapse();
|
||||||
|
});
|
||||||
|
document.querySelector("main").addEventListener("click", collapse);
|
||||||
|
const searchInput = document.getElementById("search-input");
|
||||||
|
if (searchInput) searchInput.addEventListener("focus", collapse);
|
||||||
|
document.querySelectorAll("h1, h2, h3, h4, h5, h6")
|
||||||
|
.forEach((hdr, idx) => {
|
||||||
|
// Create anchor links for headers with an associated id attribute
|
||||||
|
var id = hdr.getAttribute("id") || hdr.parentElement.getAttribute("id")
|
||||||
|
|| (hdr.querySelector("a") && hdr.querySelector("a").getAttribute("id"));
|
||||||
|
if (id) {
|
||||||
|
var template = document.createElement('template');
|
||||||
|
template.innerHTML =" <a href='#" + encodeURI(id) + "' class='anchor-link' aria-label='" + linkToSection
|
||||||
|
+ "'><img src='" + pathtoroot + "resource-files/link.svg' alt='" + linkIcon +"' tabindex='0'"
|
||||||
|
+ " width='16' height='16'></a>";
|
||||||
|
hdr.append(...template.content.childNodes);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
var sections;
|
||||||
|
var scrollTimeout;
|
||||||
|
var scrollTimeoutNeeded;
|
||||||
|
var prevHash;
|
||||||
|
function initSectionData() {
|
||||||
|
sections = [{ id: "", top: 0 }].concat(Array.from(main.querySelectorAll("section[id], h2[id], h2 a[id], div[id]"))
|
||||||
|
.filter((e) => {
|
||||||
|
return sidebar.querySelector("a[href=\"#" + encodeURI(e.getAttribute("id")) + "\"]") !== null
|
||||||
|
}).map((e) => {
|
||||||
|
return {
|
||||||
|
id: e.getAttribute("id"),
|
||||||
|
top: e.offsetTop
|
||||||
|
};
|
||||||
|
}));
|
||||||
|
}
|
||||||
|
function setScrollTimeout() {
|
||||||
|
clearTimeout(scrollTimeout);
|
||||||
|
scrollTimeoutNeeded = false;
|
||||||
|
scrollTimeout = setTimeout(() => {
|
||||||
|
scrollTimeout = null;
|
||||||
|
handleScroll();
|
||||||
|
}, 50);
|
||||||
|
}
|
||||||
|
function handleScroll() {
|
||||||
|
if (!sidebar || !sidebar.offsetParent || sidebar.classList.contains("hide-sidebar")) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (scrollTimeout || scrollTimeoutNeeded) {
|
||||||
|
setScrollTimeout();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
var scrollTop = document.documentElement.scrollTop;
|
||||||
|
var scrollHeight = document.documentElement.scrollHeight;
|
||||||
|
var currHash = null;
|
||||||
|
if (scrollHeight - scrollTop < window.innerHeight + 10) {
|
||||||
|
// Select last item if at bottom of the page
|
||||||
|
currHash = "#" + encodeURI(sections.at(-1).id);
|
||||||
|
} else {
|
||||||
|
for (var i = 0; i < sections.length; i++) {
|
||||||
|
var top = sections[i].top;
|
||||||
|
var bottom = sections[i + 1] ? sections[i + 1].top : scrollHeight;
|
||||||
|
if (top + ((bottom - top) / 2) > scrollTop || bottom > scrollTop + (window.innerHeight / 3)) {
|
||||||
|
currHash = "#" + encodeURI(sections[i].id);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (currHash !== prevHash) {
|
||||||
|
setSelected(currHash);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function setSelected(hash) {
|
||||||
|
var prev = sidebar.querySelector("a.current-selection");
|
||||||
|
if (prev)
|
||||||
|
prev.classList.remove("current-selection");
|
||||||
|
prevHash = hash;
|
||||||
|
if (hash) {
|
||||||
|
var curr = sidebar.querySelector("ol.toc-list a[href=\"" + hash + "\"]");
|
||||||
|
if (curr) {
|
||||||
|
curr.classList.add("current-selection");
|
||||||
|
curr.scrollIntoView({ behavior: "instant", block: "nearest" });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (sidebar) {
|
||||||
|
initSectionData();
|
||||||
|
document.querySelectorAll("a[href^='#']").forEach((link) => {
|
||||||
|
link.addEventListener("click", (e) => {
|
||||||
|
scrollTimeoutNeeded = true;
|
||||||
|
setSelected(link.getAttribute("href"));
|
||||||
|
})
|
||||||
|
});
|
||||||
|
sidebar.querySelector("button.hide-sidebar").addEventListener("click", () => {
|
||||||
|
sidebar.classList.add("hide-sidebar");
|
||||||
|
sessionStorage.setItem("sidebar", "hidden");
|
||||||
|
});
|
||||||
|
sidebar.querySelector("button.show-sidebar").addEventListener("click", () => {
|
||||||
|
sidebar.classList.remove("hide-sidebar");
|
||||||
|
sessionStorage.removeItem("sidebar");
|
||||||
|
initSectionData();
|
||||||
|
handleScroll();
|
||||||
|
});
|
||||||
|
window.addEventListener("hashchange", (e) => {
|
||||||
|
scrollTimeoutNeeded = true;
|
||||||
|
});
|
||||||
|
if (document.location.hash) {
|
||||||
|
scrollTimeoutNeeded = true;
|
||||||
|
setSelected(document.location.hash);
|
||||||
|
} else {
|
||||||
|
handleScroll();
|
||||||
|
}
|
||||||
|
window.addEventListener("scroll", handleScroll);
|
||||||
|
window.addEventListener("scrollend", () => {
|
||||||
|
if (scrollTimeout) {
|
||||||
|
clearTimeout(scrollTimeout);
|
||||||
|
scrollTimeout = null;
|
||||||
|
handleScroll();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
// Resize handler
|
||||||
|
function handleResize(e) {
|
||||||
|
if (expanded) {
|
||||||
|
if (windowWidth != window.innerWidth) {
|
||||||
|
collapse();
|
||||||
|
} else {
|
||||||
|
expand();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (sections) {
|
||||||
|
initSectionData();
|
||||||
|
prevHash = null;
|
||||||
|
handleScroll();
|
||||||
|
}
|
||||||
|
setTopMargin();
|
||||||
|
}
|
||||||
|
window.addEventListener("orientationchange", handleResize);
|
||||||
|
window.addEventListener("resize", handleResize);
|
||||||
|
});
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -31,8 +31,6 @@ const messages = {
|
|||||||
loading: "##REPLACE:doclet.search.loading##",
|
loading: "##REPLACE:doclet.search.loading##",
|
||||||
searching: "##REPLACE:doclet.search.searching##",
|
searching: "##REPLACE:doclet.search.searching##",
|
||||||
redirecting: "##REPLACE:doclet.search.redirecting##",
|
redirecting: "##REPLACE:doclet.search.redirecting##",
|
||||||
linkIcon: "##REPLACE:doclet.Link_icon##",
|
|
||||||
linkToSection: "##REPLACE:doclet.Link_to_section##"
|
|
||||||
}
|
}
|
||||||
const categories = {
|
const categories = {
|
||||||
modules: "##REPLACE:doclet.search.modules##",
|
modules: "##REPLACE:doclet.search.modules##",
|
||||||
@ -255,9 +253,6 @@ function rateNoise(str) {
|
|||||||
function doSearch(request, response) {
|
function doSearch(request, response) {
|
||||||
var term = request.term.trim();
|
var term = request.term.trim();
|
||||||
var maxResults = request.maxResults || MAX_RESULTS;
|
var maxResults = request.maxResults || MAX_RESULTS;
|
||||||
if (term.length === 0) {
|
|
||||||
return this.close();
|
|
||||||
}
|
|
||||||
var matcher = {
|
var matcher = {
|
||||||
plainMatcher: createMatcher(term, false),
|
plainMatcher: createMatcher(term, false),
|
||||||
camelCaseMatcher: createMatcher(term, true)
|
camelCaseMatcher: createMatcher(term, true)
|
||||||
@ -407,52 +402,18 @@ $.widget("custom.catcomplete", $.ui.autocomplete, {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
$(function() {
|
$(function() {
|
||||||
var expanded = false;
|
|
||||||
var windowWidth;
|
|
||||||
function collapse() {
|
|
||||||
if (expanded) {
|
|
||||||
$("div#navbar-top").removeAttr("style");
|
|
||||||
$("button#navbar-toggle-button")
|
|
||||||
.removeClass("expanded")
|
|
||||||
.attr("aria-expanded", "false");
|
|
||||||
expanded = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$("button#navbar-toggle-button").click(function (e) {
|
|
||||||
if (expanded) {
|
|
||||||
collapse();
|
|
||||||
} else {
|
|
||||||
var navbar = $("div#navbar-top");
|
|
||||||
navbar.height(navbar.prop("scrollHeight"));
|
|
||||||
$("button#navbar-toggle-button")
|
|
||||||
.addClass("expanded")
|
|
||||||
.attr("aria-expanded", "true");
|
|
||||||
expanded = true;
|
|
||||||
windowWidth = window.innerWidth;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
$("ul.sub-nav-list-small li a").click(collapse);
|
|
||||||
$("input#search-input").focus(collapse);
|
|
||||||
$("main").click(collapse);
|
|
||||||
$("section[id] > :header, :header[id], :header:has(a[id])").each(function(idx, el) {
|
|
||||||
// Create anchor links for headers with an associated id attribute
|
|
||||||
var hdr = $(el);
|
|
||||||
var id = hdr.attr("id") || hdr.parent("section").attr("id") || hdr.children("a").attr("id");
|
|
||||||
if (id) {
|
|
||||||
hdr.append(" <a href='#" + id + "' class='anchor-link' aria-label='" + messages.linkToSection
|
|
||||||
+ "'><img src='" + pathtoroot + "resource-files/link.svg' alt='" + messages.linkIcon +"' tabindex='0'"
|
|
||||||
+ " width='16' height='16'></a>");
|
|
||||||
}
|
|
||||||
});
|
|
||||||
$(window).on("orientationchange", collapse).on("resize", function(e) {
|
|
||||||
if (expanded && windowWidth !== window.innerWidth) collapse();
|
|
||||||
});
|
|
||||||
var search = $("#search-input");
|
var search = $("#search-input");
|
||||||
var reset = $("#reset-button");
|
var reset = $("#reset-search");
|
||||||
search.catcomplete({
|
search.catcomplete({
|
||||||
minLength: 1,
|
minLength: 1,
|
||||||
delay: 200,
|
delay: 200,
|
||||||
source: doSearch,
|
source: function(request, response) {
|
||||||
|
reset.css("display", "inline");
|
||||||
|
if (request.term.trim() === "") {
|
||||||
|
return this.close();
|
||||||
|
}
|
||||||
|
return doSearch(request, response);
|
||||||
|
},
|
||||||
response: function(event, ui) {
|
response: function(event, ui) {
|
||||||
if (!ui.content.length) {
|
if (!ui.content.length) {
|
||||||
ui.content.push({ l: messages.noResult });
|
ui.content.push({ l: messages.noResult });
|
||||||
@ -460,6 +421,12 @@ $(function() {
|
|||||||
$("#search-input").empty();
|
$("#search-input").empty();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
close: function(event, ui) {
|
||||||
|
reset.css("display", search.val() ? "inline" : "none");
|
||||||
|
},
|
||||||
|
change: function(event, ui) {
|
||||||
|
reset.css("display", search.val() ? "inline" : "none");
|
||||||
|
},
|
||||||
autoFocus: true,
|
autoFocus: true,
|
||||||
focus: function(event, ui) {
|
focus: function(event, ui) {
|
||||||
return false;
|
return false;
|
||||||
@ -480,6 +447,7 @@ $(function() {
|
|||||||
reset.prop("disabled", false);
|
reset.prop("disabled", false);
|
||||||
reset.click(function() {
|
reset.click(function() {
|
||||||
search.val('').focus();
|
search.val('').focus();
|
||||||
|
reset.css("display", "none");
|
||||||
});
|
});
|
||||||
search.focus();
|
search.focus();
|
||||||
});
|
});
|
||||||
|
@ -15,7 +15,11 @@
|
|||||||
--code-font-family: 'DejaVu Sans Mono', monospace;
|
--code-font-family: 'DejaVu Sans Mono', monospace;
|
||||||
/* Base font sizes for body and code elements */
|
/* Base font sizes for body and code elements */
|
||||||
--body-font-size: 14px;
|
--body-font-size: 14px;
|
||||||
|
--block-font-size: 14px;
|
||||||
--code-font-size: 14px;
|
--code-font-size: 14px;
|
||||||
|
--nav-font-size: 13.2px;
|
||||||
|
/* Line height for continuous text blocks */
|
||||||
|
--block-line-height: 1.4em;
|
||||||
/* Text colors for body and block elements */
|
/* Text colors for body and block elements */
|
||||||
--body-text-color: #353833;
|
--body-text-color: #353833;
|
||||||
--block-text-color: #474747;
|
--block-text-color: #474747;
|
||||||
@ -59,6 +63,11 @@
|
|||||||
/* Colors for invalid tag notifications */
|
/* Colors for invalid tag notifications */
|
||||||
--invalid-tag-background-color: #ffe6e6;
|
--invalid-tag-background-color: #ffe6e6;
|
||||||
--invalid-tag-text-color: #000000;
|
--invalid-tag-text-color: #000000;
|
||||||
|
/* Navigation bar dimensions */
|
||||||
|
--top-nav-height: 44px;
|
||||||
|
--sub-nav-height: 34px;
|
||||||
|
--nav-height: calc(var(--top-nav-height) + var(--sub-nav-height));
|
||||||
|
scroll-behavior: smooth;
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
* Styles for individual HTML elements.
|
* Styles for individual HTML elements.
|
||||||
@ -76,28 +85,20 @@ body {
|
|||||||
height:100%;
|
height:100%;
|
||||||
width:100%;
|
width:100%;
|
||||||
}
|
}
|
||||||
iframe {
|
main [id] {
|
||||||
margin:0;
|
scroll-margin-top: calc(var(--nav-height) + 6px);
|
||||||
padding:0;
|
|
||||||
height:100%;
|
|
||||||
width:100%;
|
|
||||||
overflow-y:scroll;
|
|
||||||
border:none;
|
|
||||||
}
|
|
||||||
:not(input)[id] {
|
|
||||||
scroll-margin-top: 78px;
|
|
||||||
}
|
}
|
||||||
a:link, a:visited {
|
a:link, a:visited {
|
||||||
text-decoration:none;
|
text-decoration:none;
|
||||||
color:var(--link-color);
|
color:var(--link-color);
|
||||||
}
|
}
|
||||||
a[href]:hover, a[href]:focus {
|
a[href]:hover, a[href]:active {
|
||||||
text-decoration:none;
|
text-decoration:none;
|
||||||
color:var(--link-color-active);
|
color:var(--link-color-active);
|
||||||
}
|
}
|
||||||
pre {
|
pre {
|
||||||
font-family:var(--code-font-family);
|
font-family:var(--code-font-family);
|
||||||
font-size:1em;
|
font-size:var(--code-font-size);
|
||||||
}
|
}
|
||||||
h1 {
|
h1 {
|
||||||
font-size:1.428em;
|
font-size:1.428em;
|
||||||
@ -130,8 +131,6 @@ code, tt {
|
|||||||
:not(h1, h2, h3, h4, h5, h6) > code,
|
:not(h1, h2, h3, h4, h5, h6) > code,
|
||||||
:not(h1, h2, h3, h4, h5, h6) > tt {
|
:not(h1, h2, h3, h4, h5, h6) > tt {
|
||||||
font-size:var(--code-font-size);
|
font-size:var(--code-font-size);
|
||||||
padding-top:4px;
|
|
||||||
margin-top:8px;
|
|
||||||
line-height:1.4em;
|
line-height:1.4em;
|
||||||
}
|
}
|
||||||
dt code {
|
dt code {
|
||||||
@ -152,6 +151,9 @@ button {
|
|||||||
font-family: var(--body-font-family);
|
font-family: var(--body-font-family);
|
||||||
font-size: 1em;
|
font-size: 1em;
|
||||||
}
|
}
|
||||||
|
hr {
|
||||||
|
border-color: #aaa;
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
* Styles for HTML generated by javadoc.
|
* Styles for HTML generated by javadoc.
|
||||||
*
|
*
|
||||||
@ -162,14 +164,14 @@ button {
|
|||||||
* Styles for document title and copyright.
|
* Styles for document title and copyright.
|
||||||
*/
|
*/
|
||||||
.about-language {
|
.about-language {
|
||||||
float:right;
|
flex: 0 0 auto;
|
||||||
padding:0 21px 8px 8px;
|
padding:0 20px;
|
||||||
|
margin:0;
|
||||||
font-size:0.915em;
|
font-size:0.915em;
|
||||||
margin-top:-9px;
|
max-width: 50%;
|
||||||
height:2.9em;
|
white-space: nowrap;
|
||||||
}
|
}
|
||||||
.legal-copy {
|
.legal-copy {
|
||||||
margin-left:.5em;
|
|
||||||
}
|
}
|
||||||
/*
|
/*
|
||||||
* Styles for navigation bar.
|
* Styles for navigation bar.
|
||||||
@ -178,83 +180,102 @@ button {
|
|||||||
header {
|
header {
|
||||||
position:sticky;
|
position:sticky;
|
||||||
top:0;
|
top:0;
|
||||||
z-index:1;
|
z-index:2;
|
||||||
background: var(--body-background-color);
|
background: var(--body-background-color);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
.nav-content {
|
||||||
|
display:flex;
|
||||||
|
flex-direction: row;
|
||||||
|
align-items: center;
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
.top-nav {
|
.top-nav {
|
||||||
background-color:var(--navbar-background-color);
|
background-color:var(--navbar-background-color);
|
||||||
color:var(--navbar-text-color);
|
color:var(--navbar-text-color);
|
||||||
float:left;
|
|
||||||
width:100%;
|
width:100%;
|
||||||
clear:right;
|
height:var(--top-nav-height);
|
||||||
min-height:2.8em;
|
overflow:visible;
|
||||||
padding:10px 0 0 0;
|
|
||||||
overflow:hidden;
|
|
||||||
font-size:0.857em;
|
font-size:0.857em;
|
||||||
|
position:relative;
|
||||||
|
}
|
||||||
|
.top-nav nav.toc {
|
||||||
|
display: none;
|
||||||
|
flex-direction: column;
|
||||||
|
}
|
||||||
|
.top-nav nav.toc button.show-sidebar,
|
||||||
|
.top-nav nav.toc button.hide-sidebar {
|
||||||
|
display: none;
|
||||||
}
|
}
|
||||||
button#navbar-toggle-button {
|
button#navbar-toggle-button {
|
||||||
display:none;
|
display:none;
|
||||||
}
|
}
|
||||||
ul.sub-nav-list-small {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
.sub-nav {
|
|
||||||
background-color:var(--subnav-background-color);
|
|
||||||
float:left;
|
|
||||||
width:100%;
|
|
||||||
overflow:hidden;
|
|
||||||
font-size:0.857em;
|
|
||||||
}
|
|
||||||
.sub-nav div {
|
|
||||||
clear:left;
|
|
||||||
float:left;
|
|
||||||
padding:6px;
|
|
||||||
text-transform:uppercase;
|
|
||||||
}
|
|
||||||
.sub-nav .sub-nav-list {
|
|
||||||
padding-top:4px;
|
|
||||||
}
|
|
||||||
ul.nav-list {
|
ul.nav-list {
|
||||||
display:block;
|
display:inline-flex;
|
||||||
margin:0 25px 0 0;
|
margin:0;
|
||||||
padding:0;
|
padding-left:4px;
|
||||||
}
|
flex: 1 1 auto;
|
||||||
ul.sub-nav-list {
|
white-space: nowrap;
|
||||||
float:left;
|
|
||||||
margin:0 25px 0 0;
|
|
||||||
padding:0;
|
|
||||||
}
|
}
|
||||||
ul.nav-list li {
|
ul.nav-list li {
|
||||||
list-style:none;
|
list-style:none;
|
||||||
float:left;
|
|
||||||
padding: 5px 6px;
|
padding: 5px 6px;
|
||||||
text-transform:uppercase;
|
text-transform:uppercase;
|
||||||
|
height: 1.2em;
|
||||||
|
}
|
||||||
|
div.sub-nav {
|
||||||
|
background-color:var(--subnav-background-color);
|
||||||
|
width:100%;
|
||||||
|
overflow:hidden;
|
||||||
|
font-size:var(--nav-font-size);
|
||||||
|
height: var(--sub-nav-height);
|
||||||
|
}
|
||||||
|
ol.sub-nav-list {
|
||||||
|
flex: 1 1 90%;
|
||||||
|
line-height: 1.8em;
|
||||||
|
display: inline-flex;
|
||||||
|
overflow: auto;
|
||||||
|
scroll-snap-type: x mandatory;
|
||||||
|
scroll-padding-left: 13px;
|
||||||
|
scrollbar-width: none;
|
||||||
|
padding-left:6px;
|
||||||
|
white-space: nowrap;
|
||||||
|
margin:0;
|
||||||
|
}
|
||||||
|
ol.sub-nav-list::-webkit-scrollbar {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
ol.sub-nav-list li {
|
||||||
|
list-style:none;
|
||||||
|
scroll-snap-align: start;
|
||||||
|
}
|
||||||
|
ol.sub-nav-list a {
|
||||||
|
padding: 3px;
|
||||||
|
}
|
||||||
|
ol.sub-nav-list a.current-selection {
|
||||||
|
background-color: var(--section-background-color);
|
||||||
|
border-radius: 4px;
|
||||||
}
|
}
|
||||||
.sub-nav .nav-list-search {
|
.sub-nav .nav-list-search {
|
||||||
float:right;
|
flex: 1 1 10%;
|
||||||
margin:0;
|
margin:0;
|
||||||
padding:6px;
|
padding:6px;
|
||||||
clear:none;
|
|
||||||
text-align:right;
|
|
||||||
position:relative;
|
position:relative;
|
||||||
|
white-space: nowrap;
|
||||||
}
|
}
|
||||||
ul.sub-nav-list li {
|
.top-nav .nav-list a:link, .top-nav .nav-list a:active, .top-nav .nav-list a:visited {
|
||||||
list-style:none;
|
|
||||||
float:left;
|
|
||||||
}
|
|
||||||
.top-nav a:link, .top-nav a:active, .top-nav a:visited {
|
|
||||||
color:var(--navbar-text-color);
|
color:var(--navbar-text-color);
|
||||||
text-decoration:none;
|
text-decoration:none;
|
||||||
text-transform:uppercase;
|
text-transform:uppercase;
|
||||||
}
|
}
|
||||||
.top-nav a:hover {
|
.top-nav .nav-list a:hover {
|
||||||
color:var(--link-color-active);
|
color:var(--link-color-active);
|
||||||
}
|
}
|
||||||
.nav-bar-cell1-rev {
|
.nav-bar-cell1-rev {
|
||||||
background-color:var(--selected-background-color);
|
background-color:var(--selected-background-color);
|
||||||
color:var(--selected-text-color);
|
color:var(--selected-text-color);
|
||||||
margin: auto 5px;
|
margin: 0 5px;
|
||||||
}
|
}
|
||||||
.skip-nav {
|
.skip-nav {
|
||||||
position:absolute;
|
position:absolute;
|
||||||
@ -298,6 +319,7 @@ body.module-declaration-page .block-list h2 {
|
|||||||
font-style: italic;
|
font-style: italic;
|
||||||
padding:0;
|
padding:0;
|
||||||
margin:15px 0;
|
margin:15px 0;
|
||||||
|
overflow-x:auto;
|
||||||
}
|
}
|
||||||
body.class-declaration-page .summary h3,
|
body.class-declaration-page .summary h3,
|
||||||
body.class-declaration-page .details h3 {
|
body.class-declaration-page .details h3 {
|
||||||
@ -310,6 +332,18 @@ body.class-declaration-page .details h3 {
|
|||||||
/*
|
/*
|
||||||
* Styles for page layout containers.
|
* Styles for page layout containers.
|
||||||
*/
|
*/
|
||||||
|
.main-grid {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: row;
|
||||||
|
}
|
||||||
|
.main-grid main {
|
||||||
|
flex: 2.6 1 0;
|
||||||
|
min-width: 240px
|
||||||
|
}
|
||||||
|
.main-grid nav.toc {
|
||||||
|
flex: 1 1 0;
|
||||||
|
min-width: 240px;
|
||||||
|
}
|
||||||
main {
|
main {
|
||||||
clear:both;
|
clear:both;
|
||||||
padding:10px 20px;
|
padding:10px 20px;
|
||||||
@ -328,7 +362,7 @@ dl.notes > dt {
|
|||||||
}
|
}
|
||||||
dl.notes > dd {
|
dl.notes > dd {
|
||||||
margin:5px 10px 10px 0;
|
margin:5px 10px 10px 0;
|
||||||
font-size:1em;
|
font-size:var(--block-font-size);
|
||||||
font-family:var(--block-font-family)
|
font-family:var(--block-font-family)
|
||||||
}
|
}
|
||||||
dl.name-value > dt {
|
dl.name-value > dt {
|
||||||
@ -342,6 +376,120 @@ dl.name-value > dd {
|
|||||||
font-size:1.1em;
|
font-size:1.1em;
|
||||||
display:inline;
|
display:inline;
|
||||||
}
|
}
|
||||||
|
/*
|
||||||
|
* Styles for table of contents.
|
||||||
|
*/
|
||||||
|
.main-grid nav.toc {
|
||||||
|
background-color: var(--section-background-color);
|
||||||
|
border-right: 1px solid var(--border-color);
|
||||||
|
position: sticky;
|
||||||
|
top: calc(var(--nav-height));
|
||||||
|
max-height: calc(100vh - var(--nav-height));
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
font-family: var(--body-font-family);
|
||||||
|
z-index: 1;
|
||||||
|
}
|
||||||
|
.main-grid nav.toc div.toc-header {
|
||||||
|
background-color: var(--section-background-color);
|
||||||
|
border-right: 1px solid var(--border-color);
|
||||||
|
top: var(--nav-height);
|
||||||
|
z-index: 1;
|
||||||
|
padding: 15px 20px;
|
||||||
|
}
|
||||||
|
.main-grid nav.toc > ol.toc-list {
|
||||||
|
max-height: calc(100vh - var(--nav-height) - 100px);
|
||||||
|
padding-left: 12px;
|
||||||
|
}
|
||||||
|
.main-grid nav.toc button {
|
||||||
|
position: absolute;
|
||||||
|
bottom: 16px;
|
||||||
|
z-index: 3;
|
||||||
|
background-color: var(--section-background-color);
|
||||||
|
color: #666666;
|
||||||
|
font-size: 0.76rem;
|
||||||
|
border: none;
|
||||||
|
cursor: pointer;
|
||||||
|
padding: 6px 10px;
|
||||||
|
white-space: nowrap;
|
||||||
|
}
|
||||||
|
.main-grid nav.toc button.hide-sidebar {
|
||||||
|
right: 0;
|
||||||
|
}
|
||||||
|
.main-grid nav.toc button.show-sidebar {
|
||||||
|
left: 0;
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.main-grid nav.toc button span {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.main-grid nav.toc button:hover {
|
||||||
|
color: var(--body-text-color);
|
||||||
|
border: 1px solid var(--subnav-background-color);
|
||||||
|
}
|
||||||
|
.main-grid nav.toc button:active {
|
||||||
|
background-color: var(--subnav-background-color);
|
||||||
|
color: var(--link-color-active);
|
||||||
|
}
|
||||||
|
.main-grid nav.toc button:hover span,
|
||||||
|
.main-grid nav.toc button:active span {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
.main-grid nav.toc button:hover {
|
||||||
|
box-shadow: 1px 1px 5px rgba(0,0,0,0.2);
|
||||||
|
}
|
||||||
|
.main-grid nav.toc.hide-sidebar {
|
||||||
|
min-width: revert;
|
||||||
|
max-width: 28px;
|
||||||
|
}
|
||||||
|
.main-grid nav.toc.hide-sidebar div.toc-header,
|
||||||
|
.main-grid nav.toc.hide-sidebar ol.toc-list,
|
||||||
|
.main-grid nav.toc.hide-sidebar button.hide-sidebar {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.main-grid nav.toc.hide-sidebar button.show-sidebar {
|
||||||
|
display: inline;
|
||||||
|
}
|
||||||
|
nav.toc div.toc-header {
|
||||||
|
padding: 15px;
|
||||||
|
display: inline-flex;
|
||||||
|
align-items: center;
|
||||||
|
color: var(--body-text-color);
|
||||||
|
background-color: var(--body-background-color);
|
||||||
|
font-size: 0.856em;
|
||||||
|
font-weight: bold;
|
||||||
|
white-space: nowrap;
|
||||||
|
overflow-x: hidden;
|
||||||
|
position: sticky;
|
||||||
|
min-height: 20px;
|
||||||
|
}
|
||||||
|
nav.toc > ol.toc-list {
|
||||||
|
overflow: hidden auto;
|
||||||
|
overscroll-behavior: contain;
|
||||||
|
}
|
||||||
|
nav.toc ol.toc-list {
|
||||||
|
list-style: none;
|
||||||
|
padding-left: 8px;
|
||||||
|
margin: 0;
|
||||||
|
}
|
||||||
|
nav.toc ol.toc-list ol.toc-list {
|
||||||
|
margin-left: 8px;
|
||||||
|
}
|
||||||
|
nav.toc ol.toc-list li {
|
||||||
|
margin: 0;
|
||||||
|
font-size: var(--nav-font-size);
|
||||||
|
overflow-x: hidden;
|
||||||
|
}
|
||||||
|
a.current-selection {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
nav.toc a {
|
||||||
|
display: block;
|
||||||
|
padding: 8px;
|
||||||
|
}
|
||||||
|
nav.toc a.current-selection {
|
||||||
|
background-color: var(--subnav-background-color);
|
||||||
|
}
|
||||||
/*
|
/*
|
||||||
* Styles for lists.
|
* Styles for lists.
|
||||||
*/
|
*/
|
||||||
@ -359,11 +507,14 @@ div.inheritance {
|
|||||||
div.inheritance div.inheritance {
|
div.inheritance div.inheritance {
|
||||||
margin-left:2em;
|
margin-left:2em;
|
||||||
}
|
}
|
||||||
|
main > div.inheritance {
|
||||||
|
overflow-x:auto;
|
||||||
|
}
|
||||||
ul.block-list,
|
ul.block-list,
|
||||||
ul.details-list,
|
ul.details-list,
|
||||||
ul.member-list,
|
ul.member-list,
|
||||||
ul.summary-list {
|
ul.summary-list {
|
||||||
margin:10px 0 10px 0;
|
margin:4px 0 10px 0;
|
||||||
padding:0;
|
padding:0;
|
||||||
}
|
}
|
||||||
ul.block-list > li,
|
ul.block-list > li,
|
||||||
@ -599,8 +750,9 @@ div.checkboxes > label > input {
|
|||||||
* Styles for contents.
|
* Styles for contents.
|
||||||
*/
|
*/
|
||||||
div.block {
|
div.block {
|
||||||
font-size:var(--body-font-size);
|
font-size:var(--block-font-size);
|
||||||
font-family:var(--block-font-family);
|
font-family:var(--block-font-family);
|
||||||
|
line-height:var(--block-line-height);
|
||||||
}
|
}
|
||||||
.col-last div {
|
.col-last div {
|
||||||
padding-top:0;
|
padding-top:0;
|
||||||
@ -646,7 +798,6 @@ div.block {
|
|||||||
color:var(--block-text-color);
|
color:var(--block-text-color);
|
||||||
}
|
}
|
||||||
.deprecated-label, .description-from-type-label, .implementation-label, .member-name-link,
|
.deprecated-label, .description-from-type-label, .implementation-label, .member-name-link,
|
||||||
.module-label-in-package, .module-label-in-type, .package-label-in-type,
|
|
||||||
.package-hierarchy-label, .type-name-label, .type-name-link, .search-tag-link, .preview-label, .restricted-label {
|
.package-hierarchy-label, .type-name-label, .type-name-link, .search-tag-link, .preview-label, .restricted-label {
|
||||||
font-weight:bold;
|
font-weight:bold;
|
||||||
}
|
}
|
||||||
@ -686,9 +837,6 @@ details summary {
|
|||||||
main, nav, header, footer, section {
|
main, nav, header, footer, section {
|
||||||
display:block;
|
display:block;
|
||||||
}
|
}
|
||||||
nav {
|
|
||||||
overflow:hidden;
|
|
||||||
}
|
|
||||||
/*
|
/*
|
||||||
* Styles for javadoc search.
|
* Styles for javadoc search.
|
||||||
*/
|
*/
|
||||||
@ -712,15 +860,14 @@ nav {
|
|||||||
.ui-autocomplete {
|
.ui-autocomplete {
|
||||||
max-height:85%;
|
max-height:85%;
|
||||||
max-width:65%;
|
max-width:65%;
|
||||||
overflow-y:auto;
|
overflow:auto;
|
||||||
overflow-x:auto;
|
|
||||||
white-space:nowrap;
|
white-space:nowrap;
|
||||||
box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
|
box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
|
||||||
overscroll-behavior: contain;
|
overscroll-behavior: contain;
|
||||||
}
|
}
|
||||||
ul.ui-autocomplete {
|
ul.ui-autocomplete {
|
||||||
position:fixed;
|
position:fixed;
|
||||||
z-index:1;
|
z-index:10;
|
||||||
background-color: var(--body-background-color);
|
background-color: var(--body-background-color);
|
||||||
}
|
}
|
||||||
ul.ui-autocomplete li {
|
ul.ui-autocomplete li {
|
||||||
@ -738,7 +885,7 @@ ul.ui-autocomplete li.ui-static-link {
|
|||||||
font-family: var(--body-font-family);
|
font-family: var(--body-font-family);
|
||||||
font-size: 0.93em;
|
font-size: 0.93em;
|
||||||
font-weight: bolder;
|
font-weight: bolder;
|
||||||
z-index: 2;
|
z-index: 10;
|
||||||
}
|
}
|
||||||
li.ui-static-link a, li.ui-static-link a:visited {
|
li.ui-static-link a, li.ui-static-link a:visited {
|
||||||
text-decoration:none;
|
text-decoration:none;
|
||||||
@ -756,7 +903,11 @@ li.ui-static-link a, li.ui-static-link a:visited {
|
|||||||
padding-top: 0.4em;
|
padding-top: 0.4em;
|
||||||
padding-bottom: 0.4em;
|
padding-bottom: 0.4em;
|
||||||
}
|
}
|
||||||
#search-input, #page-search-input {
|
.ui-menu .ui-menu-item-wrapper {
|
||||||
|
padding-top: 5px;
|
||||||
|
padding-bottom: 5px;
|
||||||
|
}
|
||||||
|
input[type="text"] {
|
||||||
background-image:url('glass.png');
|
background-image:url('glass.png');
|
||||||
background-size:13px;
|
background-size:13px;
|
||||||
background-repeat:no-repeat;
|
background-repeat:no-repeat;
|
||||||
@ -764,14 +915,27 @@ li.ui-static-link a, li.ui-static-link a:visited {
|
|||||||
background-color: var(--search-input-background-color);
|
background-color: var(--search-input-background-color);
|
||||||
color: var(--search-input-text-color);
|
color: var(--search-input-text-color);
|
||||||
border-color: var(--border-color);
|
border-color: var(--border-color);
|
||||||
|
border-radius: 4px;
|
||||||
padding-left:20px;
|
padding-left:20px;
|
||||||
width: 250px;
|
font-size: var(--nav-font-size);
|
||||||
|
height: 17px;
|
||||||
|
}
|
||||||
|
input#search-input, input#page-search-input {
|
||||||
|
width: calc(180px + 10vw);
|
||||||
margin: 0;
|
margin: 0;
|
||||||
}
|
}
|
||||||
#search-input {
|
input#search-input {
|
||||||
margin-left: 4px;
|
margin: 0 4px;
|
||||||
|
padding-right: 18px;
|
||||||
|
max-width: 340px;
|
||||||
}
|
}
|
||||||
#reset-button {
|
input.filter-input {
|
||||||
|
width: 40%;
|
||||||
|
max-width: 140px;
|
||||||
|
margin: 0 4px;
|
||||||
|
padding-right: 18px;
|
||||||
|
}
|
||||||
|
input#reset-search, input.reset-filter {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
background-image:url('x.png');
|
background-image:url('x.png');
|
||||||
background-repeat:no-repeat;
|
background-repeat:no-repeat;
|
||||||
@ -780,12 +944,20 @@ li.ui-static-link a, li.ui-static-link a:visited {
|
|||||||
border-radius:0;
|
border-radius:0;
|
||||||
width:12px;
|
width:12px;
|
||||||
height:12px;
|
height:12px;
|
||||||
position:absolute;
|
|
||||||
right:12px;
|
|
||||||
top:10px;
|
|
||||||
font-size:0;
|
font-size:0;
|
||||||
|
display:none;
|
||||||
}
|
}
|
||||||
::placeholder {
|
input#reset-search {
|
||||||
|
position:absolute;
|
||||||
|
right:15px;
|
||||||
|
top:11px;
|
||||||
|
}
|
||||||
|
input.reset-filter {
|
||||||
|
position: relative;
|
||||||
|
right: 20px;
|
||||||
|
top: 0;
|
||||||
|
}
|
||||||
|
input::placeholder {
|
||||||
color:var(--search-input-placeholder-color);
|
color:var(--search-input-placeholder-color);
|
||||||
opacity: 1;
|
opacity: 1;
|
||||||
}
|
}
|
||||||
@ -849,7 +1021,7 @@ span#page-search-link {
|
|||||||
.module-graph:hover span, .sealed-graph:hover span {
|
.module-graph:hover span, .sealed-graph:hover span {
|
||||||
display:block;
|
display:block;
|
||||||
margin: -100px 0 0 100px;
|
margin: -100px 0 0 100px;
|
||||||
z-index: 1;
|
z-index: 5;
|
||||||
}
|
}
|
||||||
.inherited-list {
|
.inherited-list {
|
||||||
margin: 10px 0 10px 0;
|
margin: 10px 0 10px 0;
|
||||||
@ -874,6 +1046,10 @@ section.class-description {
|
|||||||
.vertical-separator {
|
.vertical-separator {
|
||||||
padding: 0 5px;
|
padding: 0 5px;
|
||||||
}
|
}
|
||||||
|
.help-section {
|
||||||
|
font-size: var(--block-font-size);
|
||||||
|
line-height: var(--block-line-height);
|
||||||
|
}
|
||||||
ul.help-section-list {
|
ul.help-section-list {
|
||||||
margin: 0;
|
margin: 0;
|
||||||
}
|
}
|
||||||
@ -1100,22 +1276,67 @@ table.striped > tbody > tr > th {
|
|||||||
/**
|
/**
|
||||||
* Tweak style for small screens.
|
* Tweak style for small screens.
|
||||||
*/
|
*/
|
||||||
|
@media screen and (max-width: 1050px) {
|
||||||
|
.summary section[class$="-summary"], .details section[class$="-details"],
|
||||||
|
.class-uses .detail, .serialized-class-details {
|
||||||
|
padding: 0 10px 5px 8px;
|
||||||
|
}
|
||||||
|
input#search-input {
|
||||||
|
width: 22vw;
|
||||||
|
}
|
||||||
|
}
|
||||||
@media screen and (max-width: 920px) {
|
@media screen and (max-width: 920px) {
|
||||||
|
.main-grid nav.toc {
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.top-nav nav.toc {
|
||||||
|
display: none;
|
||||||
|
position: absolute;
|
||||||
|
top: var(--top-nav-height);
|
||||||
|
left: 40vw;
|
||||||
|
width: 60vw;
|
||||||
|
z-index: 7;
|
||||||
|
background-color: var(--section-background-color);
|
||||||
|
box-sizing: border-box;
|
||||||
|
}
|
||||||
|
.top-nav nav.toc div.toc-header {
|
||||||
|
padding: 6px 15px;
|
||||||
|
font-size: 0.94em;
|
||||||
|
background-color: var(--section-background-color);
|
||||||
|
top: calc(var(--top-nav-height) + 10px);
|
||||||
|
}
|
||||||
|
.top-nav nav.toc ol.toc-list li {
|
||||||
|
font-size: 1.04em;
|
||||||
|
}
|
||||||
|
nav.toc a:link, nav.toc a:visited {
|
||||||
|
text-decoration:none;
|
||||||
|
color:var(--link-color);
|
||||||
|
}
|
||||||
|
nav.toc a[href]:hover, nav.toc a[href]:focus {
|
||||||
|
text-decoration:none;
|
||||||
|
color:var(--link-color-active);
|
||||||
|
}
|
||||||
|
:root {
|
||||||
|
scroll-behavior: auto;
|
||||||
|
}
|
||||||
header {
|
header {
|
||||||
max-height: 100vh;
|
max-height: 100vh;
|
||||||
overflow-y: auto;
|
overflow-y: visible;
|
||||||
|
overscroll-behavior: contain;
|
||||||
}
|
}
|
||||||
div#navbar-top {
|
nav {
|
||||||
height: 2.8em;
|
overflow: visible;
|
||||||
transition: height 0.35s ease;
|
|
||||||
}
|
}
|
||||||
ul.nav-list {
|
ul.nav-list {
|
||||||
display: block;
|
display: none;
|
||||||
|
position: absolute;
|
||||||
|
top: var(--top-nav-height);
|
||||||
|
overflow: auto;
|
||||||
|
z-index: 7;
|
||||||
|
background-color: var(--navbar-background-color);
|
||||||
width: 40%;
|
width: 40%;
|
||||||
float:left;
|
|
||||||
clear: left;
|
|
||||||
margin: 10px 0 0 0;
|
|
||||||
padding: 0;
|
padding: 0;
|
||||||
|
box-sizing: border-box;
|
||||||
}
|
}
|
||||||
ul.nav-list li {
|
ul.nav-list li {
|
||||||
float: none;
|
float: none;
|
||||||
@ -1123,51 +1344,21 @@ table.striped > tbody > tr > th {
|
|||||||
margin-left: 10px;
|
margin-left: 10px;
|
||||||
margin-top: 2px;
|
margin-top: 2px;
|
||||||
}
|
}
|
||||||
ul.sub-nav-list-small {
|
|
||||||
display:block;
|
|
||||||
height: 100%;
|
|
||||||
width: 50%;
|
|
||||||
float: right;
|
|
||||||
clear: right;
|
|
||||||
background-color: var(--subnav-background-color);
|
|
||||||
color: var(--body-text-color);
|
|
||||||
margin: 6px 0 0 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
ul.sub-nav-list-small ul {
|
|
||||||
padding-left: 20px;
|
|
||||||
}
|
|
||||||
ul.sub-nav-list-small a:link, ul.sub-nav-list-small a:visited {
|
|
||||||
color:var(--link-color);
|
|
||||||
}
|
|
||||||
ul.sub-nav-list-small a:hover {
|
|
||||||
color:var(--link-color-active);
|
|
||||||
}
|
|
||||||
ul.sub-nav-list-small li {
|
|
||||||
list-style:none;
|
|
||||||
float:none;
|
|
||||||
padding: 6px;
|
|
||||||
margin-top: 1px;
|
|
||||||
text-transform:uppercase;
|
|
||||||
}
|
|
||||||
ul.sub-nav-list-small > li {
|
|
||||||
margin-left: 10px;
|
|
||||||
}
|
|
||||||
ul.sub-nav-list-small li p {
|
|
||||||
margin: 5px 0;
|
|
||||||
}
|
|
||||||
div#navbar-sub-list {
|
|
||||||
display: none;
|
|
||||||
}
|
|
||||||
.top-nav a:link, .top-nav a:active, .top-nav a:visited {
|
.top-nav a:link, .top-nav a:active, .top-nav a:visited {
|
||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
|
.top-nav div.nav-menu-button {
|
||||||
|
flex: 1 1 auto;
|
||||||
|
}
|
||||||
|
.sub-nav ol.sub-nav-list {
|
||||||
|
margin-left: 4px;
|
||||||
|
padding-left: 4px;
|
||||||
|
}
|
||||||
button#navbar-toggle-button {
|
button#navbar-toggle-button {
|
||||||
width: 3.4em;
|
width: 3.4em;
|
||||||
height: 2.8em;
|
height: 2.8em;
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
display: block;
|
display: block;
|
||||||
float: left;
|
|
||||||
border: 0;
|
border: 0;
|
||||||
margin: 0 10px;
|
margin: 0 10px;
|
||||||
cursor: pointer;
|
cursor: pointer;
|
||||||
@ -1177,9 +1368,8 @@ table.striped > tbody > tr > th {
|
|||||||
display: block;
|
display: block;
|
||||||
width: 24px;
|
width: 24px;
|
||||||
height: 3px;
|
height: 3px;
|
||||||
margin: 1px 0 4px 0;
|
margin: 4px 0;
|
||||||
border-radius: 2px;
|
border-radius: 2px;
|
||||||
transition: all 0.1s;
|
|
||||||
background-color: var(--navbar-text-color);
|
background-color: var(--navbar-text-color);
|
||||||
}
|
}
|
||||||
button#navbar-toggle-button.expanded span.nav-bar-toggle-icon:nth-child(1) {
|
button#navbar-toggle-button.expanded span.nav-bar-toggle-icon:nth-child(1) {
|
||||||
@ -1199,50 +1389,30 @@ table.striped > tbody > tr > th {
|
|||||||
@media screen and (max-width: 800px) {
|
@media screen and (max-width: 800px) {
|
||||||
.about-language {
|
.about-language {
|
||||||
padding-right: 16px;
|
padding-right: 16px;
|
||||||
|
max-width: 90%;
|
||||||
}
|
}
|
||||||
ul.nav-list li {
|
ul.nav-list li {
|
||||||
margin-left: 5px;
|
margin-left: 5px;
|
||||||
}
|
}
|
||||||
ul.sub-nav-list-small > li {
|
|
||||||
margin-left: 5px;
|
|
||||||
}
|
|
||||||
main {
|
main {
|
||||||
padding: 10px;
|
padding: 10px 12px;
|
||||||
}
|
|
||||||
.summary section[class$="-summary"], .details section[class$="-details"],
|
|
||||||
.class-uses .detail, .serialized-class-details {
|
|
||||||
padding: 0 8px 5px 8px;
|
|
||||||
}
|
}
|
||||||
body {
|
body {
|
||||||
-webkit-text-size-adjust: none;
|
-webkit-text-size-adjust: none;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@media screen and (max-width: 400px) {
|
@media screen and (max-width: 600px) {
|
||||||
.about-language {
|
.nav-list-search > a {
|
||||||
font-size: 10px;
|
|
||||||
padding-right: 12px;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@media screen and (max-width: 400px) {
|
|
||||||
.nav-list-search {
|
|
||||||
width: 94%;
|
|
||||||
}
|
|
||||||
#search-input, #page-search-input {
|
|
||||||
width: 70%;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@media screen and (max-width: 320px) {
|
|
||||||
.nav-list-search > label {
|
|
||||||
display: none;
|
display: none;
|
||||||
}
|
}
|
||||||
.nav-list-search {
|
input#search-input {
|
||||||
width: 90%;
|
width: 18vw;
|
||||||
}
|
}
|
||||||
#search-input, #page-search-input {
|
.summary section[class$="-summary"], .details section[class$="-details"],
|
||||||
width: 80%;
|
.class-uses .detail, .serialized-class-details {
|
||||||
|
padding: 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pre.snippet {
|
pre.snippet {
|
||||||
background-color: var(--snippet-background-color);
|
background-color: var(--snippet-background-color);
|
||||||
color: var(--snippet-text-color);
|
color: var(--snippet-text-color);
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
#
|
#
|
||||||
# Copyright (c) 2010, 2023, Oracle and/or its affiliates. All rights reserved.
|
# Copyright (c) 2010, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
# DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
#
|
#
|
||||||
# This code is free software; you can redistribute it and/or modify it
|
# This code is free software; you can redistribute it and/or modify it
|
||||||
@ -232,8 +232,9 @@ doclet.Modifier=Modifier
|
|||||||
doclet.Type=Type
|
doclet.Type=Type
|
||||||
doclet.Modifier_and_Type=Modifier and Type
|
doclet.Modifier_and_Type=Modifier and Type
|
||||||
doclet.Implementation=Implementation(s):
|
doclet.Implementation=Implementation(s):
|
||||||
doclet.search=SEARCH
|
doclet.search=Search
|
||||||
doclet.search_placeholder=Search
|
doclet.search_placeholder=Search
|
||||||
|
doclet.search_in_documentation=Search in documentation
|
||||||
doclet.search_reset=Reset
|
doclet.search_reset=Reset
|
||||||
doclet.Field=Field
|
doclet.Field=Field
|
||||||
doclet.Property=Property
|
doclet.Property=Property
|
||||||
@ -247,6 +248,12 @@ doclet.Enum_Constant=Enum Constant
|
|||||||
doclet.Description=Description
|
doclet.Description=Description
|
||||||
doclet.ConstantField=Constant Field
|
doclet.ConstantField=Constant Field
|
||||||
doclet.Value=Value
|
doclet.Value=Value
|
||||||
|
doclet.table_of_contents=Table of contents
|
||||||
|
doclet.hide_sidebar=Hide sidebar
|
||||||
|
doclet.show_sidebar=Show sidebar
|
||||||
|
doclet.filter_label=Filter
|
||||||
|
doclet.filter_table_of_contents=Filter table of contents
|
||||||
|
doclet.filter_reset=Reset
|
||||||
doclet.linkMismatch_PackagedLinkedtoModule=The code being documented uses packages in the unnamed module, \
|
doclet.linkMismatch_PackagedLinkedtoModule=The code being documented uses packages in the unnamed module, \
|
||||||
but the packages defined in {0} are in named modules.
|
but the packages defined in {0} are in named modules.
|
||||||
doclet.linkMismatch_ModuleLinkedtoPackage=The code being documented uses modules but the packages defined \
|
doclet.linkMismatch_ModuleLinkedtoPackage=The code being documented uses modules but the packages defined \
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2012, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2012, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -90,7 +90,7 @@ public class DocLink {
|
|||||||
|
|
||||||
DocPath newPath = base.relativize(path);
|
DocPath newPath = base.relativize(path);
|
||||||
// avoid generating an empty link by using the basename of the path if necessary
|
// avoid generating an empty link by using the basename of the path if necessary
|
||||||
if (newPath.isEmpty() && isEmpty(fragment)) {
|
if (newPath.isEmpty() && fragment == null) {
|
||||||
newPath = path.basename();
|
newPath = path.basename();
|
||||||
}
|
}
|
||||||
return new DocLink(newPath, fragment);
|
return new DocLink(newPath, fragment);
|
||||||
@ -121,18 +121,14 @@ public class DocLink {
|
|||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
// common fast path
|
// common fast path
|
||||||
if (path != null && isEmpty(fragment))
|
if (path != null && fragment == null)
|
||||||
return path.getPath();
|
return path.getPath();
|
||||||
|
|
||||||
StringBuilder sb = new StringBuilder();
|
StringBuilder sb = new StringBuilder();
|
||||||
if (path != null)
|
if (path != null)
|
||||||
sb.append(path.getPath());
|
sb.append(path.getPath());
|
||||||
if (!isEmpty(fragment))
|
if (fragment != null)
|
||||||
sb.append("#").append(fragment);
|
sb.append("#").append(fragment);
|
||||||
return sb.toString();
|
return sb.toString();
|
||||||
}
|
}
|
||||||
|
|
||||||
private static boolean isEmpty(String s) {
|
|
||||||
return (s == null) || s.isEmpty();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 1998, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 1998, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -94,6 +94,9 @@ public class DocPaths {
|
|||||||
/** The name of the default javascript file. */
|
/** The name of the default javascript file. */
|
||||||
public static final DocPath SCRIPT_JS = DocPath.create("script.js");
|
public static final DocPath SCRIPT_JS = DocPath.create("script.js");
|
||||||
|
|
||||||
|
/** The name of the template of the default javascript file. */
|
||||||
|
public static final DocPath SCRIPT_JS_TEMPLATE = DocPath.create("script.js.template");
|
||||||
|
|
||||||
/** The name of the copy-to-clipboard icon file. */
|
/** The name of the copy-to-clipboard icon file. */
|
||||||
public static final DocPath CLIPBOARD_SVG = DocPath.create("copy.svg");
|
public static final DocPath CLIPBOARD_SVG = DocPath.create("copy.svg");
|
||||||
|
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2013, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2013, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -68,19 +68,19 @@ public class TestAnchorNames extends JavadocTester {
|
|||||||
"""
|
"""
|
||||||
<section class="nested-class-summary" id="nested-class-summary">
|
<section class="nested-class-summary" id="nested-class-summary">
|
||||||
<h2>Nested Class Summary</h2>""",
|
<h2>Nested Class Summary</h2>""",
|
||||||
"<a href=\"#nested-class-summary\">",
|
"<a href=\"#nested-class-summary\" tabindex=\"0\">",
|
||||||
"""
|
"""
|
||||||
<section class="method-summary" id="method-summary">
|
<section class="method-summary" id="method-summary">
|
||||||
<h2>Method Summary</h2>""",
|
<h2>Method Summary</h2>""",
|
||||||
"<a href=\"#method-summary\">",
|
"<a href=\"#method-summary\" tabindex=\"0\">",
|
||||||
"""
|
"""
|
||||||
<section class="field-details" id="field-detail">
|
<section class="field-details" id="field-detail">
|
||||||
<h2>Field Details</h2>""",
|
<h2>Field Details</h2>""",
|
||||||
"<a href=\"#field-detail\">",
|
"<a href=\"#field-detail\" tabindex=\"0\">",
|
||||||
"""
|
"""
|
||||||
<section class="constructor-details" id="constructor-detail">
|
<section class="constructor-details" id="constructor-detail">
|
||||||
<h2>Constructor Details</h2>""",
|
<h2>Constructor Details</h2>""",
|
||||||
"<a href=\"#constructor-detail\">");
|
"<a href=\"#constructor-detail\" tabindex=\"0\">");
|
||||||
|
|
||||||
// Test some members and link to these members
|
// Test some members and link to these members
|
||||||
checkOutput("pkg1/RegClass.html", true,
|
checkOutput("pkg1/RegClass.html", true,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2004, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2004, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -52,11 +52,11 @@ public class TestAnnotationTypes extends JavadocTester {
|
|||||||
|
|
||||||
checkOutput("pkg/AnnotationTypeField.html", true,
|
checkOutput("pkg/AnnotationTypeField.html", true,
|
||||||
"""
|
"""
|
||||||
<li>Summary: </li>
|
<li><a href="#field-summary" tabindex="0">Field Summary</a></li>""",
|
||||||
<li><a href="#field-summary">Field</a> | </li>""",
|
|
||||||
"""
|
"""
|
||||||
<li>Detail: </li>
|
<li><a href="#field-detail" tabindex="0">Field Details</a>
|
||||||
<li><a href="#field-detail">Field</a> | </li>""",
|
<ol class="toc-list">
|
||||||
|
<li><a href="#DEFAULT_NAME" tabindex="0">DEFAULT_NAME</a></li>""",
|
||||||
"<!-- =========== FIELD SUMMARY =========== -->",
|
"<!-- =========== FIELD SUMMARY =========== -->",
|
||||||
"<h2>Field Summary</h2>",
|
"<h2>Field Summary</h2>",
|
||||||
"""
|
"""
|
||||||
@ -73,18 +73,17 @@ public class TestAnnotationTypes extends JavadocTester {
|
|||||||
|
|
||||||
checkOutput("pkg/AnnotationType.html", true,
|
checkOutput("pkg/AnnotationType.html", true,
|
||||||
"""
|
"""
|
||||||
<ul class="sub-nav-list">
|
<ol class="toc-list">
|
||||||
<li>Summary: </li>
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li>Field | </li>
|
<li><a href="#annotation-interface-required-element-summary" tabindex="0">Required Element Summary</a></li>
|
||||||
<li><a href="#annotation-interface-required-element-summary">Required</a> | </li>
|
<li><a href="#annotation-interface-optional-element-summary" tabindex="0">Optional Element Summary</a></li>
|
||||||
<li><a href="#annotation-interface-optional-element-summary">Optional</a></li>
|
<li><a href="#annotation-interface-element-detail" tabindex="0">Element Details</a>
|
||||||
</ul>""",
|
<ol class="toc-list">
|
||||||
"""
|
<li><a href="#value()" tabindex="0">value</a></li>
|
||||||
<ul class="sub-nav-list">
|
<li><a href="#optional()" tabindex="0">optional</a></li>
|
||||||
<li>Detail: </li>
|
</ol>
|
||||||
<li>Field | </li>
|
</li>
|
||||||
<li><a href="#annotation-interface-element-detail">Element</a></li>
|
</ol>""");
|
||||||
</ul>""");
|
|
||||||
|
|
||||||
checkOutput("pkg/AnnotationType.html", true,
|
checkOutput("pkg/AnnotationType.html", true,
|
||||||
"""
|
"""
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2002, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2002, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -107,13 +107,17 @@ public class TestConstantValuesPage extends JavadocTester {
|
|||||||
|
|
||||||
checkOutput("constant-values.html", true,
|
checkOutput("constant-values.html", true,
|
||||||
"""
|
"""
|
||||||
<section class="packages">
|
<nav role="navigation" class="toc" aria-label="Table of contents">
|
||||||
<h2 title="Contents">Contents</h2>
|
<div class="toc-header">Contents """,
|
||||||
<ul class="contents-list">
|
"""
|
||||||
<li><a href="#p1.p2a">p1.p2a.*</a></li>
|
<li><a href="#" tabindex="0">Constant Field Values</a>
|
||||||
<li><a href="#p1.p2b">p1.p2b.*</a></li>
|
<ol class="toc-list">
|
||||||
</ul>
|
<li><a href="#p1.p2a" tabindex="0">p1.p2a.*</a></li>
|
||||||
</section>""");
|
<li><a href="#p1.p2b" tabindex="0">p1.p2b.*</a></li>
|
||||||
|
</ol>
|
||||||
|
</li>
|
||||||
|
</ol>
|
||||||
|
</nav>""");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -140,12 +144,16 @@ public class TestConstantValuesPage extends JavadocTester {
|
|||||||
|
|
||||||
checkOutput("constant-values.html", true,
|
checkOutput("constant-values.html", true,
|
||||||
"""
|
"""
|
||||||
<section class="packages">
|
<nav role="navigation" class="toc" aria-label="Table of contents">
|
||||||
<h2 title="Contents">Contents</h2>
|
<div class="toc-header">Contents """,
|
||||||
<ul class="contents-list">
|
"""
|
||||||
<li><a href="#unnamed-package">Unnamed Package</a></li>
|
<li><a href="#" tabindex="0">Constant Field Values</a>
|
||||||
</ul>
|
<ol class="toc-list">
|
||||||
</section>""");
|
<li><a href="#unnamed-package" tabindex="0">Unnamed Package</a></li>
|
||||||
|
</ol>
|
||||||
|
</li>
|
||||||
|
</ol>
|
||||||
|
</nav>""");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -179,13 +187,17 @@ public class TestConstantValuesPage extends JavadocTester {
|
|||||||
|
|
||||||
checkOutput("constant-values.html", true,
|
checkOutput("constant-values.html", true,
|
||||||
"""
|
"""
|
||||||
<section class="packages">
|
<nav role="navigation" class="toc" aria-label="Table of contents">
|
||||||
<h2 title="Contents">Contents</h2>
|
<div class="toc-header">Contents """,
|
||||||
<ul class="contents-list">
|
"""
|
||||||
<li><a href="#unnamed-package">Unnamed Package</a></li>
|
<li><a href="#" tabindex="0">Constant Field Values</a>
|
||||||
<li><a href="#p1.p2a">p1.p2a.*</a></li>
|
<ol class="toc-list">
|
||||||
</ul>
|
<li><a href="#unnamed-package" tabindex="0">Unnamed Package</a></li>
|
||||||
</section>""");
|
<li><a href="#p1.p2a" tabindex="0">p1.p2a.*</a></li>
|
||||||
|
</ol>
|
||||||
|
</li>
|
||||||
|
</ol>
|
||||||
|
</nav>""");
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -245,13 +257,17 @@ public class TestConstantValuesPage extends JavadocTester {
|
|||||||
|
|
||||||
checkOutput("constant-values.html", true,
|
checkOutput("constant-values.html", true,
|
||||||
"""
|
"""
|
||||||
<section class="packages">
|
<nav role="navigation" class="toc" aria-label="Table of contents">
|
||||||
<h2 title="Contents">Contents</h2>
|
<div class="toc-header">Contents """,
|
||||||
<ul class="contents-list">
|
"""
|
||||||
<li><a href="#p.a">p.a.*</a></li>
|
<li><a href="#" tabindex="0">Constant Field Values</a>
|
||||||
<li><a href="#p.b">p.b.*</a></li>
|
<ol class="toc-list">
|
||||||
<li><a href="#p.q">p.q.*</a></li>
|
<li><a href="#p.a" tabindex="0">p.a.*</a></li>
|
||||||
</ul>
|
<li><a href="#p.b" tabindex="0">p.b.*</a></li>
|
||||||
</section>""");
|
<li><a href="#p.q" tabindex="0">p.q.*</a></li>
|
||||||
|
</ol>
|
||||||
|
</li>
|
||||||
|
</ol>
|
||||||
|
</nav>""");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2016, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -56,17 +56,17 @@ public class TestCopyFiles extends JavadocTester {
|
|||||||
"Hello World" (phi-WINDOW-TITLE-phi)""",
|
"Hello World" (phi-WINDOW-TITLE-phi)""",
|
||||||
"phi-TOP-phi",
|
"phi-TOP-phi",
|
||||||
// check top navbar
|
// check top navbar
|
||||||
"phi-HEADER-phi",
|
|
||||||
"""
|
"""
|
||||||
<a href="../../module-summary.html">Module</a>""",
|
<a href="../package-tree.html">Tree</a>""",
|
||||||
"""
|
|
||||||
<a href="../package-summary.html">Package</a>""",
|
|
||||||
"""
|
|
||||||
<a href="../../../overview-tree.html">Tree</a>""",
|
|
||||||
"""
|
"""
|
||||||
<a href="../../../deprecated-list.html">Deprecated</a>""",
|
<a href="../../../deprecated-list.html">Deprecated</a>""",
|
||||||
"""
|
"""
|
||||||
<a href="../../../index-all.html">Index</a>""",
|
<a href="../../../index-all.html">Index</a>""",
|
||||||
|
"phi-HEADER-phi",
|
||||||
|
"""
|
||||||
|
<a href="../../module-summary.html">acme.mdle</a>""",
|
||||||
|
"""
|
||||||
|
<a href="../package-summary.html" class="current-selection">p</a>""",
|
||||||
"""
|
"""
|
||||||
In a named module acme.module and named package <a href="../package-summary.html"><code>p</code></a>.""",
|
In a named module acme.module and named package <a href="../package-summary.html"><code>p</code></a>.""",
|
||||||
"<dt>Since:</",
|
"<dt>Since:</",
|
||||||
@ -93,17 +93,17 @@ public class TestCopyFiles extends JavadocTester {
|
|||||||
"Hello World" (phi-WINDOW-TITLE-phi)""",
|
"Hello World" (phi-WINDOW-TITLE-phi)""",
|
||||||
"phi-TOP-phi",
|
"phi-TOP-phi",
|
||||||
// check top navbar
|
// check top navbar
|
||||||
"phi-HEADER-phi",
|
|
||||||
"""
|
"""
|
||||||
<a href="../../module-summary.html">Module</a>""",
|
<a href="../package-tree.html">Tree</a>""",
|
||||||
"""
|
|
||||||
<a href="../package-summary.html">Package</a>""",
|
|
||||||
"""
|
|
||||||
<a href="../../../overview-tree.html">Tree</a>""",
|
|
||||||
"""
|
"""
|
||||||
<a href="../../../deprecated-list.html">Deprecated</a>""",
|
<a href="../../../deprecated-list.html">Deprecated</a>""",
|
||||||
"""
|
"""
|
||||||
<a href="../../../index-all.html">Index</a>""",
|
<a href="../../../index-all.html">Index</a>""",
|
||||||
|
"phi-HEADER-phi",
|
||||||
|
"""
|
||||||
|
<a href="../../module-summary.html">acme.mdle</a>""",
|
||||||
|
"""
|
||||||
|
<a href="../package-summary.html" class="current-selection">p</a>""",
|
||||||
"""
|
"""
|
||||||
In a named module acme.module and named package <a href="../package-summary.html"><code>p</code></a>.""",
|
In a named module acme.module and named package <a href="../package-summary.html"><code>p</code></a>.""",
|
||||||
"<dt>Since:</",
|
"<dt>Since:</",
|
||||||
@ -117,17 +117,17 @@ public class TestCopyFiles extends JavadocTester {
|
|||||||
"SubSubReadme (phi-WINDOW-TITLE-phi)",
|
"SubSubReadme (phi-WINDOW-TITLE-phi)",
|
||||||
"phi-TOP-phi",
|
"phi-TOP-phi",
|
||||||
// check top navbar
|
// check top navbar
|
||||||
"phi-HEADER-phi",
|
|
||||||
"""
|
"""
|
||||||
<a href="../../../../module-summary.html">Module</a>""",
|
<a href="../../../package-tree.html">Tree</a>""",
|
||||||
"""
|
|
||||||
<a href="../../../package-summary.html">Package</a>""",
|
|
||||||
"""
|
|
||||||
<a href="../../../../../overview-tree.html">Tree</a>""",
|
|
||||||
"""
|
"""
|
||||||
<a href="../../../../../deprecated-list.html">Deprecated</a>""",
|
<a href="../../../../../deprecated-list.html">Deprecated</a>""",
|
||||||
"""
|
"""
|
||||||
<a href="../../../../../index-all.html">Index</a>""",
|
<a href="../../../../../index-all.html">Index</a>""",
|
||||||
|
"phi-HEADER-phi",
|
||||||
|
"""
|
||||||
|
<a href="../../../../module-summary.html">acme2.mdle</a>""",
|
||||||
|
"""
|
||||||
|
<a href="../../../package-summary.html" class="current-selection">p2</a>""",
|
||||||
"SubSubReadme.html at third level of doc-file directory.",
|
"SubSubReadme.html at third level of doc-file directory.",
|
||||||
// check footer
|
// check footer
|
||||||
"phi-BOTTOM-phi"
|
"phi-BOTTOM-phi"
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -188,13 +188,12 @@ public class TestHtmlVersion extends JavadocTester {
|
|||||||
<header role="banner">
|
<header role="banner">
|
||||||
<nav role="navigation">
|
<nav role="navigation">
|
||||||
<!-- ========= START OF TOP NAVBAR ======= -->""",
|
<!-- ========= START OF TOP NAVBAR ======= -->""",
|
||||||
|
"""
|
||||||
|
<nav role="navigation" class="toc" aria-label="Table of contents">
|
||||||
|
<div class="toc-header">Contents """,
|
||||||
"""
|
"""
|
||||||
<main role="main">
|
<main role="main">
|
||||||
<div class="header">""",
|
<div class="header">""",
|
||||||
"""
|
|
||||||
<section class="packages">
|
|
||||||
<h2 title="Contents">Contents</h2>
|
|
||||||
""",
|
|
||||||
"""
|
"""
|
||||||
<section class="constants-summary" id="pkg">
|
<section class="constants-summary" id="pkg">
|
||||||
<h2 title="pkg.*">pkg.*</h2>
|
<h2 title="pkg.*">pkg.*</h2>
|
||||||
@ -297,6 +296,7 @@ public class TestHtmlVersion extends JavadocTester {
|
|||||||
<!-- ========= START OF TOP NAVBAR ======= -->""",
|
<!-- ========= START OF TOP NAVBAR ======= -->""",
|
||||||
"""
|
"""
|
||||||
</header>
|
</header>
|
||||||
|
<div class="main-grid">
|
||||||
<main role="main">""",
|
<main role="main">""",
|
||||||
"""
|
"""
|
||||||
<footer role="contentinfo">""",
|
<footer role="contentinfo">""",
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2016, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -151,21 +151,39 @@ public class TestModulePackages extends JavadocTester {
|
|||||||
checkPackageRow("o", "p", 0, "package-summary-table package-summary-table-tab1", null, null, " ");
|
checkPackageRow("o", "p", 0, "package-summary-table package-summary-table-tab1", null, null, " ");
|
||||||
checkOutput("m/p/package-summary.html", true,
|
checkOutput("m/p/package-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<div class="sub-title"><span class="module-label-in-package">Module</span> <a href="../module-summary.html">m</a></div>
|
<ol class="sub-nav-list">
|
||||||
|
<li><a href="../module-summary.html">m</a></li>
|
||||||
|
>
|
||||||
|
<li><a href="package-summary.html" class="current-selection">p</a></li>
|
||||||
|
</ol>
|
||||||
""");
|
""");
|
||||||
checkOutput("o/p/package-summary.html", true,
|
checkOutput("o/p/package-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<div class="sub-title"><span class="module-label-in-package">Module</span> <a href="../module-summary.html">o</a></div>
|
<ol class="sub-nav-list">
|
||||||
|
<li><a href="../module-summary.html">o</a></li>
|
||||||
|
>
|
||||||
|
<li><a href="package-summary.html" class="current-selection">p</a></li>
|
||||||
|
</ol>
|
||||||
""");
|
""");
|
||||||
checkOutput("m/p/C.html", true,
|
checkOutput("m/p/C.html", true,
|
||||||
"""
|
"""
|
||||||
<div class="sub-title"><span class="module-label-in-type">Module</span> <a href="../module-summary.html">m</a></div>
|
<ol class="sub-nav-list">
|
||||||
<div class="sub-title"><span class="package-label-in-type">Package</span> <a href="package-summary.html">p</a></div>
|
<li><a href="../module-summary.html">m</a></li>
|
||||||
|
>
|
||||||
|
<li><a href="package-summary.html">p</a></li>
|
||||||
|
>
|
||||||
|
<li><a href="C.html" class="current-selection" title="class in p">C</a></li>
|
||||||
|
</ol>
|
||||||
""");
|
""");
|
||||||
checkOutput("o/p/C.html", true,
|
checkOutput("o/p/C.html", true,
|
||||||
"""
|
"""
|
||||||
<div class="sub-title"><span class="module-label-in-type">Module</span> <a href="../module-summary.html">o</a></div>
|
<ol class="sub-nav-list">
|
||||||
<div class="sub-title"><span class="package-label-in-type">Package</span> <a href="package-summary.html">p</a></div>
|
<li><a href="../module-summary.html">o</a></li>
|
||||||
|
>
|
||||||
|
<li><a href="package-summary.html">p</a></li>
|
||||||
|
>
|
||||||
|
<li><a href="C.html" class="current-selection" title="class in p">C</a></li>
|
||||||
|
</ol>
|
||||||
""");
|
""");
|
||||||
checkOutput("type-search-index.js", true,
|
checkOutput("type-search-index.js", true,
|
||||||
"""
|
"""
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2017, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -72,10 +72,11 @@ public class TestModuleServicesLink extends JavadocTester {
|
|||||||
|
|
||||||
checkOutput("m/module-summary.html", true,
|
checkOutput("m/module-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<li><a href="#module-description">Description</a> | </li>
|
<ol class="toc-list">
|
||||||
<li>Modules | </li>
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#packages-summary">Packages</a> | </li>
|
<li><a href="#packages-summary" tabindex="0">Packages</a></li>
|
||||||
<li><a href="#services-summary">Services</a></li>""");
|
<li><a href="#services-summary" tabindex="0">Services</a></li>
|
||||||
|
</ol>""");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -97,10 +98,11 @@ public class TestModuleServicesLink extends JavadocTester {
|
|||||||
|
|
||||||
checkOutput("m/module-summary.html", true,
|
checkOutput("m/module-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<li><a href="#module-description">Description</a> | </li>
|
<ol class="toc-list">
|
||||||
<li>Modules | </li>
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#packages-summary">Packages</a> | </li>
|
<li><a href="#packages-summary" tabindex="0">Packages</a></li>
|
||||||
<li><a href="#services-summary">Services</a></li>""");
|
<li><a href="#services-summary" tabindex="0">Services</a></li>
|
||||||
|
</ol>""");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -120,10 +122,10 @@ public class TestModuleServicesLink extends JavadocTester {
|
|||||||
|
|
||||||
checkOutput("m/module-summary.html", true,
|
checkOutput("m/module-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<li>Description | </li>
|
<ol class="toc-list">
|
||||||
<li>Modules | </li>
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#packages-summary">Packages</a> | </li>
|
<li><a href="#packages-summary" tabindex="0">Packages</a></li>
|
||||||
<li>Services</li>""");
|
</ol>""");
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2016, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2016, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -521,6 +521,7 @@ public class TestModules extends JavadocTester {
|
|||||||
"""
|
"""
|
||||||
</nav>
|
</nav>
|
||||||
</header>
|
</header>
|
||||||
|
<div class="main-grid">
|
||||||
<main role="main">
|
<main role="main">
|
||||||
<div class="block">The overview summary page header.</div>
|
<div class="block">The overview summary page header.</div>
|
||||||
<div id="all-modules-table">
|
<div id="all-modules-table">
|
||||||
@ -576,7 +577,7 @@ public class TestModules extends JavadocTester {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void checkModuleLink() {
|
void checkModuleLink() {
|
||||||
checkOutput("index.html", true,
|
checkOutput("index.html", false,
|
||||||
"<li>Module</li>");
|
"<li>Module</li>");
|
||||||
checkOutput("moduleA/module-summary.html", true,
|
checkOutput("moduleA/module-summary.html", true,
|
||||||
"""
|
"""
|
||||||
@ -586,16 +587,16 @@ public class TestModules extends JavadocTester {
|
|||||||
<li class="nav-bar-cell1-rev">Module</li>""");
|
<li class="nav-bar-cell1-rev">Module</li>""");
|
||||||
checkOutput("moduleA/testpkgmdlA/class-use/TestClassInModuleA.html", true,
|
checkOutput("moduleA/testpkgmdlA/class-use/TestClassInModuleA.html", true,
|
||||||
"""
|
"""
|
||||||
<li><a href="../../module-summary.html">Module</a></li>""");
|
<li><a href="../../module-summary.html">moduleA</a></li>""");
|
||||||
checkOutput("moduleB/testpkgmdlB/package-summary.html", true,
|
checkOutput("moduleB/testpkgmdlB/package-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<li><a href="../module-summary.html">Module</a></li>""");
|
<li><a href="../module-summary.html">moduleB</a></li>""");
|
||||||
checkOutput("moduleB/testpkgmdlB/TestClassInModuleB.html", true,
|
checkOutput("moduleB/testpkgmdlB/TestClassInModuleB.html", false,
|
||||||
"""
|
"""
|
||||||
<li><a href="../module-summary.html">Module</a></li>""");
|
<li><a href="../module-summary.html">Module</a></li>""");
|
||||||
checkOutput("moduleB/testpkgmdlB/class-use/TestClassInModuleB.html", true,
|
checkOutput("moduleB/testpkgmdlB/class-use/TestClassInModuleB.html", true,
|
||||||
"""
|
"""
|
||||||
<li><a href="../../module-summary.html">Module</a></li>""");
|
<li><a href="../../module-summary.html">moduleB</a></li>""");
|
||||||
}
|
}
|
||||||
|
|
||||||
void checkNoModuleLink() {
|
void checkNoModuleLink() {
|
||||||
@ -710,6 +711,7 @@ public class TestModules extends JavadocTester {
|
|||||||
"""
|
"""
|
||||||
</nav>
|
</nav>
|
||||||
</header>
|
</header>
|
||||||
|
<div class="main-grid">
|
||||||
<main role="main">
|
<main role="main">
|
||||||
<div class="block">The overview summary page header.</div>
|
<div class="block">The overview summary page header.</div>
|
||||||
<div id="all-packages-table">
|
<div id="all-packages-table">
|
||||||
@ -720,13 +722,11 @@ public class TestModules extends JavadocTester {
|
|||||||
void checkModuleSummary() {
|
void checkModuleSummary() {
|
||||||
checkOutput("moduleA/module-summary.html", true,
|
checkOutput("moduleA/module-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<ul class="sub-nav-list">
|
<ol class="toc-list">
|
||||||
<li>Module: </li>
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#module-description">Description</a> | </li>
|
<li><a href="#packages-summary" tabindex="0">Packages</a></li>
|
||||||
<li><a href="#modules-summary">Modules</a> | </li>
|
<li><a href="#modules-summary" tabindex="0">Modules</a></li>
|
||||||
<li><a href="#packages-summary">Packages</a> | </li>
|
</ol>""",
|
||||||
<li>Services</li>
|
|
||||||
</ul>""",
|
|
||||||
"""
|
"""
|
||||||
<section class="modules-summary" id="modules-summary">
|
<section class="modules-summary" id="modules-summary">
|
||||||
<!-- ============ MODULES SUMMARY =========== -->
|
<!-- ============ MODULES SUMMARY =========== -->
|
||||||
@ -748,10 +748,11 @@ public class TestModules extends JavadocTester {
|
|||||||
""");
|
""");
|
||||||
checkOutput("moduleB/module-summary.html", true,
|
checkOutput("moduleB/module-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<li><a href="#module-description">Description</a> | </li>
|
<ol class="toc-list">
|
||||||
<li>Modules | </li>
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#packages-summary">Packages</a> | </li>
|
<li><a href="#packages-summary" tabindex="0">Packages</a></li>
|
||||||
<li><a href="#services-summary">Services</a></li>""",
|
<li><a href="#services-summary" tabindex="0">Services</a></li>
|
||||||
|
</ol>""",
|
||||||
"""
|
"""
|
||||||
<!-- ============ PACKAGES SUMMARY =========== -->
|
<!-- ============ PACKAGES SUMMARY =========== -->
|
||||||
<h2>Packages</h2>""",
|
<h2>Packages</h2>""",
|
||||||
@ -822,23 +823,19 @@ public class TestModules extends JavadocTester {
|
|||||||
void checkModuleFilesAndLinks(boolean found) {
|
void checkModuleFilesAndLinks(boolean found) {
|
||||||
checkFileAndOutput("moduleA/testpkgmdlA/package-summary.html", found,
|
checkFileAndOutput("moduleA/testpkgmdlA/package-summary.html", found,
|
||||||
"""
|
"""
|
||||||
<li><a href="../module-summary.html">Module</a></li>""",
|
<li><a href="../module-summary.html">moduleA</a></li>""",
|
||||||
"""
|
"""
|
||||||
<div class="sub-title"><span class="module-label-in-package">Module</span> \
|
<li><a href="../module-summary.html">moduleA</a></li>""");
|
||||||
<a href="../module-summary.html">moduleA</a></div>""");
|
|
||||||
checkFileAndOutput("moduleA/testpkgmdlA/TestClassInModuleA.html", found,
|
checkFileAndOutput("moduleA/testpkgmdlA/TestClassInModuleA.html", found,
|
||||||
"""
|
"""
|
||||||
<li><a href="../module-summary.html">Module</a></li>""",
|
<li><a href="../module-summary.html">moduleA</a></li>""",
|
||||||
"""
|
"""
|
||||||
<div class="sub-title"><span class="module-label-in-type">Module</span> <a \
|
<li><a href="../module-summary.html">moduleA</a></li>""");
|
||||||
href="../module-summary.html">moduleA</a></div>""");
|
|
||||||
checkFileAndOutput("moduleB/testpkgmdlB/AnnotationType.html", found,
|
checkFileAndOutput("moduleB/testpkgmdlB/AnnotationType.html", found,
|
||||||
"""
|
"""
|
||||||
<div class="sub-title"><span class="module-label-in-type">Module</span> <a \
|
<li><a href="../module-summary.html">moduleB</a></li>""",
|
||||||
href="../module-summary.html">moduleB</a></div>""",
|
|
||||||
"""
|
"""
|
||||||
<div class="sub-title"><span class="package-label-in-type">Package</span> <\
|
<li><a href="package-summary.html">testpkgmdlB</a></li>""");
|
||||||
a href="package-summary.html">testpkgmdlB</a></div>""");
|
|
||||||
checkFiles(found,
|
checkFiles(found,
|
||||||
"moduleA/module-summary.html");
|
"moduleA/module-summary.html");
|
||||||
}
|
}
|
||||||
@ -900,10 +897,11 @@ public class TestModules extends JavadocTester {
|
|||||||
</div>""");
|
</div>""");
|
||||||
checkOutput("moduleA/module-summary.html", true,
|
checkOutput("moduleA/module-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<li><a href="#module-description">Description</a> | </li>
|
<ol class="toc-list">
|
||||||
<li><a href="#modules-summary">Modules</a> | </li>
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#packages-summary">Packages</a> | </li>
|
<li><a href="#packages-summary" tabindex="0">Packages</a></li>
|
||||||
<li>Services</li>""",
|
<li><a href="#modules-summary" tabindex="0">Modules</a></li>
|
||||||
|
</ol>""",
|
||||||
"""
|
"""
|
||||||
<div class="col-first even-row-color"><a href="../moduleB/module-summary.html">moduleB</a></div>
|
<div class="col-first even-row-color"><a href="../moduleB/module-summary.html">moduleB</a></div>
|
||||||
<div class="col-last even-row-color"><a href="../moduleB/testpkgmdlB/package-summary.html">testpkgmdlB</a></div>
|
<div class="col-last even-row-color"><a href="../moduleB/testpkgmdlB/package-summary.html">testpkgmdlB</a></div>
|
||||||
@ -914,10 +912,11 @@ public class TestModules extends JavadocTester {
|
|||||||
-tab1"><a href="testpkgmdltags/package-summary.html">testpkgmdltags</a></div>
|
-tab1"><a href="testpkgmdltags/package-summary.html">testpkgmdltags</a></div>
|
||||||
<div class="col-last even-row-color package-summary-table package-summary-table-tab1"> </div>""",
|
<div class="col-last even-row-color package-summary-table package-summary-table-tab1"> </div>""",
|
||||||
"""
|
"""
|
||||||
<li><a href="#module-description">Description</a> | </li>
|
<ol class="toc-list">
|
||||||
<li><a href="#modules-summary">Modules</a> | </li>
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#packages-summary">Packages</a> | </li>
|
<li><a href="#packages-summary" tabindex="0">Packages</a></li>
|
||||||
<li>Services</li>""",
|
<li><a href="#modules-summary" tabindex="0">Modules</a></li>
|
||||||
|
</ol>""",
|
||||||
"""
|
"""
|
||||||
<div class="caption"><span>Indirect Requires</span></div>
|
<div class="caption"><span>Indirect Requires</span></div>
|
||||||
<div class="details-table three-column-summary">""",
|
<div class="details-table three-column-summary">""",
|
||||||
@ -961,10 +960,11 @@ public class TestModules extends JavadocTester {
|
|||||||
<div class="col-last even-row-color package-summary-table package-summary-table-tab1"> </div>""");
|
<div class="col-last even-row-color package-summary-table package-summary-table-tab1"> </div>""");
|
||||||
checkOutput("moduleB/module-summary.html", found,
|
checkOutput("moduleB/module-summary.html", found,
|
||||||
"""
|
"""
|
||||||
<li><a href="#module-description">Description</a> | </li>
|
<ol class="toc-list">
|
||||||
<li>Modules | </li>
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#packages-summary">Packages</a> | </li>
|
<li><a href="#packages-summary" tabindex="0">Packages</a></li>
|
||||||
<li><a href="#services-summary">Services</a></li>""",
|
<li><a href="#services-summary" tabindex="0">Services</a></li>
|
||||||
|
</ol>""",
|
||||||
"""
|
"""
|
||||||
<div class="col-first even-row-color package-summary-table package-summary-table\
|
<div class="col-first even-row-color package-summary-table package-summary-table\
|
||||||
-tab2"><a href="testpkgmdlB/package-summary.html">testpkgmdlB</a></div>
|
-tab2"><a href="testpkgmdlB/package-summary.html">testpkgmdlB</a></div>
|
||||||
@ -1037,10 +1037,12 @@ public class TestModules extends JavadocTester {
|
|||||||
<div class="col-last even-row-color package-summary-table package-summary-table-tab3"> </div>""");
|
<div class="col-last even-row-color package-summary-table package-summary-table-tab3"> </div>""");
|
||||||
checkOutput("moduleB/module-summary.html", found,
|
checkOutput("moduleB/module-summary.html", found,
|
||||||
"""
|
"""
|
||||||
<li><a href="#module-description">Description</a> | </li>
|
<ol class="toc-list">
|
||||||
<li><a href="#modules-summary">Modules</a> | </li>
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#packages-summary">Packages</a> | </li>
|
<li><a href="#packages-summary" tabindex="0">Packages</a></li>
|
||||||
<li><a href="#services-summary">Services</a></li>""",
|
<li><a href="#modules-summary" tabindex="0">Modules</a></li>
|
||||||
|
<li><a href="#services-summary" tabindex="0">Services</a></li>
|
||||||
|
</ol>""",
|
||||||
"""
|
"""
|
||||||
<div class="col-first even-row-color package-summary-table package-summary-table\
|
<div class="col-first even-row-color package-summary-table package-summary-table\
|
||||||
-tab2"><a href="testpkgmdlB/package-summary.html">testpkgmdlB</a></div>
|
-tab2"><a href="testpkgmdlB/package-summary.html">testpkgmdlB</a></div>
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2018, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -23,7 +23,7 @@
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* @test
|
* @test
|
||||||
* @bug 8196027 8196202
|
* @bug 8196027 8196202 8320458
|
||||||
* @summary test navigation links
|
* @summary test navigation links
|
||||||
* @modules jdk.compiler/com.sun.tools.javac.api
|
* @modules jdk.compiler/com.sun.tools.javac.api
|
||||||
* jdk.compiler/com.sun.tools.javac.main
|
* jdk.compiler/com.sun.tools.javac.main
|
||||||
@ -54,6 +54,122 @@ public class TestModuleNavigation extends JavadocTester {
|
|||||||
tb = new ToolBox();
|
tb = new ToolBox();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testSingleModule(Path base) throws Exception {
|
||||||
|
Path src = Files.createDirectories(base.resolve("src"));
|
||||||
|
ModuleBuilder mb = new ModuleBuilder(tb, "m")
|
||||||
|
.comment("Module m.")
|
||||||
|
.exports("p1")
|
||||||
|
.classes("package p1; @Deprecated public class A {}")
|
||||||
|
.classes("package p1; public class B {}");
|
||||||
|
mb.write(src);
|
||||||
|
|
||||||
|
javadoc("-d", base.resolve("out-single-module").toString(),
|
||||||
|
"--module-source-path", src.toString(),
|
||||||
|
"--module", "m");
|
||||||
|
checkExit(Exit.OK);
|
||||||
|
|
||||||
|
checkOutput("index.html", true,
|
||||||
|
"""
|
||||||
|
<script type="text/javascript">window.location.replace('m/module-summary.html')</script>
|
||||||
|
<noscript>
|
||||||
|
<meta http-equiv="Refresh" content="0;m/module-summary.html">
|
||||||
|
</noscript>""",
|
||||||
|
"""
|
||||||
|
<p><a href="m/module-summary.html">m/module-summary.html</a></p>""");
|
||||||
|
|
||||||
|
checkOutput("m/module-summary.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li class="nav-bar-cell1-rev">Module</li>
|
||||||
|
<li><a href="../overview-tree.html">Tree</a></li>
|
||||||
|
<li><a href="../deprecated-list.html">Deprecated</a></li>
|
||||||
|
<li><a href="../index-all.html">Index</a></li>
|
||||||
|
<li><a href="../search.html">Search</a></li>
|
||||||
|
<li><a href="../help-doc.html#module">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("overview-tree.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="m/module-summary.html">Module</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Tree</li>
|
||||||
|
<li><a href="deprecated-list.html">Deprecated</a></li>
|
||||||
|
<li><a href="index-all.html">Index</a></li>
|
||||||
|
<li><a href="search.html">Search</a></li>
|
||||||
|
<li><a href="help-doc.html#tree">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("deprecated-list.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="m/module-summary.html">Module</a></li>
|
||||||
|
<li><a href="overview-tree.html">Tree</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Deprecated</li>
|
||||||
|
<li><a href="index-all.html">Index</a></li>
|
||||||
|
<li><a href="search.html">Search</a></li>
|
||||||
|
<li><a href="help-doc.html#deprecated">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("index-all.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="m/module-summary.html">Module</a></li>
|
||||||
|
<li><a href="overview-tree.html">Tree</a></li>
|
||||||
|
<li><a href="deprecated-list.html">Deprecated</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Index</li>
|
||||||
|
<li><a href="search.html">Search</a></li>
|
||||||
|
<li><a href="help-doc.html#index">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("search.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="m/module-summary.html">Module</a></li>
|
||||||
|
<li><a href="overview-tree.html">Tree</a></li>
|
||||||
|
<li><a href="deprecated-list.html">Deprecated</a></li>
|
||||||
|
<li><a href="index-all.html">Index</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Search</li>
|
||||||
|
<li><a href="help-doc.html#search">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("help-doc.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="m/module-summary.html">Module</a></li>
|
||||||
|
<li><a href="overview-tree.html">Tree</a></li>
|
||||||
|
<li><a href="deprecated-list.html">Deprecated</a></li>
|
||||||
|
<li><a href="index-all.html">Index</a></li>
|
||||||
|
<li><a href="search.html">Search</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Help</li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("m/p1/package-summary.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="../module-summary.html">Module</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Package</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="../../deprecated-list.html">Deprecated</a></li>
|
||||||
|
<li><a href="../../index-all.html">Index</a></li>
|
||||||
|
<li><a href="../../search.html">Search</a></li>
|
||||||
|
<li><a href="../../help-doc.html#package">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("m/p1/A.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="../module-summary.html">Module</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Class</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="../../deprecated-list.html">Deprecated</a></li>
|
||||||
|
<li><a href="../../index-all.html">Index</a></li>
|
||||||
|
<li><a href="../../search.html">Search</a></li>
|
||||||
|
<li><a href="../../help-doc.html#class">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void checkNavbar(Path base) throws Exception {
|
public void checkNavbar(Path base) throws Exception {
|
||||||
Path src = Files.createDirectories(base.resolve("src"));
|
Path src = Files.createDirectories(base.resolve("src"));
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2003, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2003, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -23,21 +23,22 @@
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* @test
|
* @test
|
||||||
* @bug 4131628 4664607 7025314 8023700 7198273 8025633 8026567 8081854 8150188 8151743 8196027 8182765
|
* @bug 7025314 8023700 7198273 8025633 8026567 8081854 8196027 8182765
|
||||||
* 8196200 8196202 8223378 8258659 8261976
|
* 8196200 8196202 8223378 8258659 8261976 8320458
|
||||||
* @summary Make sure the Next/Prev Class links iterate through all types.
|
* @summary Make sure the Next/Prev Class links iterate through all types.
|
||||||
* Make sure the navagation is 2 columns, not 3.
|
* Make sure the navagation is 2 columns, not 3.
|
||||||
* @library /tools/lib ../../lib
|
* @library /tools/lib ../../lib
|
||||||
* @modules jdk.javadoc/jdk.javadoc.internal.tool
|
* @modules jdk.javadoc/jdk.javadoc.internal.tool
|
||||||
* @build toolbox.ToolBox javadoc.tester.*
|
* @build toolbox.ToolBox javadoc.tester.* builder.ClassBuilder
|
||||||
* @run main TestNavigation
|
* @run main TestNavigation
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.nio.file.Files;
|
||||||
import java.nio.file.Path;
|
import java.nio.file.Path;
|
||||||
import java.nio.file.Paths;
|
|
||||||
|
|
||||||
import javadoc.tester.JavadocTester;
|
import javadoc.tester.JavadocTester;
|
||||||
|
import builder.ClassBuilder;
|
||||||
import toolbox.ToolBox;
|
import toolbox.ToolBox;
|
||||||
|
|
||||||
public class TestNavigation extends JavadocTester {
|
public class TestNavigation extends JavadocTester {
|
||||||
@ -53,28 +54,67 @@ public class TestNavigation extends JavadocTester {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void test(Path ignore) {
|
public void testOverview(Path base) {
|
||||||
javadoc("-d", "out",
|
javadoc("-d", base.resolve("api").toString(),
|
||||||
"-overview", testSrc("overview.html"),
|
"-overview", testSrc("overview.html"),
|
||||||
"-sourcepath", testSrc,
|
"-sourcepath", testSrc,
|
||||||
"pkg");
|
"pkg");
|
||||||
checkExit(Exit.OK);
|
checkExit(Exit.OK);
|
||||||
checkSubNav();
|
checkSubNav();
|
||||||
|
|
||||||
|
checkOutput("index.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li class="nav-bar-cell1-rev">Overview</li>
|
||||||
|
<li><a href="pkg/package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="index-all.html">Index</a></li>
|
||||||
|
<li><a href="search.html">Search</a></li>
|
||||||
|
<li><a href="help-doc.html#overview">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("pkg/package-summary.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="../index.html">Overview</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Package</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="../index-all.html">Index</a></li>
|
||||||
|
<li><a href="../search.html">Search</a></li>
|
||||||
|
<li><a href="../help-doc.html#package">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
checkOutput("pkg/A.html", true,
|
checkOutput("pkg/A.html", true,
|
||||||
"""
|
"""
|
||||||
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
<li><a href="../index.html">Overview</a></li>""");
|
<li><a href="../index.html">Overview</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Class</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="../index-all.html">Index</a></li>
|
||||||
|
<li><a href="../search.html">Search</a></li>
|
||||||
|
<li><a href="../help-doc.html#class">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
checkOutput("pkg/C.html", true,
|
checkOutput("pkg/C.html", true,
|
||||||
"""
|
"""
|
||||||
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
<li><a href="../index.html">Overview</a></li>""");
|
<li><a href="../index.html">Overview</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Class</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="../index-all.html">Index</a></li>
|
||||||
|
<li><a href="../search.html">Search</a></li>
|
||||||
|
<li><a href="../help-doc.html#class">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
checkOutput("pkg/E.html", true,
|
checkOutput("pkg/E.html", true,
|
||||||
"""
|
"""
|
||||||
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
<li><a href="../index.html">Overview</a></li>""");
|
<li><a href="../index.html">Overview</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Class</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="../index-all.html">Index</a></li>
|
||||||
|
<li><a href="../search.html">Search</a></li>
|
||||||
|
<li><a href="../help-doc.html#class">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
checkOutput("pkg/I.html", true,
|
checkOutput("pkg/I.html", true,
|
||||||
// Test for 4664607
|
// Test for 4664607
|
||||||
@ -84,79 +124,10 @@ public class TestNavigation extends JavadocTester {
|
|||||||
""",
|
""",
|
||||||
"""
|
"""
|
||||||
<li><a href="../index.html">Overview</a></li>""");
|
<li><a href="../index.html">Overview</a></li>""");
|
||||||
|
|
||||||
// Remaining tests check for additional padding to offset the fixed navigation bar.
|
|
||||||
checkOutput("pkg/A.html", true,
|
|
||||||
"""
|
|
||||||
<!-- ========= END OF TOP NAVBAR ========= -->
|
|
||||||
<span class="skip-nav" id="skip-navbar-top"></span></nav>
|
|
||||||
</header>
|
|
||||||
<main role="main">
|
|
||||||
<!-- ======== START OF CLASS DATA ======== -->""");
|
|
||||||
|
|
||||||
checkOutput("pkg/package-summary.html", true,
|
|
||||||
"""
|
|
||||||
<!-- ========= END OF TOP NAVBAR ========= -->
|
|
||||||
<span class="skip-nav" id="skip-navbar-top"></span></nav>
|
|
||||||
</header>
|
|
||||||
<main role="main">
|
|
||||||
<div class="header">""");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test for checking additional padding to offset the fixed navigation bar in HTML5.
|
|
||||||
@Test
|
|
||||||
public void test1(Path ignore) {
|
|
||||||
javadoc("-d", "out-1",
|
|
||||||
"-html5",
|
|
||||||
"-sourcepath", testSrc,
|
|
||||||
"pkg");
|
|
||||||
checkExit(Exit.OK);
|
|
||||||
checkSubNav();
|
|
||||||
|
|
||||||
checkOutput("pkg/A.html", true,
|
|
||||||
"""
|
|
||||||
<!-- ========= END OF TOP NAVBAR ========= -->
|
|
||||||
<span class="skip-nav" id="skip-navbar-top"></span></nav>
|
|
||||||
</header>
|
|
||||||
<main role="main">
|
|
||||||
<!-- ======== START OF CLASS DATA ======== -->""");
|
|
||||||
|
|
||||||
checkOutput("pkg/package-summary.html", true,
|
|
||||||
"""
|
|
||||||
<!-- ========= END OF TOP NAVBAR ========= -->
|
|
||||||
<span class="skip-nav" id="skip-navbar-top"></span></nav>
|
|
||||||
""");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test to make sure that no extra padding for nav bar gets generated if -nonavbar is specified.
|
|
||||||
@Test
|
|
||||||
public void test2(Path ignore) {
|
|
||||||
javadoc("-d", "out-2",
|
|
||||||
"-nonavbar",
|
|
||||||
"-sourcepath", testSrc,
|
|
||||||
"pkg");
|
|
||||||
checkExit(Exit.OK);
|
|
||||||
checkSubNav();
|
|
||||||
|
|
||||||
checkOutput("pkg/A.html", false,
|
|
||||||
"""
|
|
||||||
<!-- ========= END OF TOP NAVBAR ========= -->
|
|
||||||
</div>
|
|
||||||
<div class="skip-nav"><a id="skip-navbar-top"></a></div>
|
|
||||||
</nav>
|
|
||||||
</header>
|
|
||||||
<!-- ======== START OF CLASS DATA ======== -->""");
|
|
||||||
|
|
||||||
checkOutput("pkg/package-summary.html", false,
|
|
||||||
"""
|
|
||||||
<!-- ========= END OF TOP NAVBAR ========= -->
|
|
||||||
</div>
|
|
||||||
<div class="skip-nav"><a id="skip-navbar-top"></a></div>
|
|
||||||
</nav>""");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void test3(Path base) throws IOException {
|
public void testNavLinks(Path base) throws IOException {
|
||||||
Path src = base.resolve("src");
|
Path src = base.resolve("src");
|
||||||
tb.writeJavaFiles(src,
|
tb.writeJavaFiles(src,
|
||||||
"""
|
"""
|
||||||
@ -201,57 +172,82 @@ public class TestNavigation extends JavadocTester {
|
|||||||
package pkg1; public interface InterfaceWithNoMembers {
|
package pkg1; public interface InterfaceWithNoMembers {
|
||||||
}""");
|
}""");
|
||||||
|
|
||||||
javadoc("-d", "out-3",
|
javadoc("-d", base.resolve("api").toString(),
|
||||||
"-sourcepath", src.toString(),
|
"-sourcepath", src.toString(),
|
||||||
"pkg1");
|
"pkg1");
|
||||||
checkExit(Exit.OK);
|
checkExit(Exit.OK);
|
||||||
|
|
||||||
checkOrder("pkg1/A.X.html",
|
checkOrder("pkg1/A.X.html",
|
||||||
"Summary",
|
|
||||||
"""
|
"""
|
||||||
<li><a href="#nested-class-summary">Nested</a> | </li>""",
|
<ol class="toc-list">
|
||||||
"""
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#field-summary">Field</a> | </li>""",
|
<li><a href="#nested-class-summary" tabindex="0">Nested Class Summary</a></li>
|
||||||
"""
|
<li><a href="#field-summary" tabindex="0">Field Summary</a></li>
|
||||||
<li><a href="#constructor-summary">Constr</a> | </li>""",
|
<li><a href="#constructor-summary" tabindex="0">Constructor Summary</a></li>
|
||||||
"""
|
<li><a href="#method-summary" tabindex="0">Method Summary</a></li>
|
||||||
<li><a href="#method-summary">Method</a></li>""");
|
<li><a href="#field-detail" tabindex="0">Field Details</a>
|
||||||
|
<ol class="toc-list">
|
||||||
|
<li><a href="#field" tabindex="0">field</a></li>
|
||||||
|
</ol>
|
||||||
|
</li>
|
||||||
|
<li><a href="#constructor-detail" tabindex="0">Constructor Details</a>
|
||||||
|
<ol class="toc-list">
|
||||||
|
<li><a href="#%3Cinit%3E()" tabindex="0">X()</a></li>
|
||||||
|
</ol>
|
||||||
|
</li>
|
||||||
|
<li><a href="#method-detail" tabindex="0">Method Details</a>
|
||||||
|
<ol class="toc-list">
|
||||||
|
<li><a href="#method()" tabindex="0">method()</a></li>
|
||||||
|
</ol>
|
||||||
|
</li>
|
||||||
|
</ol>""");
|
||||||
|
|
||||||
checkOrder("pkg1/A.Y.html",
|
checkOrder("pkg1/A.Y.html",
|
||||||
"Summary",
|
|
||||||
"""
|
"""
|
||||||
<li><a href="#nested-class-summary">Nested</a> | </li>""",
|
<ol class="toc-list">
|
||||||
"""
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#field-summary">Field</a> | </li>""",
|
<li><a href="#nested-class-summary" tabindex="0">Nested Class Summary</a></li>
|
||||||
"""
|
<li><a href="#field-summary" tabindex="0">Field Summary</a></li>
|
||||||
<li><a href="#constructor-summary">Constr</a> | </li>""",
|
<li><a href="#constructor-summary" tabindex="0">Constructor Summary</a></li>
|
||||||
"""
|
<li><a href="#method-summary" tabindex="0">Method Summary</a></li>
|
||||||
<li><a href="#method-summary">Method</a></li>""");
|
<li><a href="#constructor-detail" tabindex="0">Constructor Details</a>
|
||||||
|
<ol class="toc-list">
|
||||||
|
<li><a href="#%3Cinit%3E()" tabindex="0">Y()</a></li>
|
||||||
|
</ol>
|
||||||
|
</li>
|
||||||
|
</ol>""");
|
||||||
|
|
||||||
checkOrder("pkg1/A.X.IC.html",
|
checkOrder("pkg1/A.X.IC.html",
|
||||||
"Summary",
|
|
||||||
"<li>Nested | </li>",
|
|
||||||
"<li>Field | </li>",
|
|
||||||
"""
|
"""
|
||||||
<li><a href="#constructor-summary">Constr</a> | </li>""",
|
<ol class="toc-list">
|
||||||
"""
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#method-summary">Method</a></li>""");
|
<li><a href="#constructor-summary" tabindex="0">Constructor Summary</a></li>
|
||||||
|
<li><a href="#method-summary" tabindex="0">Method Summary</a></li>
|
||||||
|
<li><a href="#constructor-detail" tabindex="0">Constructor Details</a>
|
||||||
|
<ol class="toc-list">
|
||||||
|
<li><a href="#%3Cinit%3E()" tabindex="0">IC()</a></li>
|
||||||
|
</ol>
|
||||||
|
</li>
|
||||||
|
</ol>""");
|
||||||
|
|
||||||
checkOrder("pkg1/C.html",
|
checkOrder("pkg1/C.html",
|
||||||
"Summary",
|
|
||||||
"<li>Nested | </li>",
|
|
||||||
"<li>Field | </li>",
|
|
||||||
"""
|
"""
|
||||||
<li><a href="#constructor-summary">Constr</a> | </li>""",
|
<ol class="toc-list">
|
||||||
"""
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<li><a href="#method-summary">Method</a></li>""");
|
<li><a href="#constructor-summary" tabindex="0">Constructor Summary</a></li>
|
||||||
|
<li><a href="#method-summary" tabindex="0">Method Summary</a></li>
|
||||||
|
<li><a href="#constructor-detail" tabindex="0">Constructor Details</a>
|
||||||
|
<ol class="toc-list">
|
||||||
|
<li><a href="#%3Cinit%3E()" tabindex="0">C()</a></li>
|
||||||
|
</ol>
|
||||||
|
</li>
|
||||||
|
</ol>""");
|
||||||
|
|
||||||
checkOrder("pkg1/InterfaceWithNoMembers.html",
|
checkOrder("pkg1/InterfaceWithNoMembers.html",
|
||||||
"Summary",
|
"""
|
||||||
"<li>Nested | </li>",
|
<ol class="toc-list">
|
||||||
"<li>Field | </li>",
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
"<li>Constr | </li>",
|
</ol>""");
|
||||||
"<li>Method</li>");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkSubNav() {
|
private void checkSubNav() {
|
||||||
@ -301,4 +297,123 @@ public class TestNavigation extends JavadocTester {
|
|||||||
<script type="text/javascript"><!--
|
<script type="text/javascript"><!--
|
||||||
allClassesLink = document.getElementById("allclasses_navbar_bottom");""");
|
allClassesLink = document.getElementById("allclasses_navbar_bottom");""");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testSinglePackage(Path base) {
|
||||||
|
javadoc("-d", base.resolve("api").toString(),
|
||||||
|
"-sourcepath", testSrc,
|
||||||
|
"pkg");
|
||||||
|
checkExit(Exit.OK);
|
||||||
|
checkSubNav();
|
||||||
|
|
||||||
|
checkOutput("index.html", true,
|
||||||
|
"""
|
||||||
|
<meta http-equiv="Refresh" content="0;pkg/package-summary.html">""",
|
||||||
|
"""
|
||||||
|
<p><a href="pkg/package-summary.html">pkg/package-summary.html</a></p>""");
|
||||||
|
|
||||||
|
checkOutput("pkg/package-summary.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li class="nav-bar-cell1-rev">Package</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="../index-all.html">Index</a></li>
|
||||||
|
<li><a href="../search.html">Search</a></li>
|
||||||
|
<li><a href="../help-doc.html#package">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("pkg/A.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="package-summary.html">Package</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Class</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="../index-all.html">Index</a></li>
|
||||||
|
<li><a href="../search.html">Search</a></li>
|
||||||
|
<li><a href="../help-doc.html#class">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("pkg/C.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="package-summary.html">Package</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Class</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="../index-all.html">Index</a></li>
|
||||||
|
<li><a href="../search.html">Search</a></li>
|
||||||
|
<li><a href="../help-doc.html#class">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("pkg/E.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="package-summary.html">Package</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Class</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="../index-all.html">Index</a></li>
|
||||||
|
<li><a href="../search.html">Search</a></li>
|
||||||
|
<li><a href="../help-doc.html#class">Help</a></li>
|
||||||
|
</ul>""");
|
||||||
|
|
||||||
|
checkOutput("pkg/I.html", true,
|
||||||
|
// Test for 4664607
|
||||||
|
"""
|
||||||
|
<div class="skip-nav"><a href="#skip-navbar-top" title="Skip navigation links">Skip navigation links</a></div>
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
""",
|
||||||
|
"""
|
||||||
|
<li><a href="package-summary.html">Package</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Class</li>""");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testUnnamedPackage(Path base) throws Exception {
|
||||||
|
Path src = Files.createDirectories(base.resolve("src"));
|
||||||
|
new ClassBuilder(tb, "C")
|
||||||
|
.setModifiers("public", "class")
|
||||||
|
.write(src);
|
||||||
|
|
||||||
|
javadoc("-d", base.resolve("api").toString(),
|
||||||
|
src.resolve("C.java").toString());
|
||||||
|
checkExit(Exit.OK);
|
||||||
|
|
||||||
|
checkOutput("index.html", true,
|
||||||
|
"""
|
||||||
|
<script type="text/javascript">window.location.replace('package-summary.html')</script>
|
||||||
|
<noscript>
|
||||||
|
<meta http-equiv="Refresh" content="0;package-summary.html">
|
||||||
|
</noscript>""");
|
||||||
|
|
||||||
|
checkOutput("package-summary.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li class="nav-bar-cell1-rev">Package</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="index-all.html">Index</a></li>
|
||||||
|
<li><a href="search.html">Search</a></li>
|
||||||
|
<li><a href="help-doc.html#package">Help</a></li>
|
||||||
|
</ul>""",
|
||||||
|
"""
|
||||||
|
<ol class="sub-nav-list">
|
||||||
|
<li><a href="package-summary.html" class="current-selection">Unnamed Package</a></li>
|
||||||
|
</ol>""");
|
||||||
|
|
||||||
|
checkOutput("C.html", true,
|
||||||
|
"""
|
||||||
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
|
<li><a href="package-summary.html">Package</a></li>
|
||||||
|
<li class="nav-bar-cell1-rev">Class</li>
|
||||||
|
<li><a href="package-tree.html">Tree</a></li>
|
||||||
|
<li><a href="index-all.html">Index</a></li>
|
||||||
|
<li><a href="search.html">Search</a></li>
|
||||||
|
<li><a href="help-doc.html#class">Help</a></li>
|
||||||
|
</ul>""",
|
||||||
|
"""
|
||||||
|
<ol class="sub-nav-list">
|
||||||
|
<li><a href="package-summary.html">Unnamed Package</a></li>
|
||||||
|
>
|
||||||
|
<li><a href="C.html" class="current-selection" title="class in Unnamed Package">C</a></li>
|
||||||
|
</ol>""");
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2002, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2002, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -78,11 +78,11 @@ public class TestPackagePage extends JavadocTester {
|
|||||||
checkExit(Exit.OK);
|
checkExit(Exit.OK);
|
||||||
|
|
||||||
//With multiple packages, there is no package link in general pages.
|
//With multiple packages, there is no package link in general pages.
|
||||||
checkOutput("deprecated-list.html", true,
|
checkOutput("deprecated-list.html", false,
|
||||||
"<li>Package</li>");
|
"<li>Package</li>");
|
||||||
checkOutput("index-all.html", true,
|
checkOutput("index-all.html", false,
|
||||||
"<li>Package</li>");
|
"<li>Package</li>");
|
||||||
checkOutput("help-doc.html", true,
|
checkOutput("help-doc.html", false,
|
||||||
"<li>Package</li>");
|
"<li>Package</li>");
|
||||||
checkOutput("allclasses-index.html", true,
|
checkOutput("allclasses-index.html", true,
|
||||||
"""
|
"""
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2017, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2017, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -24,7 +24,7 @@
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
* @test
|
* @test
|
||||||
* @bug 8189841 8253117 8263507
|
* @bug 8189841 8253117 8263507 8320458
|
||||||
* @summary Error in alternate row coloring in package-summary files
|
* @summary Error in alternate row coloring in package-summary files
|
||||||
* @summary Improve structure of package summary pages
|
* @summary Improve structure of package summary pages
|
||||||
* @library ../../lib/
|
* @library ../../lib/
|
||||||
@ -51,37 +51,27 @@ public class TestPackageSummary extends JavadocTester {
|
|||||||
|
|
||||||
checkOutput("pkg/package-summary.html", true,
|
checkOutput("pkg/package-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<div class="sub-nav">
|
<ol class="toc-list">
|
||||||
<div id="navbar-sub-list">
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<ul class="sub-nav-list">
|
<li><a href="#class-summary" tabindex="0">Classes and Interfaces</a></li>
|
||||||
<li>Package: </li>
|
</ol>
|
||||||
<li>Description | </li>
|
""");
|
||||||
<li>Related Packages | </li>
|
|
||||||
<li><a href="#class-summary">Classes and Interfaces</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>""");
|
|
||||||
checkOutput("pkg1/package-summary.html", true,
|
checkOutput("pkg1/package-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<div class="sub-nav">
|
<ol class="toc-list">
|
||||||
<div id="navbar-sub-list">
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<ul class="sub-nav-list">
|
<li><a href="#related-package-summary" tabindex="0">Related Packages</a></li>
|
||||||
<li>Package: </li>
|
<li><a href="#class-summary" tabindex="0">Classes and Interfaces</a></li>
|
||||||
<li><a href="#package-description">Description</a> | </li>
|
</ol>
|
||||||
<li><a href="#related-package-summary">Related Packages</a> | </li>
|
""");
|
||||||
<li><a href="#class-summary">Classes and Interfaces</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>""");
|
|
||||||
checkOutput("pkg1/sub/package-summary.html", true,
|
checkOutput("pkg1/sub/package-summary.html", true,
|
||||||
"""
|
"""
|
||||||
<div class="sub-nav">
|
<ol class="toc-list">
|
||||||
<div id="navbar-sub-list">
|
<li><a href="#" tabindex="0">Description</a></li>
|
||||||
<ul class="sub-nav-list">
|
<li><a href="#related-package-summary" tabindex="0">Related Packages</a></li>
|
||||||
<li>Package: </li>
|
<li><a href="#class-summary" tabindex="0">Classes and Interfaces</a></li>
|
||||||
<li>Description | </li>
|
</ol>
|
||||||
<li><a href="#related-package-summary">Related Packages</a> | </li>
|
""");
|
||||||
<li><a href="#class-summary">Classes and Interfaces</a></li>
|
|
||||||
</ul>
|
|
||||||
</div>""");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2015, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2015, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -426,14 +426,17 @@ public class TestSearch extends JavadocTester {
|
|||||||
"""
|
"""
|
||||||
<script type="text/javascript" src="script-files/jquery-ui.min.js"></script>""",
|
<script type="text/javascript" src="script-files/jquery-ui.min.js"></script>""",
|
||||||
"""
|
"""
|
||||||
var pathtoroot = "./";
|
const pathtoroot = "./";
|
||||||
loadScripts(document, 'script');""",
|
loadScripts(document, 'script');""",
|
||||||
"<div class=\"nav-list-search\">",
|
"<div class=\"nav-list-search\">",
|
||||||
"""
|
"""
|
||||||
<div class="nav-list-search"><a href="search.html">SEARCH</a>
|
<li><a href="search.html">Search</a></li>""",
|
||||||
<input type="text" id="search-input" disabled placeholder="Search">
|
"""
|
||||||
<input type="reset" id="reset-button" disabled value="reset">
|
<div class="nav-list-search">
|
||||||
""");
|
<input type="text" id="search-input" disabled placeholder="Search" aria-label="S\
|
||||||
|
earch in documentation" autocomplete="off" autocapitalize="off">
|
||||||
|
<input type="reset" id="reset-search" disabled value="Reset">
|
||||||
|
</div>""");
|
||||||
}
|
}
|
||||||
|
|
||||||
void checkSingleIndex() {
|
void checkSingleIndex() {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2019, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2019, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -41,6 +41,7 @@ import java.nio.file.Path;
|
|||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
import java.util.Stack;
|
import java.util.Stack;
|
||||||
import java.util.TreeMap;
|
import java.util.TreeMap;
|
||||||
import java.util.function.Function;
|
import java.util.function.Function;
|
||||||
@ -225,7 +226,7 @@ public class TestSingletonLists extends JavadocTester {
|
|||||||
public class ListChecker extends HtmlChecker {
|
public class ListChecker extends HtmlChecker {
|
||||||
private int listErrors;
|
private int listErrors;
|
||||||
// Ignore "Constant Field Values" @see items for final fields created by javadoc
|
// Ignore "Constant Field Values" @see items for final fields created by javadoc
|
||||||
private boolean inSeeList;
|
private int inSeeOrTocList = 0;
|
||||||
private Stack<Map<String,Integer>> counts = new Stack<>();
|
private Stack<Map<String,Integer>> counts = new Stack<>();
|
||||||
private String fileName;
|
private String fileName;
|
||||||
private List<String> excludeFiles = List.of(
|
private List<String> excludeFiles = List.of(
|
||||||
@ -270,8 +271,9 @@ public class TestSingletonLists extends JavadocTester {
|
|||||||
switch (name) {
|
switch (name) {
|
||||||
case "ul": case "ol": case "dl":
|
case "ul": case "ol": case "dl":
|
||||||
counts.push(new TreeMap<>());
|
counts.push(new TreeMap<>());
|
||||||
if ("tag-list".equals(attrs.get("class"))) {
|
String classAttr = attrs.get("class");
|
||||||
inSeeList = true;
|
if (classAttr != null && Set.of("tag-list", "toc-list", "sub-nav-list").contains(classAttr)) {
|
||||||
|
inSeeOrTocList++;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -288,10 +290,10 @@ public class TestSingletonLists extends JavadocTester {
|
|||||||
switch (name) {
|
switch (name) {
|
||||||
case "ul": case "ol": {
|
case "ul": case "ol": {
|
||||||
Map<String,Integer> c = counts.pop();
|
Map<String,Integer> c = counts.pop();
|
||||||
if (inSeeList) {
|
if (inSeeOrTocList > 0) {
|
||||||
// Ignore "Constant Field Values" @see items for final fields created by javadoc
|
// Ignore "Constant Field Values" @see items for final fields created by javadoc
|
||||||
inSeeList = false;
|
inSeeOrTocList--;
|
||||||
} else if (c.get("li") == 0) {
|
} else if (!c.containsKey("li")) {
|
||||||
error(currFile, getLineNumber(), "empty list");
|
error(currFile, getLineNumber(), "empty list");
|
||||||
listErrors++;
|
listErrors++;
|
||||||
} else if (c.get("li") == 1 && fileName != null && !excludeFiles.contains(fileName)) {
|
} else if (c.get("li") == 1 && fileName != null && !excludeFiles.contains(fileName)) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2021, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2021, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -112,21 +112,31 @@ public class TestSpecTag extends JavadocTester {
|
|||||||
checkOutput("external-specs.html", true,
|
checkOutput("external-specs.html", true,
|
||||||
"""
|
"""
|
||||||
<!-- ========= START OF TOP NAVBAR ======= -->
|
<!-- ========= START OF TOP NAVBAR ======= -->
|
||||||
<div class="top-nav" id="navbar-top"><button id="navbar-toggle-button" aria-controls="navbar-top" aria-expanded="false" aria-label="Toggle navigation links"><span class="nav-bar-toggle-icon"> </span><span class="nav-bar-toggle-icon"> </span><span class="nav-bar-toggle-icon"> </span></button>
|
<div class="top-nav" id="navbar-top">
|
||||||
<div class="skip-nav"><a href="#skip-navbar-top" title="Skip navigation links">Skip navigation links</a></div>
|
<div class="nav-content">
|
||||||
|
<div class="nav-menu-button"><button id="navbar-toggle-button" aria-controls="na\
|
||||||
|
vbar-top" aria-expanded="false" aria-label="Toggle navigation links"><span class\
|
||||||
|
="nav-bar-toggle-icon"> </span><span class="nav-bar-toggle-icon"> </sp\
|
||||||
|
an><span class="nav-bar-toggle-icon"> </span></button></div>
|
||||||
|
<div class="skip-nav"><a href="#skip-navbar-top" title="Skip navigation links">S\
|
||||||
|
kip navigation links</a></div>
|
||||||
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
<ul id="navbar-top-firstrow" class="nav-list" title="Navigation">
|
||||||
<li><a href="p/package-summary.html">Package</a></li>
|
<li><a href="p/package-summary.html">Package</a></li>
|
||||||
<li>Class</li>
|
|
||||||
<li><a href="p/package-tree.html">Tree</a></li>
|
<li><a href="p/package-tree.html">Tree</a></li>
|
||||||
<li><a href="index-all.html">Index</a></li>
|
<li><a href="index-all.html">Index</a></li>
|
||||||
|
<li><a href="search.html">Search</a></li>
|
||||||
<li><a href="help-doc.html#external-specs">Help</a></li>
|
<li><a href="help-doc.html#external-specs">Help</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
<div class="sub-nav">
|
<div class="sub-nav">
|
||||||
<div id="navbar-sub-list"></div>
|
<div class="nav-content">
|
||||||
<div class="nav-list-search"><a href="search.html">SEARCH</a>
|
<ol class="sub-nav-list"></ol>
|
||||||
<input type="text" id="search-input" disabled placeholder="Search">
|
<div class="nav-list-search">
|
||||||
<input type="reset" id="reset-button" disabled value="reset">
|
<input type="text" id="search-input" disabled placeholder="Search" aria-label="S\
|
||||||
|
earch in documentation" autocomplete="off" autocapitalize="off">
|
||||||
|
<input type="reset" id="reset-search" disabled value="Reset">
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
<!-- ========= END OF TOP NAVBAR ========= -->
|
<!-- ========= END OF TOP NAVBAR ========= -->
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2005, 2023, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2005, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -77,15 +77,6 @@ public class TestStylesheet extends JavadocTester {
|
|||||||
height:100%;
|
height:100%;
|
||||||
width:100%;
|
width:100%;
|
||||||
}""",
|
}""",
|
||||||
"""
|
|
||||||
iframe {
|
|
||||||
margin:0;
|
|
||||||
padding:0;
|
|
||||||
height:100%;
|
|
||||||
width:100%;
|
|
||||||
overflow-y:scroll;
|
|
||||||
border:none;
|
|
||||||
}""",
|
|
||||||
"""
|
"""
|
||||||
ul {
|
ul {
|
||||||
list-style-type:disc;
|
list-style-type:disc;
|
||||||
@ -147,7 +138,7 @@ public class TestStylesheet extends JavadocTester {
|
|||||||
background-color:var(--search-tag-highlight-color);
|
background-color:var(--search-tag-highlight-color);
|
||||||
}""",
|
}""",
|
||||||
"""
|
"""
|
||||||
a[href]:hover, a[href]:focus {
|
a[href]:hover, a[href]:active {
|
||||||
text-decoration:none;
|
text-decoration:none;
|
||||||
color:var(--link-color-active);
|
color:var(--link-color-active);
|
||||||
}""",
|
}""",
|
||||||
@ -173,7 +164,7 @@ public class TestStylesheet extends JavadocTester {
|
|||||||
display:inline-block;
|
display:inline-block;
|
||||||
}""",
|
}""",
|
||||||
"""
|
"""
|
||||||
#reset-button {
|
input#reset-search, input.reset-filter {
|
||||||
background-color: transparent;
|
background-color: transparent;
|
||||||
background-image:url('x.png');
|
background-image:url('x.png');
|
||||||
background-repeat:no-repeat;
|
background-repeat:no-repeat;
|
||||||
@ -182,10 +173,8 @@ public class TestStylesheet extends JavadocTester {
|
|||||||
border-radius:0;
|
border-radius:0;
|
||||||
width:12px;
|
width:12px;
|
||||||
height:12px;
|
height:12px;
|
||||||
position:absolute;
|
|
||||||
right:12px;
|
|
||||||
top:10px;
|
|
||||||
font-size:0;
|
font-size:0;
|
||||||
|
display:none;
|
||||||
}""",
|
}""",
|
||||||
"""
|
"""
|
||||||
::placeholder {
|
::placeholder {
|
||||||
@ -352,7 +341,6 @@ public class TestStylesheet extends JavadocTester {
|
|||||||
"packages",
|
"packages",
|
||||||
"return-type",
|
"return-type",
|
||||||
// and others...
|
// and others...
|
||||||
"help-section", // part of the help page
|
|
||||||
"hierarchy", // for the hierarchy on a tree page
|
"hierarchy", // for the hierarchy on a tree page
|
||||||
"index" // on the index page
|
"index" // on the index page
|
||||||
);
|
);
|
||||||
|
@ -1,68 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2011, 2022, Oracle and/or its affiliates. All rights reserved.
|
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
||||||
*
|
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
|
||||||
* under the terms of the GNU General Public License version 2 only, as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
||||||
* version 2 for more details (a copy is included in the LICENSE file that
|
|
||||||
* accompanied this code).
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License version
|
|
||||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
||||||
*
|
|
||||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
||||||
* or visit www.oracle.com if you need additional information or have any
|
|
||||||
* questions.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* @test
|
|
||||||
* @bug 7010342 8150000 8174974
|
|
||||||
* @summary Test for correct sub title generation.
|
|
||||||
* @library ../../lib
|
|
||||||
* @modules jdk.javadoc/jdk.javadoc.internal.tool
|
|
||||||
* @build javadoc.tester.*
|
|
||||||
* @run main TestSubTitle
|
|
||||||
*/
|
|
||||||
|
|
||||||
import javadoc.tester.JavadocTester;
|
|
||||||
|
|
||||||
public class TestSubTitle extends JavadocTester {
|
|
||||||
|
|
||||||
public static void main(String... args) throws Exception {
|
|
||||||
var tester = new TestSubTitle();
|
|
||||||
tester.runTests();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
|
||||||
public void test() {
|
|
||||||
javadoc("-d", "out",
|
|
||||||
"-sourcepath", testSrc,
|
|
||||||
"pkg");
|
|
||||||
checkExit(Exit.OK);
|
|
||||||
|
|
||||||
checkOutput("pkg/package-summary.html", true,
|
|
||||||
"""
|
|
||||||
<div class="block">This is the description of package pkg.</div>""");
|
|
||||||
|
|
||||||
checkOutput("pkg/C.html", true,
|
|
||||||
"""
|
|
||||||
<div class="sub-title"><span class="package-label-in-type">Package</span> <\
|
|
||||||
a href="package-summary.html">pkg</a></div>""");
|
|
||||||
|
|
||||||
checkOutput("pkg/package-summary.html", false,
|
|
||||||
"""
|
|
||||||
<p class="sub-title">
|
|
||||||
<div class="block">This is the description of package pkg.</div>
|
|
||||||
</p>""");
|
|
||||||
|
|
||||||
checkOutput("pkg/C.html", false,
|
|
||||||
"<p class=\"sub-title\">pkg</p>");
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,30 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2011, Oracle and/or its affiliates. All rights reserved.
|
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
|
||||||
*
|
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
|
||||||
* under the terms of the GNU General Public License version 2 only, as
|
|
||||||
* published by the Free Software Foundation.
|
|
||||||
*
|
|
||||||
* This code is distributed in the hope that it will be useful, but WITHOUT
|
|
||||||
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
||||||
* version 2 for more details (a copy is included in the LICENSE file that
|
|
||||||
* accompanied this code).
|
|
||||||
*
|
|
||||||
* You should have received a copy of the GNU General Public License version
|
|
||||||
* 2 along with this work; if not, write to the Free Software Foundation,
|
|
||||||
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
||||||
*
|
|
||||||
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
|
||||||
* or visit www.oracle.com if you need additional information or have any
|
|
||||||
* questions.
|
|
||||||
*/
|
|
||||||
|
|
||||||
package pkg;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Source file for C
|
|
||||||
*/
|
|
||||||
public class C {
|
|
||||||
}
|
|
@ -1,8 +0,0 @@
|
|||||||
<html lang="en">
|
|
||||||
<head>
|
|
||||||
<title>Package Summary</title>
|
|
||||||
</head>
|
|
||||||
<body>
|
|
||||||
This is the description of package pkg.
|
|
||||||
</body>
|
|
||||||
</html>
|
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2018, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2018, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2002, 2021, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2002, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -329,6 +329,7 @@ public class LinkChecker extends HtmlChecker {
|
|||||||
|
|
||||||
IDTable(Path p) {
|
IDTable(Path p) {
|
||||||
this(relativePath(p).toString());
|
this(relativePath(p).toString());
|
||||||
|
addID(0, ""); // Register empty anchor as top of page
|
||||||
}
|
}
|
||||||
|
|
||||||
IDTable(String name) {
|
IDTable(String name) {
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2010, 2022, Oracle and/or its affiliates. All rights reserved.
|
* Copyright (c) 2010, 2024, Oracle and/or its affiliates. All rights reserved.
|
||||||
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
|
||||||
*
|
*
|
||||||
* This code is free software; you can redistribute it and/or modify it
|
* This code is free software; you can redistribute it and/or modify it
|
||||||
@ -205,15 +205,17 @@ public class CheckResourceKeys {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// special handling for strings in search.js.template
|
// special handling for strings in .js.template files
|
||||||
FileObject fo = fm.getFileForInput(javadocLoc,
|
for (String fileName : List.of("resources/search.js.template", "resources/script.js.template")) {
|
||||||
"jdk.javadoc.internal.doclets.formats.html",
|
FileObject fo = fm.getFileForInput(javadocLoc,
|
||||||
"resources/search.js.template");
|
"jdk.javadoc.internal.doclets.formats.html",
|
||||||
CharSequence search_js = fo.getCharContent(true);
|
fileName);
|
||||||
Pattern p = Pattern.compile("##REPLACE:(?<key>[A-Za-z0-9._]+)##");
|
CharSequence search_js = fo.getCharContent(true);
|
||||||
Matcher m = p.matcher(search_js);
|
Pattern p = Pattern.compile("##REPLACE:(?<key>[A-Za-z0-9._]+)##");
|
||||||
while (m.find()) {
|
Matcher m = p.matcher(search_js);
|
||||||
results.add(m.group("key"));
|
while (m.find()) {
|
||||||
|
results.add(m.group("key"));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// special handling for code strings synthesized in
|
// special handling for code strings synthesized in
|
||||||
|
Loading…
x
Reference in New Issue
Block a user