From 73cb922bfc13a00bd1e07a41c6971ae7e1ac7005 Mon Sep 17 00:00:00 2001 From: Pavel Rappo Date: Thu, 31 Mar 2022 15:23:40 +0000 Subject: [PATCH] 8284026: Use unmodifiable collections where practical Reviewed-by: jjg --- .../javadoc/internal/api/JavadocTaskImpl.java | 8 ++++---- .../doclets/formats/html/ClassWriterImpl.java | 5 ----- .../formats/html/DocFilesHandlerImpl.java | 5 ++--- .../doclets/formats/html/HtmlDocletWriter.java | 3 +-- .../formats/html/IndexRedirectWriter.java | 4 ++-- .../doclets/formats/html/ModuleWriterImpl.java | 7 +++---- .../doclets/formats/html/Signatures.java | 5 ++--- .../formats/html/markup/ContentBuilder.java | 5 ++--- .../doclets/formats/html/markup/Head.java | 7 +++---- .../doclets/toolkit/BaseConfiguration.java | 2 +- .../internal/doclets/toolkit/BaseOptions.java | 3 +-- .../doclets/toolkit/taglets/TagletManager.java | 5 ++--- .../doclets/toolkit/taglets/ThrowsTaglet.java | 4 +--- .../doclets/toolkit/util/CommentHelper.java | 5 ++--- .../doclets/toolkit/util/DocFinder.java | 4 ++-- .../doclets/toolkit/util/MetaKeywords.java | 6 +++--- .../internal/doclets/toolkit/util/Utils.java | 17 ++++++++--------- .../toolkit/util/VisibleMemberTable.java | 14 +++++++------- .../jdk/javadoc/internal/doclint/Env.java | 4 ++-- .../jdk/javadoc/internal/doclint/HtmlTag.java | 7 +++---- .../javadoc/internal/tool/ElementsTable.java | 10 +++++----- .../jdk/javadoc/internal/tool/Start.java | 5 ++--- 22 files changed, 58 insertions(+), 77 deletions(-) diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/api/JavadocTaskImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/api/JavadocTaskImpl.java index 94470974247..cb41ebb6189 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/api/JavadocTaskImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/api/JavadocTaskImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2012, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2012, 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 @@ -26,9 +26,9 @@ package jdk.javadoc.internal.api; import java.util.ArrayList; -import java.util.Collections; import java.util.List; import java.util.Locale; +import java.util.Set; import java.util.concurrent.atomic.AtomicBoolean; import javax.tools.DocumentationTool.DocumentationTask; @@ -67,9 +67,9 @@ public class JavadocTaskImpl implements DocumentationTask { this.context = context; this.docletClass = docletClass; - this.options = (options == null) ? Collections.emptySet() + this.options = (options == null) ? Set.of() : nullCheck(options); - this.fileObjects = (fileObjects == null) ? Collections.emptySet() + this.fileObjects = (fileObjects == null) ? Set.of() : nullCheck(fileObjects); setLocale(Locale.getDefault()); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassWriterImpl.java index 45b10dc89e1..7f1e15292d4 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ClassWriterImpl.java @@ -27,7 +27,6 @@ package jdk.javadoc.internal.doclets.formats.html; import java.util.ArrayList; import java.util.Collection; -import java.util.Collections; import java.util.List; import java.util.Set; import java.util.SortedSet; @@ -68,10 +67,6 @@ import jdk.javadoc.internal.doclets.toolkit.util.VisibleMemberTable; * deletion without notice. * * @see javax.lang.model.element.TypeElement - * @see java.util.Collections - * @see java.util.List - * @see java.util.ArrayList - * @see java.util.HashMap */ public class ClassWriterImpl extends SubWriterHolderWriter implements ClassWriter { diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/DocFilesHandlerImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/DocFilesHandlerImpl.java index 652e53a3075..ba1e5eb0013 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/DocFilesHandlerImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/DocFilesHandlerImpl.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2020, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 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 @@ -52,7 +52,6 @@ import javax.tools.JavaFileManager.Location; import java.net.URI; import java.net.URISyntaxException; import java.util.ArrayList; -import java.util.Collections; import java.util.List; import jdk.javadoc.internal.doclets.formats.html.Navigation.PageMode; @@ -213,7 +212,7 @@ public class DocFilesHandlerImpl implements DocFilesHandler { .setHeader(docletWriter.getHeader(PageMode.DOC_FILE, element)) .addMainContent(pageContent) .setFooter(docletWriter.getFooter())); - docletWriter.printHtmlDocument(Collections.emptyList(), null, localTagsContent, Collections.emptyList(), htmlContent); + docletWriter.printHtmlDocument(List.of(), null, localTagsContent, List.of(), htmlContent); } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlDocletWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlDocletWriter.java index ac6d395cb25..3c4733c2eb9 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlDocletWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlDocletWriter.java @@ -26,7 +26,6 @@ package jdk.javadoc.internal.doclets.formats.html; import java.util.ArrayList; -import java.util.Collections; import java.util.Comparator; import java.util.EnumSet; import java.util.HashMap; @@ -411,7 +410,7 @@ public class HtmlDocletWriter { String description, Content body) throws DocFileIOException { - printHtmlDocument(metakeywords, description, new ContentBuilder(), Collections.emptyList(), body); + printHtmlDocument(metakeywords, description, new ContentBuilder(), List.of(), body); } /** diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexRedirectWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexRedirectWriter.java index 299e565a657..bf53e06fcce 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexRedirectWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexRedirectWriter.java @@ -25,7 +25,7 @@ package jdk.javadoc.internal.doclets.formats.html; -import java.util.Collections; +import java.util.List; import jdk.javadoc.internal.doclets.formats.html.markup.Head; import jdk.javadoc.internal.doclets.formats.html.markup.ContentBuilder; @@ -78,7 +78,7 @@ public class IndexRedirectWriter extends HtmlDocletWriter { .setTimestamp(!options.noTimestamp()) .setDescription("index redirect") .setGenerator(getGenerator(getClass())) - .setStylesheets(configuration.getMainStylesheet(), Collections.emptyList()) // avoid reference to default stylesheet + .setStylesheets(configuration.getMainStylesheet(), List.of()) // avoid reference to default stylesheet .addDefaultScript(false); String title = (options.windowTitle().length() > 0) diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleWriterImpl.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleWriterImpl.java index 30803551b2f..8f668fa0ffa 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleWriterImpl.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/ModuleWriterImpl.java @@ -26,7 +26,6 @@ package jdk.javadoc.internal.doclets.formats.html; import java.util.ArrayList; -import java.util.Collections; import java.util.List; import java.util.Map; import java.util.Set; @@ -264,11 +263,11 @@ public class ModuleWriterImpl extends HtmlDocletWriter implements ModuleSummaryW }); // Get all packages if module is open or if displaying concealed modules - for (PackageElement pkg : utils.getModulePackageMap().getOrDefault(mdle, Collections.emptySet())) { + for (PackageElement pkg : utils.getModulePackageMap().getOrDefault(mdle, Set.of())) { if (shouldDocument(pkg) && (mdle.isOpen() || moduleMode == ModuleMode.ALL)) { PackageEntry e = new PackageEntry(); if (mdle.isOpen()) { - e.openedTo = Collections.emptySet(); + e.openedTo = Set.of(); } packages.put(pkg, e); } @@ -329,7 +328,7 @@ public class ModuleWriterImpl extends HtmlDocletWriter implements ModuleSummaryW } SortedSet openPackages = new TreeSet<>(utils.comparators.makePackageComparator()); if (module.isOpen()) { - openPackages.addAll(utils.getModulePackageMap().getOrDefault(module, Collections.emptySet())); + openPackages.addAll(utils.getModulePackageMap().getOrDefault(module, Set.of())); } else { ElementFilter.opensIn(module.getDirectives()).forEach(directive -> { PackageElement pkg = directive.getPackage(); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/Signatures.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/Signatures.java index 6b54c48b975..3ed0320588a 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/Signatures.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/Signatures.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2020, 2021, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2020, 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 @@ -46,7 +46,6 @@ import javax.lang.model.element.TypeElement; import javax.lang.model.type.TypeMirror; import javax.lang.model.util.ElementKindVisitor14; import java.util.ArrayList; -import java.util.Collections; import java.util.List; import java.util.Set; import java.util.SortedSet; @@ -106,7 +105,7 @@ public class Signatures { private final HtmlConfiguration configuration; private Content modifiers; - private static final Set previewModifiers = Collections.emptySet(); + private static final Set previewModifiers = Set.of(); TypeSignature(TypeElement typeElement, HtmlDocletWriter writer) { this.typeElement = typeElement; diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/ContentBuilder.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/ContentBuilder.java index 79d398f9c9e..06112b09e90 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/ContentBuilder.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/ContentBuilder.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 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 @@ -28,7 +28,6 @@ package jdk.javadoc.internal.doclets.formats.html.markup; import java.io.IOException; import java.io.Writer; import java.util.ArrayList; -import java.util.Collections; import java.util.List; import java.util.Objects; @@ -38,7 +37,7 @@ import jdk.javadoc.internal.doclets.toolkit.Content; * A sequence of Content nodes. */ public class ContentBuilder extends Content { - protected List contents = Collections.emptyList(); + protected List contents = List.of(); public ContentBuilder() { } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Head.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Head.java index adbd5ef09fd..4c8e8a2e0b6 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Head.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/markup/Head.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2003, 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 @@ -31,7 +31,6 @@ import java.time.ZonedDateTime; import java.time.format.DateTimeFormatter; import java.util.ArrayList; import java.util.Arrays; -import java.util.Collections; import java.util.Date; import java.util.List; import java.util.Locale; @@ -61,12 +60,12 @@ public class Head extends Content { private String generator; private boolean showTimestamp; private DocPath mainStylesheet; - private List additionalStylesheets = Collections.emptyList(); + private List additionalStylesheets = List.of(); private boolean index; private Script mainBodyScript; private final List