Skip to content

Commit

Permalink
Suggestions
Browse files Browse the repository at this point in the history
  • Loading branch information
Stephan202 committed Aug 10, 2024
1 parent 2c2d0df commit 47016e5
Show file tree
Hide file tree
Showing 6 changed files with 32 additions and 25 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,9 @@
import com.google.errorprone.refaster.annotation.AfterTemplate;
import com.google.errorprone.refaster.annotation.AlsoNegation;
import com.google.errorprone.refaster.annotation.BeforeTemplate;
import com.google.errorprone.refaster.annotation.NotMatches;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Iterator;
import java.util.List;
Expand All @@ -21,6 +23,7 @@
import java.util.function.IntFunction;
import java.util.stream.Stream;
import tech.picnic.errorprone.refaster.annotation.OnlineDocumentation;
import tech.picnic.errorprone.refaster.matchers.IsRefasterAsVarargs;

/** Refaster rules related to expressions dealing with (arbitrary) collections. */
// XXX: There are other Guava `Iterables` methods that should not be called if the input is known to
Expand Down Expand Up @@ -294,6 +297,23 @@ String after(ImmutableCollection<T> collection) {
}
}

/** Prefer {@link Arrays#asList(Object[])} over more contrived alternatives. */
// XXX: Consider moving this rule to `ImmutableListRules` and having it suggest
// `ImmutableList#copyOf`. That would retain immutability, at the cost of no longer handling
// `null`s.
static final class ArraysAsList<T> {
// XXX: This expression produces an unmodifiable list, while the alternative doesn't.
@BeforeTemplate
List<T> before(@NotMatches(IsRefasterAsVarargs.class) T[] array) {
return Arrays.stream(array).toList();
}

@AfterTemplate
List<T> after(T[] array) {
return Arrays.asList(array);
}
}

/** Prefer calling {@link Collection#toArray()} over more contrived alternatives. */
static final class CollectionToArray<T> {
@BeforeTemplate
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,6 @@
import java.util.Comparator;
import java.util.DoubleSummaryStatistics;
import java.util.IntSummaryStatistics;
import java.util.List;
import java.util.LongSummaryStatistics;
import java.util.Map;
import java.util.Objects;
Expand Down Expand Up @@ -123,21 +122,6 @@ Stream<T> after(T[] array) {
}
}

/**
* Prefer {@link Arrays#asList(Object[])} over {@link Stream#toList()} as the former is clearer.
*/
static final class ArraysAsList<T> {
@BeforeTemplate
List<T> before(@NotMatches(IsRefasterAsVarargs.class) T[] array) {
return Arrays.stream(array).toList();
}

@AfterTemplate
List<T> after(T[] array) {
return Arrays.asList(array);
}
}

/** Don't unnecessarily call {@link Streams#concat(Stream...)}. */
static final class ConcatOneStream<T> {
@BeforeTemplate
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,11 @@
import com.google.common.collect.Iterables;
import com.google.common.collect.Lists;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.Optional;
import java.util.TreeSet;
import java.util.stream.Stream;
Expand Down Expand Up @@ -98,6 +100,10 @@ String testImmutableCollectionToString() {
return ImmutableSet.of(1).asList().toString();
}

List<String> testArraysAsList() {
return Arrays.stream(new String[0]).toList();
}

ImmutableSet<Object[]> testCollectionToArray() {
return ImmutableSet.of(
ImmutableSet.of(1).toArray(new Object[1]),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,9 +6,11 @@
import com.google.common.collect.Iterables;
import com.google.common.collect.Lists;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashSet;
import java.util.Iterator;
import java.util.LinkedList;
import java.util.List;
import java.util.Optional;
import java.util.TreeSet;
import java.util.stream.Stream;
Expand Down Expand Up @@ -90,6 +92,10 @@ String testImmutableCollectionToString() {
return ImmutableSet.of(1).toString();
}

List<String> testArraysAsList() {
return Arrays.asList(new String[0]);
}

ImmutableSet<Object[]> testCollectionToArray() {
return ImmutableSet.of(
ImmutableSet.of(1).toArray(), ImmutableSet.of(2).toArray(), ImmutableSet.of(3).toArray());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,6 @@
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.ImmutableSet;
import com.google.common.collect.Streams;
import java.util.Arrays;
import java.util.DoubleSummaryStatistics;
import java.util.IntSummaryStatistics;
import java.util.List;
Expand Down Expand Up @@ -87,10 +86,6 @@ Stream<String> testStreamOfArray() {
return Stream.of(new String[] {"foo", "bar"});
}

List<String> testArraysAsList() {
return Arrays.stream(new String[] {"foo", "bar"}).toList();
}

Stream<Integer> testConcatOneStream() {
return Streams.concat(Stream.of(1));
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -87,10 +87,6 @@ Stream<String> testStreamOfArray() {
return Arrays.stream(new String[] {"foo", "bar"});
}

List<String> testArraysAsList() {
return Arrays.asList(new String[] {"foo", "bar"});
}

Stream<Integer> testConcatOneStream() {
return Stream.of(1);
}
Expand Down

0 comments on commit 47016e5

Please sign in to comment.