/*
* ModeShape (http://www.modeshape.org)
*
* 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.modeshape.jcr.cache.document;
import java.util.Iterator;
import java.util.NoSuchElementException;
/**
* An iterator that presents the union of two iterators. The second iterator is retrieved only when needed.
*
* @param <Type> the value type of the iterator
*/
public class UnionIterator<Type> implements Iterator<Type> {
private final Iterable<Type> next;
private Iterator<Type> current;
private boolean useNext;
/**
* Create a union iterator
*
* @param firstIterator the first iterator; may not be null
* @param next the Iterable from which the second iterator is to be obtained; may be null
*/
public UnionIterator( Iterator<Type> firstIterator,
Iterable<Type> next ) {
this.next = next;
this.current = firstIterator;
this.useNext = this.next != null;
}
@Override
public boolean hasNext() {
boolean nextValue = current.hasNext();
if (!nextValue && useNext) {
current = next.iterator();
useNext = false;
nextValue = current.hasNext();
}
return nextValue;
}
@Override
public Type next() {
if (current.hasNext()) {
// At least one more on the current iterator ...
return current.next();
}
// The current iterator has no more ...
if (useNext) {
// We have another iterator ...
current = next.iterator();
useNext = false;
return current.next();
}
// No more iterators ...
throw new NoSuchElementException();
}
@Override
public void remove() {
current.remove();
}
}