8338133: Cleanup direct use of new HtmlTree
Reviewed-by: hannesw
This commit is contained in:
parent
b895d7cf9f
commit
98020e4799
@ -109,7 +109,7 @@ public abstract class AbstractExecutableMemberWriter extends AbstractMemberWrite
|
|||||||
}
|
}
|
||||||
String signature = utils.flatSignature((ExecutableElement) member, typeElement);
|
String signature = utils.flatSignature((ExecutableElement) member, typeElement);
|
||||||
if (signature.length() > 2) {
|
if (signature.length() > 2) {
|
||||||
content.add(new HtmlTree(HtmlTag.WBR));
|
content.add(HtmlTree.WBR());
|
||||||
}
|
}
|
||||||
content.add(signature);
|
content.add(signature);
|
||||||
|
|
||||||
@ -144,7 +144,7 @@ public abstract class AbstractExecutableMemberWriter extends AbstractMemberWrite
|
|||||||
// Add explicit line break between method type parameters and
|
// Add explicit line break between method type parameters and
|
||||||
// return type in member summary table to avoid random wrapping.
|
// return type in member summary table to avoid random wrapping.
|
||||||
if (typeParameters.charCount() > 10) {
|
if (typeParameters.charCount() > 10) {
|
||||||
target.add(new HtmlTree(HtmlTag.BR));
|
target.add(HtmlTree.BR());
|
||||||
} else {
|
} else {
|
||||||
target.add(Entity.NO_BREAK_SPACE);
|
target.add(Entity.NO_BREAK_SPACE);
|
||||||
}
|
}
|
||||||
@ -233,7 +233,7 @@ public abstract class AbstractExecutableMemberWriter extends AbstractMemberWrite
|
|||||||
Content params = getParameters(member, false);
|
Content params = getParameters(member, false);
|
||||||
if (params.charCount() > 2) {
|
if (params.charCount() > 2) {
|
||||||
// only add <wbr> for non-empty parameters
|
// only add <wbr> for non-empty parameters
|
||||||
target.add(new HtmlTree(HtmlTag.WBR));
|
target.add(HtmlTree.WBR());
|
||||||
}
|
}
|
||||||
target.add(params);
|
target.add(params);
|
||||||
}
|
}
|
||||||
|
@ -451,7 +451,7 @@ public abstract class AbstractMemberWriter {
|
|||||||
*/
|
*/
|
||||||
protected void addModifiersAndType(Element member, TypeMirror type,
|
protected void addModifiersAndType(Element member, TypeMirror type,
|
||||||
Content target) {
|
Content target) {
|
||||||
var code = new HtmlTree(HtmlTag.CODE);
|
var code = HtmlTree.CODE();
|
||||||
addModifiers(member, code);
|
addModifiers(member, code);
|
||||||
if (type == null) {
|
if (type == null) {
|
||||||
code.add(switch (member.getKind()) {
|
code.add(switch (member.getKind()) {
|
||||||
@ -670,7 +670,7 @@ public abstract class AbstractMemberWriter {
|
|||||||
* @return the inherited summary links
|
* @return the inherited summary links
|
||||||
*/
|
*/
|
||||||
public Content getInheritedSummaryLinks() {
|
public Content getInheritedSummaryLinks() {
|
||||||
return new HtmlTree(HtmlTag.CODE);
|
return HtmlTree.CODE();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -79,10 +79,9 @@ public abstract class AbstractTreeWriter extends HtmlDocletWriter {
|
|||||||
protected void addLevelInfo(TypeElement parent, Collection<TypeElement> collection,
|
protected void addLevelInfo(TypeElement parent, Collection<TypeElement> collection,
|
||||||
Hierarchy hierarchy, Content content) {
|
Hierarchy hierarchy, Content content) {
|
||||||
if (!collection.isEmpty()) {
|
if (!collection.isEmpty()) {
|
||||||
var ul = new HtmlTree(HtmlTag.UL);
|
var ul = HtmlTree.UL();
|
||||||
for (TypeElement local : collection) {
|
for (TypeElement local : collection) {
|
||||||
var li = new HtmlTree(HtmlTag.LI);
|
var li = HtmlTree.LI(HtmlStyles.circle);
|
||||||
li.setStyle(HtmlStyles.circle);
|
|
||||||
addPartialInfo(local, li);
|
addPartialInfo(local, li);
|
||||||
addExtendsImplements(parent, local, li);
|
addExtendsImplements(parent, local, li);
|
||||||
addLevelInfo(local, hierarchy.subtypes(local), hierarchy, li); // Recurse
|
addLevelInfo(local, hierarchy.subtypes(local), hierarchy, li); // Recurse
|
||||||
|
@ -423,7 +423,7 @@ public class ClassUseWriter extends SubWriterHolderWriter {
|
|||||||
HtmlTree body = getBody(getWindowTitle(title));
|
HtmlTree body = getBody(getWindowTitle(title));
|
||||||
ContentBuilder headingContent = new ContentBuilder();
|
ContentBuilder headingContent = new ContentBuilder();
|
||||||
headingContent.add(contents.getContent("doclet.ClassUse_Title", cltype));
|
headingContent.add(contents.getContent("doclet.ClassUse_Title", cltype));
|
||||||
headingContent.add(new HtmlTree(HtmlTag.BR));
|
headingContent.add(HtmlTree.BR());
|
||||||
headingContent.add(clname);
|
headingContent.add(clname);
|
||||||
var heading = HtmlTree.HEADING_TITLE(Headings.PAGE_TITLE_HEADING,
|
var heading = HtmlTree.HEADING_TITLE(Headings.PAGE_TITLE_HEADING,
|
||||||
HtmlStyles.title, headingContent);
|
HtmlStyles.title, headingContent);
|
||||||
|
@ -165,7 +165,7 @@ public class ClassWriter extends SubWriterHolderWriter {
|
|||||||
buildInterfaceUsageInfo(c);
|
buildInterfaceUsageInfo(c);
|
||||||
buildNestedClassInfo(c);
|
buildNestedClassInfo(c);
|
||||||
buildFunctionalInterfaceInfo(c);
|
buildFunctionalInterfaceInfo(c);
|
||||||
c.add(new HtmlTree(HtmlTag.HR));
|
c.add(HtmlTree.HR());
|
||||||
var div = HtmlTree.DIV(HtmlStyles.horizontalScroll);
|
var div = HtmlTree.DIV(HtmlStyles.horizontalScroll);
|
||||||
buildClassSignature(div);
|
buildClassSignature(div);
|
||||||
buildDeprecationInfo(div);
|
buildDeprecationInfo(div);
|
||||||
@ -461,7 +461,7 @@ public class ClassWriter extends SubWriterHolderWriter {
|
|||||||
var first = true;
|
var first = true;
|
||||||
for (TypeParameterElement t : typeParams) {
|
for (TypeParameterElement t : typeParams) {
|
||||||
if (!first) {
|
if (!first) {
|
||||||
content.add(",").add(new HtmlTree(HtmlTag.WBR));
|
content.add(",").add(HtmlTree.WBR());
|
||||||
}
|
}
|
||||||
var typeParamLink = getLink(linkInfo.forType(t.asType()));
|
var typeParamLink = getLink(linkInfo.forType(t.asType()));
|
||||||
content.add(needsId
|
content.add(needsId
|
||||||
@ -689,11 +689,9 @@ public class ClassWriter extends SubWriterHolderWriter {
|
|||||||
|
|
||||||
protected void addFunctionalInterfaceInfo (Content target) {
|
protected void addFunctionalInterfaceInfo (Content target) {
|
||||||
if (utils.isFunctionalInterface(typeElement)) {
|
if (utils.isFunctionalInterface(typeElement)) {
|
||||||
var dl = HtmlTree.DL(HtmlStyles.notes);
|
var dl = HtmlTree.DL(HtmlStyles.notes)
|
||||||
dl.add(HtmlTree.DT(contents.functionalInterface));
|
.add(HtmlTree.DT(contents.functionalInterface))
|
||||||
var dd = new HtmlTree(HtmlTag.DD);
|
.add(HtmlTree.DD(contents.functionalInterfaceMessage));
|
||||||
dd.add(contents.functionalInterfaceMessage);
|
|
||||||
dl.add(dd);
|
|
||||||
target.add(dl);
|
target.add(dl);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -414,7 +414,7 @@ public class ConstantsSummaryWriter extends HtmlDocletWriter {
|
|||||||
*/
|
*/
|
||||||
private Content getTypeColumn(VariableElement member) {
|
private Content getTypeColumn(VariableElement member) {
|
||||||
Content typeContent = new ContentBuilder();
|
Content typeContent = new ContentBuilder();
|
||||||
var code = new HtmlTree(HtmlTag.CODE)
|
var code = HtmlTree.CODE()
|
||||||
.setId(htmlIds.forMember(currentTypeElement, member));
|
.setId(htmlIds.forMember(currentTypeElement, member));
|
||||||
for (Modifier mod : member.getModifiers()) {
|
for (Modifier mod : member.getModifiers()) {
|
||||||
code.add(Text.of(mod.toString()))
|
code.add(Text.of(mod.toString()))
|
||||||
|
@ -300,7 +300,7 @@ public class ConstructorWriter extends AbstractExecutableMemberWriter {
|
|||||||
@Override
|
@Override
|
||||||
protected void addSummaryType(Element member, Content content) {
|
protected void addSummaryType(Element member, Content content) {
|
||||||
if (threeColumnSummary()) {
|
if (threeColumnSummary()) {
|
||||||
var code = new HtmlTree(HtmlTag.CODE);
|
var code = HtmlTree.CODE();
|
||||||
if (utils.isProtected(member)) {
|
if (utils.isProtected(member)) {
|
||||||
code.add("protected ");
|
code.add("protected ");
|
||||||
} else if (utils.isPrivate(member)) {
|
} else if (utils.isPrivate(member)) {
|
||||||
|
@ -105,11 +105,11 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
tableOfContents.addLink(HtmlIds.TOP_OF_PAGE, mainHeading);
|
tableOfContents.addLink(HtmlIds.TOP_OF_PAGE, mainHeading);
|
||||||
tableOfContents.pushNestedList();
|
tableOfContents.pushNestedList();
|
||||||
content.add(HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, HtmlStyles.title, mainHeading))
|
content.add(HtmlTree.HEADING(Headings.PAGE_TITLE_HEADING, HtmlStyles.title, mainHeading))
|
||||||
.add(new HtmlTree(HtmlTag.HR))
|
.add(HtmlTree.HR())
|
||||||
.add(getNavigationSection())
|
.add(getNavigationSection())
|
||||||
.add(new HtmlTree(HtmlTag.HR))
|
.add(HtmlTree.HR())
|
||||||
.add(getPageKindSection())
|
.add(getPageKindSection())
|
||||||
.add(new HtmlTree(HtmlTag.HR))
|
.add(HtmlTree.HR())
|
||||||
.add(HtmlTree.SPAN(HtmlStyles.helpFootnote,
|
.add(HtmlTree.SPAN(HtmlStyles.helpFootnote,
|
||||||
getContent("doclet.help.footnote")));
|
getContent("doclet.help.footnote")));
|
||||||
tableOfContents.popNestedList();
|
tableOfContents.popNestedList();
|
||||||
@ -255,7 +255,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
getContent("doclet.help.class_interface.implementations"),
|
getContent("doclet.help.class_interface.implementations"),
|
||||||
getContent("doclet.help.class_interface.declaration"),
|
getContent("doclet.help.class_interface.declaration"),
|
||||||
getContent("doclet.help.class_interface.description")))
|
getContent("doclet.help.class_interface.description")))
|
||||||
.add(new HtmlTree(HtmlTag.BR))
|
.add(HtmlTree.BR())
|
||||||
.add(newHelpSectionList(
|
.add(newHelpSectionList(
|
||||||
contents.nestedClassSummary,
|
contents.nestedClassSummary,
|
||||||
contents.enumConstantSummary,
|
contents.enumConstantSummary,
|
||||||
@ -265,7 +265,7 @@ public class HelpWriter extends HtmlDocletWriter {
|
|||||||
contents.methodSummary,
|
contents.methodSummary,
|
||||||
contents.annotateTypeRequiredMemberSummaryLabel,
|
contents.annotateTypeRequiredMemberSummaryLabel,
|
||||||
contents.annotateTypeOptionalMemberSummaryLabel))
|
contents.annotateTypeOptionalMemberSummaryLabel))
|
||||||
.add(new HtmlTree(HtmlTag.BR))
|
.add(HtmlTree.BR())
|
||||||
.add(newHelpSectionList(
|
.add(newHelpSectionList(
|
||||||
contents.enumConstantDetailLabel,
|
contents.enumConstantDetailLabel,
|
||||||
contents.fieldDetailsLabel,
|
contents.fieldDetailsLabel,
|
||||||
|
@ -685,7 +685,7 @@ public abstract class HtmlDocletWriter {
|
|||||||
return (bottom == null || bottom.isEmpty())
|
return (bottom == null || bottom.isEmpty())
|
||||||
? null
|
? null
|
||||||
: HtmlTree.FOOTER()
|
: HtmlTree.FOOTER()
|
||||||
.add(new HtmlTree(HtmlTag.HR))
|
.add(HtmlTree.HR())
|
||||||
.add(HtmlTree.P(HtmlStyles.legalCopy,
|
.add(HtmlTree.P(HtmlStyles.legalCopy,
|
||||||
HtmlTree.SMALL(
|
HtmlTree.SMALL(
|
||||||
RawHtml.of(replaceDocRootDir(bottom)))));
|
RawHtml.of(replaceDocRootDir(bottom)))));
|
||||||
@ -2405,7 +2405,7 @@ public abstract class HtmlDocletWriter {
|
|||||||
* @return an HtmlTree for the BODY tag
|
* @return an HtmlTree for the BODY tag
|
||||||
*/
|
*/
|
||||||
public HtmlTree getBody(String title) {
|
public HtmlTree getBody(String title) {
|
||||||
var body = new HtmlTree(HtmlTag.BODY).setStyle(getBodyStyle());
|
var body = HtmlTree.BODY(getBodyStyle());
|
||||||
|
|
||||||
this.winTitle = title;
|
this.winTitle = title;
|
||||||
// Don't print windowtitle script for overview-frame, allclasses-frame
|
// Don't print windowtitle script for overview-frame, allclasses-frame
|
||||||
@ -2601,7 +2601,7 @@ public abstract class HtmlDocletWriter {
|
|||||||
});
|
});
|
||||||
return contents.getContent(key,
|
return contents.getContent(key,
|
||||||
HtmlTree.CODE(Text.of(className)),
|
HtmlTree.CODE(Text.of(className)),
|
||||||
new HtmlTree(HtmlTag.EM).add(featureName),
|
HtmlTree.EM(featureName),
|
||||||
featureCodes);
|
featureCodes);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -395,14 +395,14 @@ public class HtmlLinkFactory {
|
|||||||
}
|
}
|
||||||
if (!vars.isEmpty()) {
|
if (!vars.isEmpty()) {
|
||||||
if (linkInfo.addLineBreakOpportunitiesInTypeParameters()) {
|
if (linkInfo.addLineBreakOpportunitiesInTypeParameters()) {
|
||||||
links.add(new HtmlTree(HtmlTag.WBR));
|
links.add(HtmlTree.WBR());
|
||||||
}
|
}
|
||||||
links.add("<");
|
links.add("<");
|
||||||
boolean many = false;
|
boolean many = false;
|
||||||
for (TypeMirror t : vars) {
|
for (TypeMirror t : vars) {
|
||||||
if (many) {
|
if (many) {
|
||||||
links.add(",");
|
links.add(",");
|
||||||
links.add(new HtmlTree(HtmlTag.WBR));
|
links.add(HtmlTree.WBR());
|
||||||
if (linkInfo.addLineBreaksInTypeParameters()) {
|
if (linkInfo.addLineBreaksInTypeParameters()) {
|
||||||
links.add(Text.NL);
|
links.add(Text.NL);
|
||||||
}
|
}
|
||||||
|
@ -92,7 +92,7 @@ public class IndexRedirectWriter extends HtmlDocletWriter {
|
|||||||
Script script = new Script("window.location.replace(")
|
Script script = new Script("window.location.replace(")
|
||||||
.appendStringLiteral(targetPath, '\'')
|
.appendStringLiteral(targetPath, '\'')
|
||||||
.append(")");
|
.append(")");
|
||||||
var metaRefresh = new HtmlTree(HtmlTag.META)
|
var metaRefresh = HtmlTree.of(HtmlTag.META)
|
||||||
.put(HtmlAttr.HTTP_EQUIV, "Refresh")
|
.put(HtmlAttr.HTTP_EQUIV, "Refresh")
|
||||||
.put(HtmlAttr.CONTENT, "0;" + targetPath);
|
.put(HtmlAttr.CONTENT, "0;" + targetPath);
|
||||||
head.addContent(script.asContent(), HtmlTree.NOSCRIPT(metaRefresh));
|
head.addContent(script.asContent(), HtmlTree.NOSCRIPT(metaRefresh));
|
||||||
@ -103,9 +103,8 @@ public class IndexRedirectWriter extends HtmlDocletWriter {
|
|||||||
|
|
||||||
bodyContent.add(HtmlTree.P(HtmlTree.A(targetPath, Text.of(targetPath))));
|
bodyContent.add(HtmlTree.P(HtmlTree.A(targetPath, Text.of(targetPath))));
|
||||||
|
|
||||||
var body = new HtmlTree(HtmlTag.BODY).setStyle(HtmlStyles.indexRedirectPage);
|
var body = HtmlTree.BODY(HtmlStyles.indexRedirectPage)
|
||||||
var main = HtmlTree.MAIN(bodyContent);
|
.add(HtmlTree.MAIN(bodyContent));
|
||||||
body.add(main);
|
|
||||||
|
|
||||||
HtmlDocument htmlDocument = new HtmlDocument(
|
HtmlDocument htmlDocument = new HtmlDocument(
|
||||||
HtmlTree.HTML(configuration.getLocale().getLanguage(), head, body));
|
HtmlTree.HTML(configuration.getLocale().getLanguage(), head, body));
|
||||||
|
@ -224,7 +224,7 @@ public class IndexWriter extends HtmlDocletWriter {
|
|||||||
default -> throw new Error();
|
default -> throw new Error();
|
||||||
}
|
}
|
||||||
target.add(dt);
|
target.add(dt);
|
||||||
var dd = new HtmlTree(HtmlTag.DD);
|
var dd = HtmlTree.DD();
|
||||||
if (element.getKind() == ElementKind.MODULE || element.getKind() == ElementKind.PACKAGE) {
|
if (element.getKind() == ElementKind.MODULE || element.getKind() == ElementKind.PACKAGE) {
|
||||||
addSummaryComment(element, dd);
|
addSummaryComment(element, dd);
|
||||||
} else {
|
} else {
|
||||||
@ -261,7 +261,7 @@ public class IndexWriter extends HtmlDocletWriter {
|
|||||||
dt.add(" - ");
|
dt.add(" - ");
|
||||||
dt.add(contents.getContent("doclet.Search_tag_in", item.getHolder()));
|
dt.add(contents.getContent("doclet.Search_tag_in", item.getHolder()));
|
||||||
target.add(dt);
|
target.add(dt);
|
||||||
var dd = new HtmlTree(HtmlTag.DD);
|
var dd = HtmlTree.DD();
|
||||||
if (item.getDescription().isEmpty()) {
|
if (item.getDescription().isEmpty()) {
|
||||||
dd.add(Entity.NO_BREAK_SPACE);
|
dd.add(Entity.NO_BREAK_SPACE);
|
||||||
} else {
|
} else {
|
||||||
@ -348,7 +348,7 @@ public class IndexWriter extends HtmlDocletWriter {
|
|||||||
content.add(Entity.NO_BREAK_SPACE);
|
content.add(Entity.NO_BREAK_SPACE);
|
||||||
}
|
}
|
||||||
|
|
||||||
content.add(new HtmlTree(HtmlTag.BR));
|
content.add(HtmlTree.BR());
|
||||||
var 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()))
|
||||||
|
@ -194,7 +194,7 @@ public class ModuleWriter extends HtmlDocletWriter {
|
|||||||
*/
|
*/
|
||||||
protected void buildContent() {
|
protected void buildContent() {
|
||||||
Content moduleContent = getContentHeader();
|
Content moduleContent = getContentHeader();
|
||||||
moduleContent.add(new HtmlTree(HtmlTag.HR));
|
moduleContent.add(HtmlTree.HR());
|
||||||
Content div = HtmlTree.DIV(HtmlStyles.horizontalScroll);
|
Content div = HtmlTree.DIV(HtmlStyles.horizontalScroll);
|
||||||
addModuleSignature(div);
|
addModuleSignature(div);
|
||||||
buildModuleDescription(div);
|
buildModuleDescription(div);
|
||||||
@ -825,7 +825,7 @@ public class ModuleWriter extends HtmlDocletWriter {
|
|||||||
}
|
}
|
||||||
// Only display the implementation details in the "all" mode.
|
// Only display the implementation details in the "all" mode.
|
||||||
if (moduleMode == ModuleMode.ALL && !implSet.isEmpty()) {
|
if (moduleMode == ModuleMode.ALL && !implSet.isEmpty()) {
|
||||||
desc.add(new HtmlTree(HtmlTag.BR));
|
desc.add(HtmlTree.BR());
|
||||||
desc.add("(");
|
desc.add("(");
|
||||||
var implSpan = HtmlTree.SPAN(HtmlStyles.implementationLabel, contents.implementation);
|
var implSpan = HtmlTree.SPAN(HtmlStyles.implementationLabel, contents.implementation);
|
||||||
desc.add(implSpan);
|
desc.add(implSpan);
|
||||||
|
@ -516,14 +516,14 @@ public class Navigation {
|
|||||||
}
|
}
|
||||||
var navigationBar = HtmlTree.NAV();
|
var navigationBar = HtmlTree.NAV();
|
||||||
|
|
||||||
var navContent = new HtmlTree(HtmlTag.DIV);
|
var navContent = HtmlTree.DIV(HtmlStyles.navContent);
|
||||||
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(HtmlStyles.navBarToggleIcon).add(Entity.NO_BREAK_SPACE);
|
HtmlTree iconSpan = HtmlTree.SPAN(HtmlStyles.navBarToggleIcon).add(Entity.NO_BREAK_SPACE);
|
||||||
navContent.setStyle(HtmlStyles.navContent).add(HtmlTree.DIV(HtmlStyles.navMenuButton,
|
navContent.add(HtmlTree.DIV(HtmlStyles.navMenuButton,
|
||||||
new HtmlTree(HtmlTag.BUTTON).setId(HtmlIds.NAVBAR_TOGGLE_BUTTON)
|
HtmlTree.BUTTON(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)
|
||||||
@ -535,9 +535,7 @@ public class Navigation {
|
|||||||
skipNavLinks.toString())));
|
skipNavLinks.toString())));
|
||||||
Content aboutContent = userHeader;
|
Content aboutContent = userHeader;
|
||||||
|
|
||||||
var navList = new HtmlTree(HtmlTag.UL)
|
var navList = HtmlTree.UL(HtmlIds.NAVBAR_TOP_FIRSTROW, HtmlStyles.navList)
|
||||||
.setId(HtmlIds.NAVBAR_TOP_FIRSTROW)
|
|
||||||
.setStyle(HtmlStyles.navList)
|
|
||||||
.put(HtmlAttr.TITLE, rowListTitle);
|
.put(HtmlAttr.TITLE, rowListTitle);
|
||||||
addMainNavLinks(navList);
|
addMainNavLinks(navList);
|
||||||
navContent.add(navList);
|
navContent.add(navList);
|
||||||
|
@ -204,7 +204,7 @@ public class PackageUseWriter extends SubWriterHolderWriter {
|
|||||||
HtmlTree body = getBody(getWindowTitle(title));
|
HtmlTree body = getBody(getWindowTitle(title));
|
||||||
ContentBuilder headingContent = new ContentBuilder();
|
ContentBuilder headingContent = new ContentBuilder();
|
||||||
headingContent.add(contents.getContent("doclet.ClassUse_Title", packageText));
|
headingContent.add(contents.getContent("doclet.ClassUse_Title", packageText));
|
||||||
headingContent.add(new HtmlTree(HtmlTag.BR));
|
headingContent.add(HtmlTree.BR());
|
||||||
headingContent.add(name);
|
headingContent.add(name);
|
||||||
var heading = HtmlTree.HEADING_TITLE(Headings.PAGE_TITLE_HEADING,
|
var heading = HtmlTree.HEADING_TITLE(Headings.PAGE_TITLE_HEADING,
|
||||||
HtmlStyles.title, headingContent);
|
HtmlStyles.title, headingContent);
|
||||||
|
@ -128,7 +128,7 @@ public class PackageWriter extends HtmlDocletWriter {
|
|||||||
*/
|
*/
|
||||||
protected void buildContent() {
|
protected void buildContent() {
|
||||||
Content packageContent = getContentHeader();
|
Content packageContent = getContentHeader();
|
||||||
packageContent.add(new HtmlTree(HtmlTag.HR));
|
packageContent.add(HtmlTree.HR());
|
||||||
Content div = HtmlTree.DIV(HtmlStyles.horizontalScroll);
|
Content div = HtmlTree.DIV(HtmlStyles.horizontalScroll);
|
||||||
addPackageSignature(div);
|
addPackageSignature(div);
|
||||||
buildPackageDescription(div);
|
buildPackageDescription(div);
|
||||||
|
@ -97,24 +97,21 @@ public class SearchWriter extends HtmlDocletWriter {
|
|||||||
.add(HtmlTree.P(contents.getContent("doclet.search.browser_info")))
|
.add(HtmlTree.P(contents.getContent("doclet.search.browser_info")))
|
||||||
.add(HtmlTree.SPAN(Text.of("link"))
|
.add(HtmlTree.SPAN(Text.of("link"))
|
||||||
.setId(HtmlId.of("page-search-link")))
|
.setId(HtmlId.of("page-search-link")))
|
||||||
.add(new HtmlTree(HtmlTag.BUTTON)
|
.add(HtmlTree.BUTTON(HtmlId.of("page-search-copy"))
|
||||||
.add(new HtmlTree(HtmlTag.IMG)
|
.add(HtmlTree.of(HtmlTag.IMG)
|
||||||
.put(HtmlAttr.SRC, pathToRoot.resolve(DocPaths.RESOURCE_FILES)
|
.put(HtmlAttr.SRC, pathToRoot.resolve(DocPaths.RESOURCE_FILES)
|
||||||
.resolve(DocPaths.CLIPBOARD_SVG).getPath())
|
.resolve(DocPaths.CLIPBOARD_SVG).getPath())
|
||||||
.put(HtmlAttr.ALT, copyUrlText))
|
.put(HtmlAttr.ALT, copyUrlText))
|
||||||
.add(HtmlTree.SPAN(Text.of(copyText))
|
.add(HtmlTree.SPAN(Text.of(copyText))
|
||||||
.put(HtmlAttr.DATA_COPIED, copiedText))
|
.put(HtmlAttr.DATA_COPIED, copiedText))
|
||||||
.addStyle(HtmlStyles.copy)
|
.addStyle(HtmlStyles.copy)
|
||||||
.put(HtmlAttr.ARIA_LABEL, copyUrlText)
|
.put(HtmlAttr.ARIA_LABEL, copyUrlText))
|
||||||
.setId(HtmlId.of("page-search-copy")))
|
|
||||||
.add(HtmlTree.P(HtmlTree.INPUT(HtmlAttr.InputType.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(HtmlTag.P)
|
.add(HtmlTree.P(contents.getContent("doclet.search.loading"))
|
||||||
.setId(HtmlId.of("page-search-notify"))
|
.setId(HtmlId.of("page-search-notify")))
|
||||||
.add(contents.getContent("doclet.search.loading")))
|
.add(HtmlTree.DIV(HtmlTree.DIV(HtmlId.of("result-container"))
|
||||||
.add(HtmlTree.DIV(new HtmlTree(HtmlTag.DIV)
|
|
||||||
.setId(HtmlId.of("result-container"))
|
|
||||||
.addUnchecked(Text.EMPTY))
|
.addUnchecked(Text.EMPTY))
|
||||||
.setId(HtmlId.of("result-section"))
|
.setId(HtmlId.of("result-section"))
|
||||||
.put(HtmlAttr.STYLE, "display: none;")
|
.put(HtmlAttr.STYLE, "display: none;")
|
||||||
|
@ -58,7 +58,7 @@ public class SerialFieldWriter extends FieldWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected Content getFieldsContentHeader() {
|
protected Content getFieldsContentHeader() {
|
||||||
return new HtmlTree(HtmlTag.LI).setStyle(HtmlStyles.blockList);
|
return HtmlTree.LI(HtmlStyles.blockList);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected Content getSerializableFields(String heading, Content source) {
|
protected Content getSerializableFields(String heading, Content source) {
|
||||||
@ -76,12 +76,12 @@ public class SerialFieldWriter extends FieldWriter {
|
|||||||
Content nameContent = Text.of(fieldName);
|
Content nameContent = Text.of(fieldName);
|
||||||
var heading = HtmlTree.HEADING(Headings.SerializedForm.MEMBER_HEADING, nameContent);
|
var heading = HtmlTree.HEADING(Headings.SerializedForm.MEMBER_HEADING, nameContent);
|
||||||
content.add(heading);
|
content.add(heading);
|
||||||
var pre = new HtmlTree(HtmlTag.PRE);
|
|
||||||
Content fieldContent = writer.getLink(new HtmlLinkInfo(
|
Content fieldContent = writer.getLink(new HtmlLinkInfo(
|
||||||
configuration, HtmlLinkInfo.Kind.LINK_TYPE_PARAMS_AND_BOUNDS, fieldType));
|
configuration, HtmlLinkInfo.Kind.LINK_TYPE_PARAMS_AND_BOUNDS, fieldType));
|
||||||
pre.add(fieldContent);
|
var pre = HtmlTree.PRE()
|
||||||
pre.add(" ");
|
.add(fieldContent)
|
||||||
pre.add(fieldName);
|
.add(" ")
|
||||||
|
.add(fieldName);
|
||||||
content.add(pre);
|
content.add(pre);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,7 +51,7 @@ public class SerialMethodWriter extends MethodWriter {
|
|||||||
}
|
}
|
||||||
|
|
||||||
protected Content getMethodsContentHeader() {
|
protected Content getMethodsContentHeader() {
|
||||||
return new HtmlTree(HtmlTag.LI);
|
return HtmlTree.LI();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -569,7 +569,7 @@ public class Signatures {
|
|||||||
// empty parameters are added without packing
|
// empty parameters are added without packing
|
||||||
target.add(parameters);
|
target.add(parameters);
|
||||||
} else {
|
} else {
|
||||||
target.add(new HtmlTree(HtmlTag.WBR))
|
target.add(HtmlTree.WBR())
|
||||||
.add(HtmlTree.SPAN(HtmlStyles.parameters, parameters));
|
.add(HtmlTree.SPAN(HtmlStyles.parameters, parameters));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -201,7 +201,7 @@ public class SourceToHTMLConverter {
|
|||||||
.resolve(configuration.docPaths.forPackage(te))
|
.resolve(configuration.docPaths.forPackage(te))
|
||||||
.invert();
|
.invert();
|
||||||
Content body = getHeader();
|
Content body = getHeader();
|
||||||
var pre = new HtmlTree(HtmlTag.PRE);
|
var pre = HtmlTree.PRE();
|
||||||
try (var reader = new LineNumberReader(r)) {
|
try (var reader = new LineNumberReader(r)) {
|
||||||
while ((line = reader.readLine()) != null) {
|
while ((line = reader.readLine()) != null) {
|
||||||
addLineNo(pre, lineno);
|
addLineNo(pre, lineno);
|
||||||
@ -246,7 +246,7 @@ public class SourceToHTMLConverter {
|
|||||||
* @return the header content for the HTML file
|
* @return the header content for the HTML file
|
||||||
*/
|
*/
|
||||||
private static Content getHeader() {
|
private static Content getHeader() {
|
||||||
return new HtmlTree(HtmlTag.BODY).setStyle(HtmlStyles.sourcePage);
|
return HtmlTree.BODY(HtmlStyles.sourcePage);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -361,7 +361,7 @@ public class Table<T> extends Content {
|
|||||||
private Content toContent() {
|
private Content toContent() {
|
||||||
Content main;
|
Content main;
|
||||||
if (id != null) {
|
if (id != null) {
|
||||||
main = new HtmlTree(HtmlTag.DIV).setId(id);
|
main = HtmlTree.DIV(id);
|
||||||
} else {
|
} else {
|
||||||
main = new ContentBuilder();
|
main = new ContentBuilder();
|
||||||
}
|
}
|
||||||
@ -403,8 +403,7 @@ public class Table<T> extends Content {
|
|||||||
if (id == null) {
|
if (id == null) {
|
||||||
throw new IllegalStateException("no id set for table");
|
throw new IllegalStateException("no id set for table");
|
||||||
}
|
}
|
||||||
var tabpanel = new HtmlTree(HtmlTag.DIV)
|
var tabpanel = HtmlTree.DIV(HtmlIds.forTabPanel(id))
|
||||||
.setId(HtmlIds.forTabPanel(id))
|
|
||||||
.put(HtmlAttr.ROLE, "tabpanel")
|
.put(HtmlAttr.ROLE, "tabpanel")
|
||||||
.put(HtmlAttr.ARIA_LABELLEDBY, defaultTabId.name());
|
.put(HtmlAttr.ARIA_LABELLEDBY, defaultTabId.name());
|
||||||
table.add(getTableBody());
|
table.add(getTableBody());
|
||||||
@ -416,8 +415,7 @@ public class Table<T> extends Content {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private HtmlTree createTab(HtmlId tabId, HtmlStyle style, boolean defaultTab, Content tabLabel) {
|
private HtmlTree createTab(HtmlId tabId, HtmlStyle style, boolean defaultTab, Content tabLabel) {
|
||||||
var tab = new HtmlTree(HtmlTag.BUTTON)
|
var tab = HtmlTree.BUTTON(tabId)
|
||||||
.setId(tabId)
|
|
||||||
.put(HtmlAttr.ROLE, "tab")
|
.put(HtmlAttr.ROLE, "tab")
|
||||||
.put(HtmlAttr.ARIA_SELECTED, defaultTab ? "true" : "false")
|
.put(HtmlAttr.ARIA_SELECTED, defaultTab ? "true" : "false")
|
||||||
.put(HtmlAttr.ARIA_CONTROLS, HtmlIds.forTabPanel(id).name())
|
.put(HtmlAttr.ARIA_CONTROLS, HtmlIds.forTabPanel(id).name())
|
||||||
|
@ -101,10 +101,10 @@ public class TableOfContents {
|
|||||||
.put(HtmlAttr.VALUE, writer.resources.getText("doclet.filter_reset")));
|
.put(HtmlAttr.VALUE, writer.resources.getText("doclet.filter_reset")));
|
||||||
}
|
}
|
||||||
content.add(header);
|
content.add(header);
|
||||||
content.add(new HtmlTree(HtmlTag.BUTTON).addStyle(HtmlStyles.hideSidebar)
|
content.add(HtmlTree.BUTTON(HtmlStyles.hideSidebar)
|
||||||
.add(HtmlTree.SPAN(writer.contents.hideSidebar).add(Entity.NO_BREAK_SPACE))
|
.add(HtmlTree.SPAN(writer.contents.hideSidebar).add(Entity.NO_BREAK_SPACE))
|
||||||
.add(Entity.LEFT_POINTING_ANGLE));
|
.add(Entity.LEFT_POINTING_ANGLE));
|
||||||
content.add(new HtmlTree(HtmlTag.BUTTON).addStyle(HtmlStyles.showSidebar)
|
content.add(HtmlTree.BUTTON(HtmlStyles.showSidebar)
|
||||||
.add(Entity.RIGHT_POINTING_ANGLE)
|
.add(Entity.RIGHT_POINTING_ANGLE)
|
||||||
.add(HtmlTree.SPAN(Entity.NO_BREAK_SPACE).add(writer.contents.showSidebar)));
|
.add(HtmlTree.SPAN(Entity.NO_BREAK_SPACE).add(writer.contents.showSidebar)));
|
||||||
return content.add(listBuilder);
|
return content.add(listBuilder);
|
||||||
|
@ -272,9 +272,9 @@ public class Head extends Content {
|
|||||||
* @return the HTML
|
* @return the HTML
|
||||||
*/
|
*/
|
||||||
private Content toContent() {
|
private Content toContent() {
|
||||||
var head = new HtmlTree(HtmlTag.HEAD);
|
var head = HtmlTree.of(HtmlTag.HEAD)
|
||||||
head.add(getGeneratedBy(showTimestamp, generatedDate));
|
.add(getGeneratedBy(showTimestamp, generatedDate))
|
||||||
head.add(HtmlTree.TITLE(title));
|
.add(HtmlTree.TITLE(title));
|
||||||
|
|
||||||
head.add(HtmlTree.META("viewport", "width=device-width, initial-scale=1"));
|
head.add(HtmlTree.META("viewport", "width=device-width, initial-scale=1"));
|
||||||
|
|
||||||
@ -300,9 +300,9 @@ public class Head extends Content {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (canonicalLink != null) {
|
if (canonicalLink != null) {
|
||||||
var link = new HtmlTree(HtmlTag.LINK);
|
var link = HtmlTree.of(HtmlTag.LINK)
|
||||||
link.put(HtmlAttr.REL, "canonical");
|
.put(HtmlAttr.REL, "canonical")
|
||||||
link.put(HtmlAttr.HREF, canonicalLink.getPath());
|
.put(HtmlAttr.HREF, canonicalLink.getPath());
|
||||||
head.add(link);
|
head.add(link);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -122,13 +122,13 @@ public class SnippetTaglet extends BaseTaglet {
|
|||||||
private Content snippetTagOutput(Element element, SnippetTree tag, StyledText content,
|
private Content snippetTagOutput(Element element, SnippetTree tag, StyledText content,
|
||||||
String id, String lang) {
|
String id, String lang) {
|
||||||
var pathToRoot = tagletWriter.htmlWriter.pathToRoot;
|
var pathToRoot = tagletWriter.htmlWriter.pathToRoot;
|
||||||
var pre = new HtmlTree(HtmlTag.PRE).setStyle(HtmlStyles.snippet);
|
var pre = HtmlTree.PRE(HtmlStyles.snippet);
|
||||||
if (id != null && !id.isBlank()) {
|
if (id != null && !id.isBlank()) {
|
||||||
pre.put(HtmlAttr.ID, id);
|
pre.put(HtmlAttr.ID, id);
|
||||||
} else {
|
} else {
|
||||||
pre.put(HtmlAttr.ID, config.htmlIds.forSnippet(element, ids).name());
|
pre.put(HtmlAttr.ID, config.htmlIds.forSnippet(element, ids).name());
|
||||||
}
|
}
|
||||||
var code = new HtmlTree(HtmlTag.CODE)
|
var code = HtmlTree.CODE()
|
||||||
.addUnchecked(Text.EMPTY); // Make sure the element is always rendered
|
.addUnchecked(Text.EMPTY); // Make sure the element is always rendered
|
||||||
if (lang != null && !lang.isBlank()) {
|
if (lang != null && !lang.isBlank()) {
|
||||||
code.addStyle("language-" + lang);
|
code.addStyle("language-" + lang);
|
||||||
@ -197,10 +197,10 @@ public class SnippetTaglet extends BaseTaglet {
|
|||||||
String copiedText = resources.getText("doclet.Copied_to_clipboard");
|
String copiedText = resources.getText("doclet.Copied_to_clipboard");
|
||||||
String copySnippetText = resources.getText("doclet.Copy_snippet_to_clipboard");
|
String copySnippetText = resources.getText("doclet.Copy_snippet_to_clipboard");
|
||||||
var snippetContainer = HtmlTree.DIV(HtmlStyles.snippetContainer,
|
var snippetContainer = HtmlTree.DIV(HtmlStyles.snippetContainer,
|
||||||
new HtmlTree(HtmlTag.BUTTON)
|
HtmlTree.of(HtmlTag.BUTTON)
|
||||||
.add(HtmlTree.SPAN(Text.of(copyText))
|
.add(HtmlTree.SPAN(Text.of(copyText))
|
||||||
.put(HtmlAttr.DATA_COPIED, copiedText))
|
.put(HtmlAttr.DATA_COPIED, copiedText))
|
||||||
.add(new HtmlTree(HtmlTag.IMG)
|
.add(HtmlTree.of(HtmlTag.IMG)
|
||||||
.put(HtmlAttr.SRC, pathToRoot.resolve(DocPaths.RESOURCE_FILES)
|
.put(HtmlAttr.SRC, pathToRoot.resolve(DocPaths.RESOURCE_FILES)
|
||||||
.resolve(DocPaths.CLIPBOARD_SVG).getPath())
|
.resolve(DocPaths.CLIPBOARD_SVG).getPath())
|
||||||
.put(HtmlAttr.ALT, copySnippetText))
|
.put(HtmlAttr.ALT, copySnippetText))
|
||||||
|
@ -83,7 +83,17 @@ public class HtmlTree extends Content {
|
|||||||
*
|
*
|
||||||
* @param tag the name
|
* @param tag the name
|
||||||
*/
|
*/
|
||||||
public HtmlTree(HtmlTag tag) {
|
public static HtmlTree of(HtmlTag tag) {
|
||||||
|
return new HtmlTree(tag);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an {@code HTMLTree} object representing an HTML element
|
||||||
|
* with the given name.
|
||||||
|
*
|
||||||
|
* @param tag the name
|
||||||
|
*/
|
||||||
|
HtmlTree(HtmlTag tag) {
|
||||||
this.tag = Objects.requireNonNull(tag);
|
this.tag = Objects.requireNonNull(tag);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -365,6 +375,46 @@ public class HtmlTree extends Content {
|
|||||||
.add(body);
|
.add(body);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an HTML {@code BODY} element with the given style.
|
||||||
|
*
|
||||||
|
* @param style the style
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree BODY(HtmlStyle style) {
|
||||||
|
return new HtmlTree(HtmlTag.BODY)
|
||||||
|
.setStyle(style);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static final HtmlTree BR_INSTANCE = unmodifiableTree(HtmlTag.BR);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@return an HTML {@code BR} element}
|
||||||
|
*/
|
||||||
|
public static HtmlTree BR() {
|
||||||
|
return BR_INSTANCE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an HTML {@code BUTTON} element with the given id.
|
||||||
|
*
|
||||||
|
* @param id the id
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree BUTTON(HtmlId id) {
|
||||||
|
return new HtmlTree(HtmlTag.BUTTON).setId(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an HTML {@code BUTTON} element with the given style.
|
||||||
|
*
|
||||||
|
* @param style the style
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree BUTTON(HtmlStyle style) {
|
||||||
|
return new HtmlTree(HtmlTag.BUTTON).setStyle(style);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code CAPTION} element with the given content.
|
* Creates an HTML {@code CAPTION} element with the given content.
|
||||||
*
|
*
|
||||||
@ -376,6 +426,15 @@ public class HtmlTree extends Content {
|
|||||||
.add(body);
|
.add(body);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an empty HTML {@code CODE} element.
|
||||||
|
*
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree CODE() {
|
||||||
|
return new HtmlTree(HtmlTag.CODE);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code CODE} element with the given content.
|
* Creates an HTML {@code CODE} element with the given content.
|
||||||
*
|
*
|
||||||
@ -387,6 +446,15 @@ public class HtmlTree extends Content {
|
|||||||
.add(body);
|
.add(body);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an empty HTML {@code DD} element.
|
||||||
|
*
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree DD() {
|
||||||
|
return new HtmlTree(HtmlTag.DD);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code DD} element with the given content.
|
* Creates an HTML {@code DD} element with the given content.
|
||||||
*
|
*
|
||||||
@ -418,27 +486,14 @@ public class HtmlTree extends Content {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code DL} element with the given style.
|
* Creates an HTML {@code DIV} element with the given id.
|
||||||
*
|
*
|
||||||
* @param style the style
|
* @param id the id
|
||||||
* @return the element
|
* @return the element
|
||||||
*/
|
*/
|
||||||
public static HtmlTree DL(HtmlStyle style) {
|
public static HtmlTree DIV(HtmlId id) {
|
||||||
return new HtmlTree(HtmlTag.DL)
|
return new HtmlTree(HtmlTag.DIV)
|
||||||
.setStyle(style);
|
.setId(id);
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates an HTML {@code DL} element with the given style and content.
|
|
||||||
*
|
|
||||||
* @param style the style
|
|
||||||
* @param body the content
|
|
||||||
* @return the element
|
|
||||||
*/
|
|
||||||
public static HtmlTree DL(HtmlStyle style, Content body) {
|
|
||||||
return new HtmlTree(HtmlTag.DL)
|
|
||||||
.setStyle(style)
|
|
||||||
.add(body);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -476,6 +531,30 @@ public class HtmlTree extends Content {
|
|||||||
.add(body);
|
.add(body);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an HTML {@code DL} element with the given style.
|
||||||
|
*
|
||||||
|
* @param style the style
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree DL(HtmlStyle style) {
|
||||||
|
return new HtmlTree(HtmlTag.DL)
|
||||||
|
.setStyle(style);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an HTML {@code DL} element with the given style and content.
|
||||||
|
*
|
||||||
|
* @param style the style
|
||||||
|
* @param body the content
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree DL(HtmlStyle style, Content body) {
|
||||||
|
return new HtmlTree(HtmlTag.DL)
|
||||||
|
.setStyle(style)
|
||||||
|
.add(body);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code DT} element with the given content.
|
* Creates an HTML {@code DT} element with the given content.
|
||||||
*
|
*
|
||||||
@ -487,6 +566,17 @@ public class HtmlTree extends Content {
|
|||||||
.add(body);
|
.add(body);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an HTML {@code EM} element with the given content.
|
||||||
|
*
|
||||||
|
* @param body content for the element
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree EM(String body) {
|
||||||
|
return new HtmlTree(HtmlTag.EM)
|
||||||
|
.add(body);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code FOOTER} element.
|
* Creates an HTML {@code FOOTER} element.
|
||||||
* The role is set to {@code contentinfo}.
|
* The role is set to {@code contentinfo}.
|
||||||
@ -573,6 +663,15 @@ public class HtmlTree extends Content {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static final HtmlTree HR_INSTANCE = unmodifiableTree(HtmlTag.HR);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@return an HTML {@code HR} element}
|
||||||
|
*/
|
||||||
|
public static HtmlTree HR() {
|
||||||
|
return HR_INSTANCE;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code HTML} element with the given {@code lang} attribute,
|
* Creates an HTML {@code HTML} element with the given {@code lang} attribute,
|
||||||
* and {@code HEAD} and {@code BODY} contents.
|
* and {@code HEAD} and {@code BODY} contents.
|
||||||
@ -630,6 +729,27 @@ public class HtmlTree extends Content {
|
|||||||
.add(body);
|
.add(body);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an empty HTML {@code LI} element.
|
||||||
|
*
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree LI() {
|
||||||
|
return new HtmlTree(HtmlTag.LI);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an HTML {@code LI} element with the given style.
|
||||||
|
*
|
||||||
|
* @param style the style
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree LI(HtmlStyle style) {
|
||||||
|
return new HtmlTree(HtmlTag.LI)
|
||||||
|
.setStyle(style);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code LI} element with the given content.
|
* Creates an HTML {@code LI} element with the given content.
|
||||||
*
|
*
|
||||||
@ -776,6 +896,25 @@ public class HtmlTree extends Content {
|
|||||||
.setStyle(style);
|
.setStyle(style);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an empty HTML {@code PRE} element.
|
||||||
|
*
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree PRE() {
|
||||||
|
return new HtmlTree(HtmlTag.PRE);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an HTML {@code PRE} element with the given style
|
||||||
|
*
|
||||||
|
* @param style the style
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree PRE(HtmlStyle style) {
|
||||||
|
return new HtmlTree(HtmlTag.PRE).setStyle(style);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code PRE} element with some content.
|
* Creates an HTML {@code PRE} element with some content.
|
||||||
*
|
*
|
||||||
@ -971,6 +1110,15 @@ public class HtmlTree extends Content {
|
|||||||
.add(body);
|
.add(body);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an empty HTML {@code UL} element.
|
||||||
|
*
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree UL() {
|
||||||
|
return new HtmlTree(HtmlTag.UL);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code UL} element with the given style.
|
* Creates an HTML {@code UL} element with the given style.
|
||||||
*
|
*
|
||||||
@ -982,6 +1130,19 @@ public class HtmlTree extends Content {
|
|||||||
.setStyle(style);
|
.setStyle(style);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates an HTML {@code UL} element with the given id and style.
|
||||||
|
*
|
||||||
|
* @param id the id
|
||||||
|
* @param style the style
|
||||||
|
* @return the element
|
||||||
|
*/
|
||||||
|
public static HtmlTree UL(HtmlId id, HtmlStyle style) {
|
||||||
|
return new HtmlTree(HtmlTag.UL)
|
||||||
|
.setId(id)
|
||||||
|
.setStyle(style);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates an HTML {@code UL} element with the given style and some content.
|
* Creates an HTML {@code UL} element with the given style and some content.
|
||||||
*
|
*
|
||||||
@ -1015,6 +1176,15 @@ public class HtmlTree extends Content {
|
|||||||
.addAll(items, mapper);
|
.addAll(items, mapper);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static final HtmlTree WBR_INSTANCE = unmodifiableTree(HtmlTag.WBR);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@return an HTML {@code WBR} element}
|
||||||
|
*/
|
||||||
|
public static HtmlTree WBR() {
|
||||||
|
return WBR_INSTANCE;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean isEmpty() {
|
public boolean isEmpty() {
|
||||||
return (!hasContent() && !hasAttrs());
|
return (!hasContent() && !hasAttrs());
|
||||||
@ -1152,4 +1322,17 @@ public class HtmlTree extends Content {
|
|||||||
// remove extra whitespaces
|
// remove extra whitespaces
|
||||||
return rawString.trim();
|
return rawString.trim();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static HtmlTree unmodifiableTree(HtmlTag tag) {
|
||||||
|
return new HtmlTree(tag) {
|
||||||
|
@Override
|
||||||
|
public HtmlTree add(Content c) {
|
||||||
|
throw new UnsupportedOperationException(this.tag + " add");
|
||||||
|
}
|
||||||
|
@Override
|
||||||
|
public HtmlTree put(HtmlAttr attrName, String attrValue) {
|
||||||
|
throw new UnsupportedOperationException(this.tag + " put");
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -70,19 +70,19 @@ public class TestHtmlDocument extends JavadocTester {
|
|||||||
// Generate the HTML output using the HTML document generation within doclet.
|
// Generate the HTML output using the HTML document generation within doclet.
|
||||||
public static String generateHtmlTree() {
|
public static String generateHtmlTree() {
|
||||||
// Document type for the HTML document
|
// Document type for the HTML document
|
||||||
HtmlTree html = new HtmlTree(HtmlTag.HTML);
|
HtmlTree html = HtmlTree.of(HtmlTag.HTML);
|
||||||
HtmlTree head = new HtmlTree(HtmlTag.HEAD);
|
HtmlTree head = HtmlTree.of(HtmlTag.HEAD);
|
||||||
HtmlTree title = new HtmlTree(HtmlTag.TITLE);
|
HtmlTree title = HtmlTree.of(HtmlTag.TITLE);
|
||||||
// String content within the document
|
// String content within the document
|
||||||
TextBuilder titleContent = new TextBuilder("Markup test");
|
TextBuilder titleContent = new TextBuilder("Markup test");
|
||||||
title.add(titleContent);
|
title.add(titleContent);
|
||||||
head.add(title);
|
head.add(title);
|
||||||
// Test META tag
|
// Test META tag
|
||||||
HtmlTree meta = new HtmlTree(HtmlTag.META);
|
HtmlTree meta = HtmlTree.of(HtmlTag.META);
|
||||||
meta.put(HtmlAttr.NAME, "keywords");
|
meta.put(HtmlAttr.NAME, "keywords");
|
||||||
meta.put(HtmlAttr.CONTENT, "testContent");
|
meta.put(HtmlAttr.CONTENT, "testContent");
|
||||||
head.add(meta);
|
head.add(meta);
|
||||||
HtmlTree link = new HtmlTree(HtmlTag.LINK);
|
HtmlTree link = HtmlTree.of(HtmlTag.LINK);
|
||||||
link.put(HtmlAttr.REL, "testRel");
|
link.put(HtmlAttr.REL, "testRel");
|
||||||
link.put(HtmlAttr.HREF, "testLink.html");
|
link.put(HtmlAttr.HREF, "testLink.html");
|
||||||
head.add(link);
|
head.add(link);
|
||||||
@ -90,10 +90,10 @@ public class TestHtmlDocument extends JavadocTester {
|
|||||||
// Comment within the document
|
// Comment within the document
|
||||||
Comment bodyMarker = new Comment("======== START OF BODY ========");
|
Comment bodyMarker = new Comment("======== START OF BODY ========");
|
||||||
html.add(bodyMarker);
|
html.add(bodyMarker);
|
||||||
HtmlTree body = new HtmlTree(HtmlTag.BODY);
|
HtmlTree body = HtmlTree.of(HtmlTag.BODY);
|
||||||
Comment pMarker = new Comment("======== START OF PARAGRAPH ========");
|
Comment pMarker = new Comment("======== START OF PARAGRAPH ========");
|
||||||
body.add(pMarker);
|
body.add(pMarker);
|
||||||
HtmlTree p = new HtmlTree(HtmlTag.P);
|
HtmlTree p = HtmlTree.of(HtmlTag.P);
|
||||||
TextBuilder bodyContent = new TextBuilder(
|
TextBuilder bodyContent = new TextBuilder(
|
||||||
"This document is generated from sample source code and HTML " +
|
"This document is generated from sample source code and HTML " +
|
||||||
"files with examples of a wide variety of Java language constructs: packages, " +
|
"files with examples of a wide variety of Java language constructs: packages, " +
|
||||||
@ -106,24 +106,24 @@ public class TestHtmlDocument extends JavadocTester {
|
|||||||
TextBuilder pContent = new TextBuilder(" to <test> out a link.");
|
TextBuilder pContent = new TextBuilder(" to <test> out a link.");
|
||||||
p.add(pContent);
|
p.add(pContent);
|
||||||
body.add(p);
|
body.add(p);
|
||||||
HtmlTree p1 = new HtmlTree(HtmlTag.P);
|
HtmlTree p1 = HtmlTree.of(HtmlTag.P);
|
||||||
// Test another version of A tag.
|
// Test another version of A tag.
|
||||||
HtmlTree anchor = new HtmlTree(HtmlTag.A);
|
HtmlTree anchor = HtmlTree.of(HtmlTag.A);
|
||||||
anchor.put(HtmlAttr.HREF, "testLink.html");
|
anchor.put(HtmlAttr.HREF, "testLink.html");
|
||||||
anchor.put(HtmlAttr.ID, "Another version of a tag");
|
anchor.put(HtmlAttr.ID, "Another version of a tag");
|
||||||
p1.add(anchor);
|
p1.add(anchor);
|
||||||
body.add(p1);
|
body.add(p1);
|
||||||
// Test for empty tags.
|
// Test for empty tags.
|
||||||
HtmlTree dl = new HtmlTree(HtmlTag.DL);
|
HtmlTree dl = HtmlTree.of(HtmlTag.DL);
|
||||||
html.add(dl);
|
html.add(dl);
|
||||||
// Test for empty nested tags.
|
// Test for empty nested tags.
|
||||||
HtmlTree dlTree = new HtmlTree(HtmlTag.DL);
|
HtmlTree dlTree = HtmlTree.of(HtmlTag.DL);
|
||||||
dlTree.add(new HtmlTree(HtmlTag.DT));
|
dlTree.add(HtmlTree.of(HtmlTag.DT));
|
||||||
dlTree.add(new HtmlTree (HtmlTag.DD));
|
dlTree.add(HtmlTree.of (HtmlTag.DD));
|
||||||
html.add(dlTree);
|
html.add(dlTree);
|
||||||
HtmlTree dlDisplay = new HtmlTree(HtmlTag.DL);
|
HtmlTree dlDisplay = HtmlTree.of(HtmlTag.DL);
|
||||||
dlDisplay.add(new HtmlTree(HtmlTag.DT));
|
dlDisplay.add(HtmlTree.of(HtmlTag.DT));
|
||||||
HtmlTree dd = new HtmlTree (HtmlTag.DD);
|
HtmlTree dd = HtmlTree.of (HtmlTag.DD);
|
||||||
TextBuilder ddContent = new TextBuilder("Test DD");
|
TextBuilder ddContent = new TextBuilder("Test DD");
|
||||||
dd.add(ddContent);
|
dd.add(ddContent);
|
||||||
dlDisplay.add(dd);
|
dlDisplay.add(dd);
|
||||||
@ -132,7 +132,7 @@ public class TestHtmlDocument extends JavadocTester {
|
|||||||
body.add(emptyString);
|
body.add(emptyString);
|
||||||
Comment emptyComment = new Comment("");
|
Comment emptyComment = new Comment("");
|
||||||
body.add(emptyComment);
|
body.add(emptyComment);
|
||||||
HtmlTree hr = new HtmlTree(HtmlTag.HR);
|
HtmlTree hr = HtmlTree.of(HtmlTag.HR);
|
||||||
body.add(hr);
|
body.add(hr);
|
||||||
html.add(body);
|
html.add(body);
|
||||||
HtmlDocument htmlDoc = new HtmlDocument(html);
|
HtmlDocument htmlDoc = new HtmlDocument(html);
|
||||||
|
@ -55,7 +55,7 @@ public class TestVoidHtmlElements {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static void check(HtmlTag htmlTag) {
|
private static void check(HtmlTag htmlTag) {
|
||||||
boolean elementIsVoid = new HtmlTree(htmlTag).isVoid();
|
boolean elementIsVoid = HtmlTree.of(htmlTag).isVoid();
|
||||||
boolean elementHasNoEndTag = htmlTag.endKind == HtmlTag.EndKind.NONE;
|
boolean elementHasNoEndTag = htmlTag.endKind == HtmlTag.EndKind.NONE;
|
||||||
if (elementIsVoid != elementHasNoEndTag) {
|
if (elementIsVoid != elementHasNoEndTag) {
|
||||||
throw new AssertionError(htmlTag + ", " + elementIsVoid + ", " + elementHasNoEndTag);
|
throw new AssertionError(htmlTag + ", " + elementIsVoid + ", " + elementHasNoEndTag);
|
||||||
|
Loading…
Reference in New Issue
Block a user