From ace3a4d196546d2bfaa21f58e50f3222085f880e Mon Sep 17 00:00:00 2001 From: Brian Goetz Date: Fri, 12 Jul 2013 15:01:08 -0700 Subject: [PATCH] 8015320: Pull spliterator() up from Collection to Iterable Reviewed-by: psandoz, mduigou --- jdk/src/share/classes/java/lang/Iterable.java | 27 +++++++++++++++++++ .../share/classes/java/util/Collection.java | 1 + .../util/ConcurrentModificationException.java | 1 + .../Spliterator/SpliteratorCollisions.java | 9 +++---- ...SpliteratorTraversingAndSplittingTest.java | 15 +++++++++++ 5 files changed, 48 insertions(+), 5 deletions(-) diff --git a/jdk/src/share/classes/java/lang/Iterable.java b/jdk/src/share/classes/java/lang/Iterable.java index 8d46dbfe5ff..fe9086f6874 100644 --- a/jdk/src/share/classes/java/lang/Iterable.java +++ b/jdk/src/share/classes/java/lang/Iterable.java @@ -26,6 +26,8 @@ package java.lang; import java.util.Iterator; import java.util.Objects; +import java.util.Spliterator; +import java.util.Spliterators; import java.util.function.Consumer; /** @@ -72,5 +74,30 @@ public interface Iterable { action.accept(t); } } + + /** + * Creates a {@link Spliterator} over the elements described by this + * {@code Iterable}. + * + * @implSpec + * The default implementation creates an + * early-binding + * spliterator from the iterable's {@code Iterator}. The spliterator + * inherits the fail-fast properties of the iterable's iterator. + * + * @implNote + * The default implementation should usually be overridden. The + * spliterator returned by the default implementation has poor splitting + * capabilities, is unsized, and does not report any spliterator + * characteristics. Implementing classes can nearly always provide a + * better implementation. + * + * @return a {@code Spliterator} over the elements described by this + * {@code Iterable}. + * @since 1.8 + */ + default Spliterator spliterator() { + return Spliterators.spliteratorUnknownSize(iterator(), 0); + } } diff --git a/jdk/src/share/classes/java/util/Collection.java b/jdk/src/share/classes/java/util/Collection.java index d42ba3e8a6e..17ab7347dc0 100644 --- a/jdk/src/share/classes/java/util/Collection.java +++ b/jdk/src/share/classes/java/util/Collection.java @@ -537,6 +537,7 @@ public interface Collection extends Iterable { * @return a {@code Spliterator} over the elements in this collection * @since 1.8 */ + @Override default Spliterator spliterator() { return Spliterators.spliterator(this, 0); } diff --git a/jdk/src/share/classes/java/util/ConcurrentModificationException.java b/jdk/src/share/classes/java/util/ConcurrentModificationException.java index 3683fb399cf..d5256538f04 100644 --- a/jdk/src/share/classes/java/util/ConcurrentModificationException.java +++ b/jdk/src/share/classes/java/util/ConcurrentModificationException.java @@ -57,6 +57,7 @@ package java.util; * @author Josh Bloch * @see Collection * @see Iterator + * @see Spliterator * @see ListIterator * @see Vector * @see LinkedList diff --git a/jdk/test/java/util/Spliterator/SpliteratorCollisions.java b/jdk/test/java/util/Spliterator/SpliteratorCollisions.java index 604d90b9f20..e40ef916d46 100644 --- a/jdk/test/java/util/Spliterator/SpliteratorCollisions.java +++ b/jdk/test/java/util/Spliterator/SpliteratorCollisions.java @@ -48,7 +48,6 @@ import java.util.Spliterator; import java.util.TreeSet; import java.util.function.Consumer; import java.util.function.Function; -import java.util.function.LongConsumer; import java.util.function.Supplier; import java.util.function.UnaryOperator; @@ -677,11 +676,11 @@ public class SpliteratorCollisions { private static Map toBoxedMultiset(Iterable c) { Map result = new HashMap<>(); - c.forEach((Consumer) e -> { - if (result.containsKey((T)e)) { - result.put((T)e, new HashableInteger(((HashableInteger)result.get(e)).value + 1, 10)); + c.forEach(e -> { + if (result.containsKey(e)) { + result.put(e, new HashableInteger(result.get(e).value + 1, 10)); } else { - result.put((T)e, new HashableInteger(1, 10)); + result.put(e, new HashableInteger(1, 10)); } }); return result; diff --git a/jdk/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java b/jdk/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java index d58c2b9d544..6da6214e1ca 100644 --- a/jdk/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java +++ b/jdk/test/java/util/Spliterator/SpliteratorTraversingAndSplittingTest.java @@ -321,6 +321,21 @@ public class SpliteratorTraversingAndSplittingTest { db.addCollection( c -> new AbstractSortedSetImpl(c)); + class IterableWrapper implements Iterable { + final Iterable it; + + IterableWrapper(Iterable it) { + this.it = it; + } + + @Override + public Iterator iterator() { + return it.iterator(); + } + } + db.add("new Iterable.spliterator()", + () -> new IterableWrapper(exp).spliterator()); + // db.add("Arrays.asList().spliterator()",