diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java index 8179c4565a9..c0e3fb4a769 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/HtmlConfiguration.java @@ -374,7 +374,7 @@ public class HtmlConfiguration extends BaseConfiguration { return options.additionalStylesheets().stream() .map(ssf -> DocFile.createFileForInput(this, ssf)) .map(file -> DocPath.create(file.getName())) - .collect(Collectors.toList()); + .collect(Collectors.toCollection(ArrayList::new)); } @Override diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexWriter.java index 29559b72984..4fadb86baa7 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/IndexWriter.java @@ -367,7 +367,7 @@ public class IndexWriter extends HtmlDocletWriter { .sorted((i1,i2)-> utils.compareStrings(i1.getLabel(), i2.getLabel())) .map(i -> links.createLink(pathToRoot.resolve(i.getUrl()), contents.getNonBreakString(i.getLabel()))) - .collect(Collectors.toList()); + .toList(); contentTree.add(contents.join(getVerticalSeparator(), pageLinks)); } 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 59a39f05219..1b509f42ce4 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 @@ -177,7 +177,7 @@ public class Signatures { List permits = typeElement.getPermittedSubclasses(); List linkablePermits = permits.stream() .filter(t -> utils.isLinkable(utils.asTypeElement(t))) - .collect(Collectors.toList()); + .toList(); if (!linkablePermits.isEmpty()) { Content permitsSpan = new HtmlTree(TagName.SPAN).setStyle(HtmlStyle.permits); boolean isFirst = true; diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SystemPropertiesWriter.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SystemPropertiesWriter.java index 65c55f1e897..63ee5792105 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SystemPropertiesWriter.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/SystemPropertiesWriter.java @@ -43,14 +43,12 @@ import jdk.javadoc.internal.doclets.toolkit.util.IndexItem; import javax.lang.model.element.Element; import java.nio.file.Path; -import java.util.List; -import java.util.Map; +import java.util.*; import java.util.Map.Entry; -import java.util.TreeMap; -import java.util.WeakHashMap; import static java.util.stream.Collectors.groupingBy; -import static java.util.stream.Collectors.toList; +import java.util.stream.Collectors; +import java.util.ArrayList; /** * Generates the file with the summary of all the system properties. @@ -148,7 +146,7 @@ public class SystemPropertiesWriter extends HtmlDocletWriter { private Map> groupSystemProperties() { return configuration.mainIndex.getItems(DocTree.Kind.SYSTEM_PROPERTY).stream() - .collect(groupingBy(IndexItem::getLabel, TreeMap::new, toList())); + .collect(groupingBy(IndexItem::getLabel, TreeMap::new, Collectors.toCollection(ArrayList::new))); } private Content createLink(IndexItem i) { diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/TableHeader.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/TableHeader.java index 7cd804e7b7a..255f61a491b 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/TableHeader.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/formats/html/TableHeader.java @@ -69,7 +69,7 @@ public class TableHeader extends Content { public TableHeader(Contents contents, String... colHeaderKeys) { this.cellContents = Arrays.stream(colHeaderKeys) .map(contents::getContent) - .collect(Collectors.toList()); + .toList(); } /** diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/MemberSummaryBuilder.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/MemberSummaryBuilder.java index a3457787f87..fca98f34f97 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/MemberSummaryBuilder.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/MemberSummaryBuilder.java @@ -413,9 +413,10 @@ public abstract class MemberSummaryBuilder extends AbstractMemberBuilder { continue; } - List members = inheritedMembersFromMap.stream() + List members = inheritedMembersFromMap.stream() .filter(e -> utils.getEnclosingTypeElement(e) == inheritedClass) - .collect(Collectors.toList()); + .toList(); + if (!members.isEmpty()) { SortedSet inheritedMembers = new TreeSet<>(comparator); inheritedMembers.addAll(members); diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/PackageSummaryBuilder.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/PackageSummaryBuilder.java index 6bcd948bf58..56772ad6ecf 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/PackageSummaryBuilder.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/builders/PackageSummaryBuilder.java @@ -349,6 +349,6 @@ public class PackageSummaryBuilder extends AbstractBuilder { private List filterPackages(Predicate filter) { return configuration.packages.stream() .filter(p -> p != packageElement && filter.test(p)) - .collect(Collectors.toList()); + .toList(); } } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/taglets/ThrowsTaglet.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/taglets/ThrowsTaglet.java index bea65063128..7a60fabcfb4 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/taglets/ThrowsTaglet.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/taglets/ThrowsTaglet.java @@ -148,7 +148,7 @@ public class ThrowsTaglet extends BaseTaglet } List inheritedTags = inheritedDoc.tagList.stream() .map(t -> (ThrowsTree) t) - .collect(Collectors.toList()); + .toList(); declaredExceptionTags.put(inheritedTags, (ExecutableElement) inheritedDoc.holder); } } diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/Utils.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/Utils.java index 536eb865ae2..bd51aaceb08 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/Utils.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/Utils.java @@ -2097,21 +2097,21 @@ public class Utils { public List getOrdinaryClasses(Element e) { return getClasses(e).stream() .filter(te -> (!isException(te) && !isError(te))) - .collect(Collectors.toList()); + .toList(); } public List getErrors(Element e) { return getClasses(e) .stream() .filter(this::isError) - .collect(Collectors.toList()); + .toList(); } public List getExceptions(Element e) { return getClasses(e) .stream() .filter(this::isException) - .collect(Collectors.toList()); + .toList(); } @SuppressWarnings("preview") @@ -2601,7 +2601,7 @@ public class Utils { return getBlockTags(element).stream() .filter(t -> t.getKind() != ERRONEOUS) .filter(filter) - .collect(Collectors.toList()); + .toList(); } public List getBlockTags(Element element, Predicate filter, Class tClass) { @@ -2609,7 +2609,7 @@ public class Utils { .filter(t -> t.getKind() != ERRONEOUS) .filter(filter) .map(t -> tClass.cast(t)) - .collect(Collectors.toList()); + .toList(); } public List getBlockTags(Element element, DocTree.Kind kind) { @@ -3027,7 +3027,7 @@ public class Utils { usedInDeclaration.addAll(types2Classes(List.of(te.getSuperclass()))); usedInDeclaration.addAll(types2Classes(te.getInterfaces())); usedInDeclaration.addAll(types2Classes(te.getPermittedSubclasses())); - usedInDeclaration.addAll(types2Classes(te.getRecordComponents().stream().map(c -> c.asType()).collect(Collectors.toList()))); //TODO: annotations on record components??? + usedInDeclaration.addAll(types2Classes(te.getRecordComponents().stream().map(c -> c.asType()).toList())); //TODO: annotations on record components??? } case CONSTRUCTOR, METHOD -> { ExecutableElement ee = (ExecutableElement) el; @@ -3037,7 +3037,7 @@ public class Utils { usedInDeclaration.addAll(types2Classes(List.of(ee.getReturnType()))); usedInDeclaration.addAll(types2Classes(List.of(ee.getReceiverType()))); usedInDeclaration.addAll(types2Classes(ee.getThrownTypes())); - usedInDeclaration.addAll(types2Classes(ee.getParameters().stream().map(p -> p.asType()).collect(Collectors.toList()))); + usedInDeclaration.addAll(types2Classes(ee.getParameters().stream().map(p -> p.asType()).toList())); usedInDeclaration.addAll(annotationValue2Classes(ee.getDefaultValue())); } case FIELD, ENUM_CONSTANT, RECORD_COMPONENT -> { diff --git a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/VisibleMemberTable.java b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/VisibleMemberTable.java index 0d3604b4535..1615141d85b 100644 --- a/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/VisibleMemberTable.java +++ b/src/jdk.javadoc/share/classes/jdk/javadoc/internal/doclets/toolkit/util/VisibleMemberTable.java @@ -54,6 +54,7 @@ import java.util.Map; import java.util.Set; import java.util.function.Predicate; import java.util.stream.Collectors; +import java.util.stream.Stream; import jdk.javadoc.internal.doclets.toolkit.BaseConfiguration; import jdk.javadoc.internal.doclets.toolkit.BaseOptions; @@ -199,7 +200,7 @@ public class VisibleMemberTable { return visibleMembers.getOrDefault(kind, Collections.emptyList()).stream() .filter(p) - .collect(Collectors.toList()); + .toList(); } /** @@ -408,8 +409,8 @@ public class VisibleMemberTable { default: List list = lmt.getOrderedMembers(kind).stream() .filter(this::mustDocument) - .collect(Collectors.toList()); - visibleMembers.put(kind, Collections.unmodifiableList(list)); + .toList(); + visibleMembers.put(kind, list); break; } } @@ -454,19 +455,16 @@ public class VisibleMemberTable { // Filter out members in the inherited list that are hidden // by this type or should not be inherited at all. - List list = result.stream() - .filter(e -> allowInheritedMembers(e, kind, lmt)) - .collect(Collectors.toList()); - - // Prefix local results first - list.addAll(0, lmt.getOrderedMembers(kind)); + Stream inheritedStream = result.stream() + .filter(e -> allowInheritedMembers(e, kind, lmt)); // Filter out elements that should not be documented - list = list.stream() - .filter(this::mustDocument) - .collect(Collectors.toList()); + // Prefix local results first + List list = Stream.concat(lmt.getOrderedMembers(kind).stream(), inheritedStream) + .filter(this::mustDocument) + .toList(); - visibleMembers.put(kind, Collections.unmodifiableList(list)); + visibleMembers.put(kind, list); } private void computeVisibleMethods(LocalMemberTable lmt) { @@ -490,9 +488,12 @@ public class VisibleMemberTable { // b. are overridden and should not be visible in this type // c. are hidden in the type being considered // see allowInheritedMethod, which performs the above actions - List list = inheritedMethods.stream() + // nb. This statement has side effects that can initialize + // members of the overridenMethodTable field, so it must be + // evaluated eagerly with toList(). + List inheritedMethodsList = inheritedMethods.stream() .filter(e -> allowInheritedMethod((ExecutableElement) e, overriddenByTable, lmt)) - .collect(Collectors.toList()); + .toList(); // Filter out the local methods, that do not override or simply // overrides a super method, or those methods that should not @@ -501,21 +502,19 @@ public class VisibleMemberTable { OverriddenMethodInfo p = overriddenMethodTable.getOrDefault(m, null); return p == null || !p.simpleOverride; }; - List localList = lmt.getOrderedMembers(Kind.METHODS) + + Stream localStream = lmt.getOrderedMembers(Kind.METHODS) .stream() .map(m -> (ExecutableElement)m) - .filter(isVisible) - .collect(Collectors.toList()); - - // Merge the above lists, making sure the local methods precede the others - list.addAll(0, localList); + .filter(isVisible); + // Merge the above list and stream, making sure the local methods precede the others // Final filtration of elements - list = list.stream() + List list = Stream.concat(localStream,inheritedMethodsList.stream()) .filter(this::mustDocument) - .collect(Collectors.toList()); + .toList(); - visibleMembers.put(Kind.METHODS, Collections.unmodifiableList(list)); + visibleMembers.put(Kind.METHODS, list); // Copy over overridden tables from the lineage, and finish up. for (VisibleMemberTable pvmt : parents) { @@ -795,7 +794,7 @@ public class VisibleMemberTable { List getPropertyMethods(String methodName, int argcount) { return getMembers(methodName + ":" + argcount, Kind.METHODS).stream() .filter(m -> (utils.isPublic(m) || utils.isProtected(m))) - .collect(Collectors.toList()); + .toList(); } } @@ -857,17 +856,17 @@ public class VisibleMemberTable { return; PropertyUtils pUtils = config.propertyUtils; - List list = visibleMembers.getOrDefault(Kind.METHODS, Collections.emptyList()) + List list = visibleMembers.getOrDefault(Kind.METHODS, Collections.emptyList()) .stream() - .map(m -> (ExecutableElement)m) - .filter(pUtils::isPropertyMethod) - .collect(Collectors.toList()); + .filter(e -> pUtils.isPropertyMethod((ExecutableElement) e)) + .toList(); - visibleMembers.put(Kind.PROPERTIES, Collections.unmodifiableList(list)); + visibleMembers.put(Kind.PROPERTIES, list); List propertyMethods = list.stream() + .map(e -> (ExecutableElement) e) .filter(e -> utils.getEnclosingTypeElement(e) == te) - .collect(Collectors.toList()); + .toList(); // Compute additional properties related sundries. for (ExecutableElement propertyMethod : propertyMethods) { @@ -931,7 +930,7 @@ public class VisibleMemberTable { ImplementedMethods imf = getImplementedMethodsFinder(method); return imf.getImplementedMethods().stream() .filter(m -> getSimplyOverriddenMethod(m) == null) - .collect(Collectors.toList()); + .toList(); } public TypeMirror getImplementedMethodHolder(ExecutableElement method,