diff --git a/error-prone-contrib/src/main/java/tech/picnic/errorprone/refasterrules/ImmutableSetRules.java b/error-prone-contrib/src/main/java/tech/picnic/errorprone/refasterrules/ImmutableSetRules.java index 37feb51a1b9..a5af1a00e42 100644 --- a/error-prone-contrib/src/main/java/tech/picnic/errorprone/refasterrules/ImmutableSetRules.java +++ b/error-prone-contrib/src/main/java/tech/picnic/errorprone/refasterrules/ImmutableSetRules.java @@ -4,6 +4,7 @@ import static com.google.errorprone.refaster.ImportPolicy.STATIC_IMPORT_ALWAYS; import static java.util.Collections.emptySet; import static java.util.Collections.singleton; +import static java.util.function.Predicate.not; import com.google.common.collect.ImmutableSet; import com.google.common.collect.Multimap; @@ -215,41 +216,101 @@ ImmutableSet after(T e1, T e2, T e3, T e4, T e5) { } } - /** Prefer {@link Sets#intersection(Set, Set)} over more contrived alternatives. */ - static final class SetsIntersection { + /** + * Prefer an immutable copy of {@link Sets#difference(Set, Set)} over more contrived alternatives. + */ + static final class SetsDifference { + @BeforeTemplate + ImmutableSet before(Set set1, Set set2) { + return set1.stream() + .filter(Refaster.anyOf(not(set2::contains), e -> !set2.contains(e))) + .collect(toImmutableSet()); + } + + @AfterTemplate + ImmutableSet after(Set set1, Set set2) { + return Sets.difference(set1, set2).immutableCopy(); + } + } + + /** + * Prefer an immutable copy of {@link Sets#difference(Set, Set)} over more contrived alternatives. + */ + static final class SetsDifferenceMap { @BeforeTemplate - ImmutableSet before(Set set1, Set set2) { + ImmutableSet before(Set set, Map map) { + return set.stream() + .filter(Refaster.anyOf(not(map::containsKey), e -> !map.containsKey(e))) + .collect(toImmutableSet()); + } + + @AfterTemplate + ImmutableSet after(Set set, Map map) { + return Sets.difference(set, map.keySet()).immutableCopy(); + } + } + + /** + * Prefer an immutable copy of {@link Sets#difference(Set, Set)} over more contrived alternatives. + */ + static final class SetsDifferenceMultimap { + @BeforeTemplate + ImmutableSet before(Set set, Multimap multimap) { + return set.stream() + .filter(Refaster.anyOf(not(multimap::containsKey), e -> !multimap.containsKey(e))) + .collect(toImmutableSet()); + } + + @AfterTemplate + ImmutableSet after(Set set, Multimap multimap) { + return Sets.difference(set, multimap.keySet()).immutableCopy(); + } + } + + /** + * Prefer an immutable copy of {@link Sets#intersection(Set, Set)} over more contrived + * alternatives. + */ + static final class SetsIntersection { + @BeforeTemplate + ImmutableSet before(Set set1, Set set2) { return set1.stream().filter(set2::contains).collect(toImmutableSet()); } @AfterTemplate - ImmutableSet after(Set set1, Set set2) { + ImmutableSet after(Set set1, Set set2) { return Sets.intersection(set1, set2).immutableCopy(); } } - /** Prefer {@link Sets#intersection(Set, Set)} over more contrived alternatives. */ - static final class SetsIntersectionMap { + /** + * Prefer an immutable copy of {@link Sets#intersection(Set, Set)} over more contrived + * alternatives. + */ + static final class SetsIntersectionMap { @BeforeTemplate - ImmutableSet before(Set set, Map map) { + ImmutableSet before(Set set, Map map) { return set.stream().filter(map::containsKey).collect(toImmutableSet()); } @AfterTemplate - ImmutableSet after(Set set, Map map) { + ImmutableSet after(Set set, Map map) { return Sets.intersection(set, map.keySet()).immutableCopy(); } } - /** Prefer {@link Sets#intersection(Set, Set)} over more contrived alternatives. */ - static final class SetsIntersectionMultimap { + /** + * Prefer an immutable copy of {@link Sets#intersection(Set, Set)} over more contrived + * alternatives. + */ + static final class SetsIntersectionMultimap { @BeforeTemplate - ImmutableSet before(Set set, Multimap multimap) { + ImmutableSet before(Set set, Multimap multimap) { return set.stream().filter(multimap::containsKey).collect(toImmutableSet()); } @AfterTemplate - ImmutableSet after(Set set, Multimap multimap) { + ImmutableSet after(Set set, Multimap multimap) { return Sets.intersection(set, multimap.keySet()).immutableCopy(); } } diff --git a/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ImmutableSetRulesTestInput.java b/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ImmutableSetRulesTestInput.java index e0c426f7f12..09fdae535bd 100644 --- a/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ImmutableSetRulesTestInput.java +++ b/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ImmutableSetRulesTestInput.java @@ -1,11 +1,12 @@ package tech.picnic.errorprone.refasterrules; import static com.google.common.collect.ImmutableSet.toImmutableSet; +import static java.util.function.Predicate.not; import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableMap; -import com.google.common.collect.ImmutableMultimap; import com.google.common.collect.ImmutableSet; +import com.google.common.collect.ImmutableSetMultimap; import com.google.common.collect.Sets; import com.google.common.collect.Streams; import java.util.Arrays; @@ -17,7 +18,7 @@ final class ImmutableSetRulesTest implements RefasterRuleCollectionTestCase { @Override public ImmutableSet elidedTypesAndStaticImports() { - return ImmutableSet.of(Arrays.class, Collections.class, Streams.class); + return ImmutableSet.of(Arrays.class, Collections.class, Streams.class, not(null)); } ImmutableSet.Builder testImmutableSetBuilder() { @@ -75,18 +76,51 @@ Set testImmutableSetOf5() { return Set.of(1, 2, 3, 4, 5); } + ImmutableSet> testSetsDifference() { + return ImmutableSet.of( + ImmutableSet.of(1).stream() + .filter(not(ImmutableSet.of(2)::contains)) + .collect(toImmutableSet()), + ImmutableSet.of(3).stream() + .filter(v -> !ImmutableSet.of(4).contains(v)) + .collect(toImmutableSet())); + } + + ImmutableSet> testSetsDifferenceMap() { + return ImmutableSet.of( + ImmutableSet.of(1).stream() + .filter(not(ImmutableMap.of(2, 3)::containsKey)) + .collect(toImmutableSet()), + ImmutableSet.of(4).stream() + .filter(v -> !ImmutableMap.of(5, 6).containsKey(v)) + .collect(toImmutableSet())); + } + + ImmutableSet> testSetsDifferenceMultimap() { + return ImmutableSet.of( + ImmutableSet.of(1).stream() + .filter(not(ImmutableSetMultimap.of(2, 3)::containsKey)) + .collect(toImmutableSet()), + ImmutableSet.of(4).stream() + .filter(v -> !ImmutableSetMultimap.of(5, 6).containsKey(v)) + .collect(toImmutableSet())); + } + ImmutableSet testSetsIntersection() { - ImmutableSet set = ImmutableSet.of(1); - return ImmutableSet.of(2).stream().filter(set::contains).collect(toImmutableSet()); + return ImmutableSet.of(1).stream() + .filter(ImmutableSet.of(2)::contains) + .collect(toImmutableSet()); } ImmutableSet testSetsIntersectionMap() { - ImmutableMap map = ImmutableMap.of(1, 2); - return ImmutableSet.of(3).stream().filter(map::containsKey).collect(toImmutableSet()); + return ImmutableSet.of(1).stream() + .filter(ImmutableMap.of(2, 3)::containsKey) + .collect(toImmutableSet()); } ImmutableSet testSetsIntersectionMultimap() { - ImmutableMultimap multimap = ImmutableMultimap.of(1, 2); - return ImmutableSet.of(3).stream().filter(multimap::containsKey).collect(toImmutableSet()); + return ImmutableSet.of(1).stream() + .filter(ImmutableSetMultimap.of(2, 3)::containsKey) + .collect(toImmutableSet()); } } diff --git a/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ImmutableSetRulesTestOutput.java b/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ImmutableSetRulesTestOutput.java index 367e2e84fe1..f60aa49842e 100644 --- a/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ImmutableSetRulesTestOutput.java +++ b/error-prone-contrib/src/test/resources/tech/picnic/errorprone/refasterrules/ImmutableSetRulesTestOutput.java @@ -1,11 +1,12 @@ package tech.picnic.errorprone.refasterrules; import static com.google.common.collect.ImmutableSet.toImmutableSet; +import static java.util.function.Predicate.not; import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableMap; -import com.google.common.collect.ImmutableMultimap; import com.google.common.collect.ImmutableSet; +import com.google.common.collect.ImmutableSetMultimap; import com.google.common.collect.Sets; import com.google.common.collect.Streams; import java.util.Arrays; @@ -17,7 +18,7 @@ final class ImmutableSetRulesTest implements RefasterRuleCollectionTestCase { @Override public ImmutableSet elidedTypesAndStaticImports() { - return ImmutableSet.of(Arrays.class, Collections.class, Streams.class); + return ImmutableSet.of(Arrays.class, Collections.class, Streams.class, not(null)); } ImmutableSet.Builder testImmutableSetBuilder() { @@ -70,18 +71,35 @@ Set testImmutableSetOf5() { return ImmutableSet.of(1, 2, 3, 4, 5); } + ImmutableSet> testSetsDifference() { + return ImmutableSet.of( + Sets.difference(ImmutableSet.of(1), ImmutableSet.of(2)).immutableCopy(), + Sets.difference(ImmutableSet.of(3), ImmutableSet.of(4)).immutableCopy()); + } + + ImmutableSet> testSetsDifferenceMap() { + return ImmutableSet.of( + Sets.difference(ImmutableSet.of(1), ImmutableMap.of(2, 3).keySet()).immutableCopy(), + Sets.difference(ImmutableSet.of(4), ImmutableMap.of(5, 6).keySet()).immutableCopy()); + } + + ImmutableSet> testSetsDifferenceMultimap() { + return ImmutableSet.of( + Sets.difference(ImmutableSet.of(1), ImmutableSetMultimap.of(2, 3).keySet()).immutableCopy(), + Sets.difference(ImmutableSet.of(4), ImmutableSetMultimap.of(5, 6).keySet()) + .immutableCopy()); + } + ImmutableSet testSetsIntersection() { - ImmutableSet set = ImmutableSet.of(1); - return Sets.intersection(ImmutableSet.of(2), set).immutableCopy(); + return Sets.intersection(ImmutableSet.of(1), ImmutableSet.of(2)).immutableCopy(); } ImmutableSet testSetsIntersectionMap() { - ImmutableMap map = ImmutableMap.of(1, 2); - return Sets.intersection(ImmutableSet.of(3), map.keySet()).immutableCopy(); + return Sets.intersection(ImmutableSet.of(1), ImmutableMap.of(2, 3).keySet()).immutableCopy(); } ImmutableSet testSetsIntersectionMultimap() { - ImmutableMultimap multimap = ImmutableMultimap.of(1, 2); - return Sets.intersection(ImmutableSet.of(3), multimap.keySet()).immutableCopy(); + return Sets.intersection(ImmutableSet.of(1), ImmutableSetMultimap.of(2, 3).keySet()) + .immutableCopy(); } }