/* * Strongback * Copyright 2015, Strongback and individual contributors by the @authors tag. * See the COPYRIGHT.txt in the distribution for a full listing of individual * contributors. * * Licensed under the MIT License; you may not use this file except in * compliance with the License. You may obtain a copy of the License at * http://opensource.org/licenses/MIT * 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.strongback.util; import java.util.Iterator; import java.util.NoSuchElementException; /** * Utility class for constructing custom iterators. * * @author Randall Hauch */ public final class Iterators { /** * Create an immutable iterator around the supplied {@link Iterable} object. * * @param iterable the iterable object * @return an immutable iterator, or an {@link #empty() empty} iterator if {@code iterable} is null * @param <T> the type of element to iterate over */ public static <T> Iterator<T> immutable(Iterable<T> iterable) { return iterable != null ? immutable(iterable.iterator()) : empty(); } /** * Create an immutable iterator around the supplied {@link Iterator}. * * @param iterator the existing iterator * @return an immutable iterator, or an {@link #empty() empty} iterator if {@code iterable} is null * @param <T> the type of element to iterate over */ public static <T> Iterator<T> immutable(Iterator<T> iterator) { return iterator == null ? empty() : new Iterator<T>() { @Override public boolean hasNext() { return iterator.hasNext(); } @Override public T next() { return iterator.next(); } }; } /** * Create an empty iterator. * * @return the empty iterator; never null * @param <T> the type of element to iterate over */ public static <T> Iterator<T> empty() { return new Iterator<T>() { @Override public boolean hasNext() { return false; } @Override public T next() { throw new NoSuchElementException(); } }; } private Iterators() { } }