8261168: Convert javadoc tool to use Stream.toList()

Reviewed-by: prappo
This commit is contained in:
Ian Graves 2021-04-26 15:20:30 +00:00 committed by Pavel Rappo
parent 8559a53056
commit fb8f0c5dd8
10 changed files with 51 additions and 53 deletions

View File

@ -374,7 +374,7 @@ public class HtmlConfiguration extends BaseConfiguration {
return options.additionalStylesheets().stream() return options.additionalStylesheets().stream()
.map(ssf -> DocFile.createFileForInput(this, ssf)) .map(ssf -> DocFile.createFileForInput(this, ssf))
.map(file -> DocPath.create(file.getName())) .map(file -> DocPath.create(file.getName()))
.collect(Collectors.toList()); .collect(Collectors.toCollection(ArrayList::new));
} }
@Override @Override

View File

@ -367,7 +367,7 @@ public class IndexWriter extends HtmlDocletWriter {
.sorted((i1,i2)-> utils.compareStrings(i1.getLabel(), i2.getLabel())) .sorted((i1,i2)-> utils.compareStrings(i1.getLabel(), i2.getLabel()))
.map(i -> links.createLink(pathToRoot.resolve(i.getUrl()), .map(i -> links.createLink(pathToRoot.resolve(i.getUrl()),
contents.getNonBreakString(i.getLabel()))) contents.getNonBreakString(i.getLabel())))
.collect(Collectors.toList()); .toList();
contentTree.add(contents.join(getVerticalSeparator(), pageLinks)); contentTree.add(contents.join(getVerticalSeparator(), pageLinks));
} }

View File

@ -177,7 +177,7 @@ public class Signatures {
List<? extends TypeMirror> permits = typeElement.getPermittedSubclasses(); List<? extends TypeMirror> permits = typeElement.getPermittedSubclasses();
List<? extends TypeMirror> linkablePermits = permits.stream() List<? extends TypeMirror> linkablePermits = permits.stream()
.filter(t -> utils.isLinkable(utils.asTypeElement(t))) .filter(t -> utils.isLinkable(utils.asTypeElement(t)))
.collect(Collectors.toList()); .toList();
if (!linkablePermits.isEmpty()) { if (!linkablePermits.isEmpty()) {
Content permitsSpan = new HtmlTree(TagName.SPAN).setStyle(HtmlStyle.permits); Content permitsSpan = new HtmlTree(TagName.SPAN).setStyle(HtmlStyle.permits);
boolean isFirst = true; boolean isFirst = true;

View File

@ -43,14 +43,12 @@ import jdk.javadoc.internal.doclets.toolkit.util.IndexItem;
import javax.lang.model.element.Element; import javax.lang.model.element.Element;
import java.nio.file.Path; import java.nio.file.Path;
import java.util.List; import java.util.*;
import java.util.Map;
import java.util.Map.Entry; 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.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. * Generates the file with the summary of all the system properties.
@ -148,7 +146,7 @@ public class SystemPropertiesWriter extends HtmlDocletWriter {
private Map<String, List<IndexItem>> groupSystemProperties() { private Map<String, List<IndexItem>> groupSystemProperties() {
return configuration.mainIndex.getItems(DocTree.Kind.SYSTEM_PROPERTY).stream() 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) { private Content createLink(IndexItem i) {

View File

@ -69,7 +69,7 @@ public class TableHeader extends Content {
public TableHeader(Contents contents, String... colHeaderKeys) { public TableHeader(Contents contents, String... colHeaderKeys) {
this.cellContents = Arrays.stream(colHeaderKeys) this.cellContents = Arrays.stream(colHeaderKeys)
.map(contents::getContent) .map(contents::getContent)
.collect(Collectors.toList()); .toList();
} }
/** /**

View File

@ -413,9 +413,10 @@ public abstract class MemberSummaryBuilder extends AbstractMemberBuilder {
continue; continue;
} }
List<Element> members = inheritedMembersFromMap.stream() List<? extends Element> members = inheritedMembersFromMap.stream()
.filter(e -> utils.getEnclosingTypeElement(e) == inheritedClass) .filter(e -> utils.getEnclosingTypeElement(e) == inheritedClass)
.collect(Collectors.toList()); .toList();
if (!members.isEmpty()) { if (!members.isEmpty()) {
SortedSet<Element> inheritedMembers = new TreeSet<>(comparator); SortedSet<Element> inheritedMembers = new TreeSet<>(comparator);
inheritedMembers.addAll(members); inheritedMembers.addAll(members);

View File

@ -349,6 +349,6 @@ public class PackageSummaryBuilder extends AbstractBuilder {
private List<PackageElement> filterPackages(Predicate<? super PackageElement> filter) { private List<PackageElement> filterPackages(Predicate<? super PackageElement> filter) {
return configuration.packages.stream() return configuration.packages.stream()
.filter(p -> p != packageElement && filter.test(p)) .filter(p -> p != packageElement && filter.test(p))
.collect(Collectors.toList()); .toList();
} }
} }

View File

@ -148,7 +148,7 @@ public class ThrowsTaglet extends BaseTaglet
} }
List<? extends ThrowsTree> inheritedTags = inheritedDoc.tagList.stream() List<? extends ThrowsTree> inheritedTags = inheritedDoc.tagList.stream()
.map(t -> (ThrowsTree) t) .map(t -> (ThrowsTree) t)
.collect(Collectors.toList()); .toList();
declaredExceptionTags.put(inheritedTags, (ExecutableElement) inheritedDoc.holder); declaredExceptionTags.put(inheritedTags, (ExecutableElement) inheritedDoc.holder);
} }
} }

View File

@ -2097,21 +2097,21 @@ public class Utils {
public List<TypeElement> getOrdinaryClasses(Element e) { public List<TypeElement> getOrdinaryClasses(Element e) {
return getClasses(e).stream() return getClasses(e).stream()
.filter(te -> (!isException(te) && !isError(te))) .filter(te -> (!isException(te) && !isError(te)))
.collect(Collectors.toList()); .toList();
} }
public List<TypeElement> getErrors(Element e) { public List<TypeElement> getErrors(Element e) {
return getClasses(e) return getClasses(e)
.stream() .stream()
.filter(this::isError) .filter(this::isError)
.collect(Collectors.toList()); .toList();
} }
public List<TypeElement> getExceptions(Element e) { public List<TypeElement> getExceptions(Element e) {
return getClasses(e) return getClasses(e)
.stream() .stream()
.filter(this::isException) .filter(this::isException)
.collect(Collectors.toList()); .toList();
} }
@SuppressWarnings("preview") @SuppressWarnings("preview")
@ -2601,7 +2601,7 @@ public class Utils {
return getBlockTags(element).stream() return getBlockTags(element).stream()
.filter(t -> t.getKind() != ERRONEOUS) .filter(t -> t.getKind() != ERRONEOUS)
.filter(filter) .filter(filter)
.collect(Collectors.toList()); .toList();
} }
public <T extends DocTree> List<? extends T> getBlockTags(Element element, Predicate<DocTree> filter, Class<T> tClass) { public <T extends DocTree> List<? extends T> getBlockTags(Element element, Predicate<DocTree> filter, Class<T> tClass) {
@ -2609,7 +2609,7 @@ public class Utils {
.filter(t -> t.getKind() != ERRONEOUS) .filter(t -> t.getKind() != ERRONEOUS)
.filter(filter) .filter(filter)
.map(t -> tClass.cast(t)) .map(t -> tClass.cast(t))
.collect(Collectors.toList()); .toList();
} }
public List<? extends DocTree> getBlockTags(Element element, DocTree.Kind kind) { public List<? extends DocTree> getBlockTags(Element element, DocTree.Kind kind) {
@ -3027,7 +3027,7 @@ public class Utils {
usedInDeclaration.addAll(types2Classes(List.of(te.getSuperclass()))); usedInDeclaration.addAll(types2Classes(List.of(te.getSuperclass())));
usedInDeclaration.addAll(types2Classes(te.getInterfaces())); usedInDeclaration.addAll(types2Classes(te.getInterfaces()));
usedInDeclaration.addAll(types2Classes(te.getPermittedSubclasses())); 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 -> { case CONSTRUCTOR, METHOD -> {
ExecutableElement ee = (ExecutableElement) el; ExecutableElement ee = (ExecutableElement) el;
@ -3037,7 +3037,7 @@ public class Utils {
usedInDeclaration.addAll(types2Classes(List.of(ee.getReturnType()))); usedInDeclaration.addAll(types2Classes(List.of(ee.getReturnType())));
usedInDeclaration.addAll(types2Classes(List.of(ee.getReceiverType()))); usedInDeclaration.addAll(types2Classes(List.of(ee.getReceiverType())));
usedInDeclaration.addAll(types2Classes(ee.getThrownTypes())); 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())); usedInDeclaration.addAll(annotationValue2Classes(ee.getDefaultValue()));
} }
case FIELD, ENUM_CONSTANT, RECORD_COMPONENT -> { case FIELD, ENUM_CONSTANT, RECORD_COMPONENT -> {

View File

@ -54,6 +54,7 @@ import java.util.Map;
import java.util.Set; import java.util.Set;
import java.util.function.Predicate; import java.util.function.Predicate;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import java.util.stream.Stream;
import jdk.javadoc.internal.doclets.toolkit.BaseConfiguration; import jdk.javadoc.internal.doclets.toolkit.BaseConfiguration;
import jdk.javadoc.internal.doclets.toolkit.BaseOptions; import jdk.javadoc.internal.doclets.toolkit.BaseOptions;
@ -199,7 +200,7 @@ public class VisibleMemberTable {
return visibleMembers.getOrDefault(kind, Collections.emptyList()).stream() return visibleMembers.getOrDefault(kind, Collections.emptyList()).stream()
.filter(p) .filter(p)
.collect(Collectors.toList()); .toList();
} }
/** /**
@ -408,8 +409,8 @@ public class VisibleMemberTable {
default: default:
List<Element> list = lmt.getOrderedMembers(kind).stream() List<Element> list = lmt.getOrderedMembers(kind).stream()
.filter(this::mustDocument) .filter(this::mustDocument)
.collect(Collectors.toList()); .toList();
visibleMembers.put(kind, Collections.unmodifiableList(list)); visibleMembers.put(kind, list);
break; break;
} }
} }
@ -454,19 +455,16 @@ public class VisibleMemberTable {
// Filter out members in the inherited list that are hidden // Filter out members in the inherited list that are hidden
// by this type or should not be inherited at all. // by this type or should not be inherited at all.
List<Element> list = result.stream() Stream<Element> inheritedStream = result.stream()
.filter(e -> allowInheritedMembers(e, kind, lmt)) .filter(e -> allowInheritedMembers(e, kind, lmt));
.collect(Collectors.toList());
// Prefix local results first
list.addAll(0, lmt.getOrderedMembers(kind));
// Filter out elements that should not be documented // Filter out elements that should not be documented
list = list.stream() // Prefix local results first
List<Element> list = Stream.concat(lmt.getOrderedMembers(kind).stream(), inheritedStream)
.filter(this::mustDocument) .filter(this::mustDocument)
.collect(Collectors.toList()); .toList();
visibleMembers.put(kind, Collections.unmodifiableList(list)); visibleMembers.put(kind, list);
} }
private void computeVisibleMethods(LocalMemberTable lmt) { private void computeVisibleMethods(LocalMemberTable lmt) {
@ -490,9 +488,12 @@ public class VisibleMemberTable {
// b. are overridden and should not be visible in this type // b. are overridden and should not be visible in this type
// c. are hidden in the type being considered // c. are hidden in the type being considered
// see allowInheritedMethod, which performs the above actions // see allowInheritedMethod, which performs the above actions
List<Element> 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<Element> inheritedMethodsList = inheritedMethods.stream()
.filter(e -> allowInheritedMethod((ExecutableElement) e, overriddenByTable, lmt)) .filter(e -> allowInheritedMethod((ExecutableElement) e, overriddenByTable, lmt))
.collect(Collectors.toList()); .toList();
// Filter out the local methods, that do not override or simply // Filter out the local methods, that do not override or simply
// overrides a super method, or those methods that should not // overrides a super method, or those methods that should not
@ -501,21 +502,19 @@ public class VisibleMemberTable {
OverriddenMethodInfo p = overriddenMethodTable.getOrDefault(m, null); OverriddenMethodInfo p = overriddenMethodTable.getOrDefault(m, null);
return p == null || !p.simpleOverride; return p == null || !p.simpleOverride;
}; };
List<Element> localList = lmt.getOrderedMembers(Kind.METHODS)
Stream<ExecutableElement> localStream = lmt.getOrderedMembers(Kind.METHODS)
.stream() .stream()
.map(m -> (ExecutableElement)m) .map(m -> (ExecutableElement)m)
.filter(isVisible) .filter(isVisible);
.collect(Collectors.toList());
// Merge the above lists, making sure the local methods precede the others
list.addAll(0, localList);
// Merge the above list and stream, making sure the local methods precede the others
// Final filtration of elements // Final filtration of elements
list = list.stream() List<Element> list = Stream.concat(localStream,inheritedMethodsList.stream())
.filter(this::mustDocument) .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. // Copy over overridden tables from the lineage, and finish up.
for (VisibleMemberTable pvmt : parents) { for (VisibleMemberTable pvmt : parents) {
@ -795,7 +794,7 @@ public class VisibleMemberTable {
List<Element> getPropertyMethods(String methodName, int argcount) { List<Element> getPropertyMethods(String methodName, int argcount) {
return getMembers(methodName + ":" + argcount, Kind.METHODS).stream() return getMembers(methodName + ":" + argcount, Kind.METHODS).stream()
.filter(m -> (utils.isPublic(m) || utils.isProtected(m))) .filter(m -> (utils.isPublic(m) || utils.isProtected(m)))
.collect(Collectors.toList()); .toList();
} }
} }
@ -857,17 +856,17 @@ public class VisibleMemberTable {
return; return;
PropertyUtils pUtils = config.propertyUtils; PropertyUtils pUtils = config.propertyUtils;
List<ExecutableElement> list = visibleMembers.getOrDefault(Kind.METHODS, Collections.emptyList()) List<Element> list = visibleMembers.getOrDefault(Kind.METHODS, Collections.emptyList())
.stream() .stream()
.map(m -> (ExecutableElement)m) .filter(e -> pUtils.isPropertyMethod((ExecutableElement) e))
.filter(pUtils::isPropertyMethod) .toList();
.collect(Collectors.toList());
visibleMembers.put(Kind.PROPERTIES, Collections.unmodifiableList(list)); visibleMembers.put(Kind.PROPERTIES, list);
List<ExecutableElement> propertyMethods = list.stream() List<ExecutableElement> propertyMethods = list.stream()
.map(e -> (ExecutableElement) e)
.filter(e -> utils.getEnclosingTypeElement(e) == te) .filter(e -> utils.getEnclosingTypeElement(e) == te)
.collect(Collectors.toList()); .toList();
// Compute additional properties related sundries. // Compute additional properties related sundries.
for (ExecutableElement propertyMethod : propertyMethods) { for (ExecutableElement propertyMethod : propertyMethods) {
@ -931,7 +930,7 @@ public class VisibleMemberTable {
ImplementedMethods imf = getImplementedMethodsFinder(method); ImplementedMethods imf = getImplementedMethodsFinder(method);
return imf.getImplementedMethods().stream() return imf.getImplementedMethods().stream()
.filter(m -> getSimplyOverriddenMethod(m) == null) .filter(m -> getSimplyOverriddenMethod(m) == null)
.collect(Collectors.toList()); .toList();
} }
public TypeMirror getImplementedMethodHolder(ExecutableElement method, public TypeMirror getImplementedMethodHolder(ExecutableElement method,