From d0551d01b3d7e97aa5d8fb1ec91e648a93dab929 Mon Sep 17 00:00:00 2001 From: dota17 Date: Tue, 22 Oct 2019 09:55:26 +0800 Subject: [PATCH 1/3] [COLLECTIONS-708] Add hashcode method to CollectionUtils that supports an equator parameter --- .../commons/collections4/CollectionUtils.java | 26 ++++++++++ .../collections4/CollectionUtilsTest.java | 49 ++++++++++++++++++- 2 files changed, 74 insertions(+), 1 deletion(-) diff --git a/src/main/java/org/apache/commons/collections4/CollectionUtils.java b/src/main/java/org/apache/commons/collections4/CollectionUtils.java index 2b73511a7..7f7d6bc7e 100644 --- a/src/main/java/org/apache/commons/collections4/CollectionUtils.java +++ b/src/main/java/org/apache/commons/collections4/CollectionUtils.java @@ -643,6 +643,32 @@ public class CollectionUtils { return isEqualCollection(collect(a, transformer), collect(b, transformer)); } + /** + * Returns the hash code the the input collection using the hash method of the equator. + *

+ * If the input collection is null return 0. + *

+ * + * @param the element type + * @param collection the input collection + * @param equator the equator used for generate hashCode + * @return the hashCode of Collection through the hash method of Equator + * @throws NullPointerException if the equator is null + * @since 4.5 + */ + public static int hashCode(final Collection collection, + final Equator equator) { + Objects.requireNonNull(equator, "equator"); + if (null == collection) { + return 0; + } + int hashCode = 1; + for (final E e : collection) { + hashCode = 31 * hashCode + equator.hash(e); + } + return hashCode; + } + /** * Wraps another object and uses the provided Equator to implement * {@link #equals(Object)} and {@link #hashCode()}. diff --git a/src/test/java/org/apache/commons/collections4/CollectionUtilsTest.java b/src/test/java/org/apache/commons/collections4/CollectionUtilsTest.java index 7d1bd98f2..4922a9176 100644 --- a/src/test/java/org/apache/commons/collections4/CollectionUtilsTest.java +++ b/src/test/java/org/apache/commons/collections4/CollectionUtilsTest.java @@ -37,6 +37,7 @@ import java.util.Iterator; import java.util.LinkedList; import java.util.List; import java.util.Map; +import java.util.Objects; import java.util.Queue; import java.util.Set; import java.util.SortedMap; @@ -741,6 +742,52 @@ public class CollectionUtilsTest extends MockTestCase { CollectionUtils.isEqualCollection(collectionA, collectionA, null); } + @Test + public void testHashCode() { + final Equator e = new Equator() { + @Override + public boolean equate(final Integer o1, final Integer o2) { + if (o1 % 2 == 0 ^ o2 % 2 == 0) { + return false; + } + return true; + } + + @Override + public int hash(final Integer o) { + return o == null ? 0 : Objects.hashCode(o); + } + }; + + assertEquals(collectionA.hashCode(), CollectionUtils.hashCode(collectionA, e)); + } + + @Test + public void testHashCodeNullCollection() { + final Equator e = new Equator() { + @Override + public boolean equate(final Integer o1, final Integer o2) { + if (o1 % 2 == 0 ^ o2 % 2 == 0) { + return false; + } + return true; + } + + @Override + public int hash(final Integer o) { + return o == null ? 0 : Objects.hashCode(o); + } + }; + + final Collection collection = null; + assertEquals(0, CollectionUtils.hashCode(collection, e)); + } + + @Test(expected=NullPointerException.class) + public void testHashCodeNullEquator() { + CollectionUtils.hashCode(collectionB, null); + } + @Test(expected = NullPointerException.class) public void testIsEqualCollectionNullColl1() { final Collection list = new ArrayList<>(1); @@ -1073,7 +1120,7 @@ public class CollectionUtilsTest extends MockTestCase { CollectionUtils.get(array, 2); } - @Test(expected=IllegalArgumentException.class) + @Test(expected = IllegalArgumentException.class) public void getFromObject() throws Exception { // Invalid object final Object obj = new Object(); From 8d6f5ae3bdf24c1a924d58efd5c8ebac89daa36a Mon Sep 17 00:00:00 2001 From: "Bruno P. Kinoshita" Date: Thu, 20 Aug 2020 20:33:04 +1200 Subject: [PATCH 2/3] [COLLECTIONS-708] Formatting and update javadocs --- .../apache/commons/collections4/CollectionUtils.java | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/src/main/java/org/apache/commons/collections4/CollectionUtils.java b/src/main/java/org/apache/commons/collections4/CollectionUtils.java index 7f7d6bc7e..4c2f4167f 100644 --- a/src/main/java/org/apache/commons/collections4/CollectionUtils.java +++ b/src/main/java/org/apache/commons/collections4/CollectionUtils.java @@ -644,20 +644,21 @@ public class CollectionUtils { } /** - * Returns the hash code the the input collection using the hash method of the equator. + * Returns the hash code of the input collection using the hash method of an equator. + * *

- * If the input collection is null return 0. + * Returns 0 if the input collection is {@code null}. *

* * @param the element type * @param collection the input collection * @param equator the equator used for generate hashCode - * @return the hashCode of Collection through the hash method of Equator - * @throws NullPointerException if the equator is null + * @return the hash code of the input collection using the hash method of an equator + * @throws NullPointerException if the equator is {@code null} * @since 4.5 */ public static int hashCode(final Collection collection, - final Equator equator) { + final Equator equator) { Objects.requireNonNull(equator, "equator"); if (null == collection) { return 0; From 28bd7432bb7bd6c093fc837935057ba4d5f73d61 Mon Sep 17 00:00:00 2001 From: "Bruno P. Kinoshita" Date: Thu, 20 Aug 2020 20:35:49 +1200 Subject: [PATCH 3/3] [COLLECTIONS-708] changelog --- src/changes/changes.xml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/changes/changes.xml b/src/changes/changes.xml index c7d8c988b..0da4fbd19 100644 --- a/src/changes/changes.xml +++ b/src/changes/changes.xml @@ -21,6 +21,9 @@ + + Add hashCode method to CollectionUtils that supports an equator parameter. + Fix checkstyle issues regarding missing newline at end of file, and CRLF vs LF.