org.d2ab.iterable.ints.IntIterable Maven / Gradle / Ivy
Show all versions of sequence Show documentation
/*
* Copyright 2015 Daniel Skogquist Åborg
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.d2ab.iterable.ints;
import org.d2ab.iterator.ints.ArrayIntIterator;
import org.d2ab.iterator.ints.IntIterator;
import org.d2ab.util.Pair;
import java.util.Arrays;
import java.util.Iterator;
import java.util.function.Consumer;
import java.util.function.IntConsumer;
import java.util.stream.IntStream;
import java.util.stream.Stream;
import static java.util.Objects.requireNonNull;
@FunctionalInterface
public interface IntIterable extends Iterable {
/**
* Converts a container of some kind into a possibly once-only {@link IntIterable}.
*
* @param container the non-null container to turn into an {@link IntIterable}, can be one of {@link Iterable},
* {@link IntIterable}, {@link Iterator}, {@link IntIterator}, {@link Stream} of {@link
* Integer}s, {@link IntStream}, array of {@link Integer}s, or int array.
*
* @return the container as a {@link IntIterable}.
*
* @throws ClassCastException if the container is not one of the permitted classes.
*/
@SuppressWarnings("unchecked")
static IntIterable from(Object container) {
requireNonNull(container);
if (container instanceof IntIterable)
return (IntIterable) container;
else if (container instanceof Iterable)
return from((Iterable) container);
else if (container instanceof IntIterator)
return from((IntIterator) container);
else if (container instanceof Stream)
return from((Iterator) container);
else if (container instanceof IntStream)
return from((IntStream) container);
else if (container instanceof int[])
return of((int[]) container);
else if (container instanceof Integer[])
return from((Integer[]) container);
else if (container instanceof Pair)
return from(((Pair) container)::iterator);
else
throw new ClassCastException("Required an Iterable, IntIterable, Iterator, IntIterator, array of " +
"Integer, int array, Stream of Integer, or IntStream but got: " +
container.getClass());
}
static IntIterable from(Iterable iterable) {
return () -> IntIterator.from(iterable);
}
static IntIterable from(IntIterator iterator) {
return iterator.asIterable();
}
static IntIterable from(Iterator iterator) {
return () -> IntIterator.from(iterator);
}
static IntIterable from(IntStream intStream) {
return from(IntIterator.from(intStream.iterator()));
}
static IntIterable of(int... integers) {
return () -> new ArrayIntIterator(integers);
}
static IntIterable from(Integer... integers) {
return from(Arrays.asList(integers));
}
static IntIterable from(Stream stream) {
return from(stream.iterator());
}
@Override
IntIterator iterator();
/**
* {@inheritDoc}
*
* If the action is an instance of {@code IntConsumer} then it is cast to {@code IntConsumer} and passed
* to {@link #forEachInt}; otherwise the action is adapted to an instance of {@code IntConsumer}, by boxing the
* argument of {@code IntConsumer}, and then passed to {@link #forEachInt}.
*/
@Override
default void forEach(Consumer super Integer> action) {
requireNonNull(action);
forEachInt((action instanceof IntConsumer) ? (IntConsumer) action : action::accept);
}
/**
* Performs the given action for each integer in this {@code Iterable} until all elements have been processed or
* the action throws an exception. Actions are performed in the order of iteration, if that order is specified.
* Exceptions thrown by the action are relayed to the caller.
*
* @param action The action to be performed for each element
*
* @throws NullPointerException if the specified action is null
*
The default implementation behaves as if:
*
{@code
* IntIterator iterator = iterator();
* while (iterator.hasNext())
* action.accept(iterator.nextInt());
* }
*/
default void forEachInt(IntConsumer action) {
requireNonNull(action);
IntIterator iterator = iterator();
while (iterator.hasNext())
action.accept(iterator.nextInt());
}
}