package it.unimi.dsi.fastutil.longs;
import java.util.Iterator;
import java.util.NoSuchElementException;
public final class LongBigListIterators {
private LongBigListIterators() {
}
public static class EmptyBigListIterator implements LongBigListIterator, java.io.Serializable, Cloneable {
private static final long serialVersionUID = -7046029254386353129L;
protected EmptyBigListIterator() {
}
@Override
public boolean hasNext() {
return false;
}
@Override
public boolean hasPrevious() {
return false;
}
@Override
public long nextLong() {
throw new NoSuchElementException();
}
@Override
public long previousLong() {
throw new NoSuchElementException();
}
@Override
public long nextIndex() {
return 0;
}
@Override
public long previousIndex() {
return -1;
}
@Override
public long skip(long n) {
return 0;
};
@Override
public long back(long n) {
return 0;
};
@Override
public Object clone() {
return EMPTY_BIG_LIST_ITERATOR;
}
private Object readResolve() {
return EMPTY_BIG_LIST_ITERATOR;
}
}
public static final EmptyBigListIterator EMPTY_BIG_LIST_ITERATOR = new EmptyBigListIterator();
private static class SingletonBigListIterator implements LongBigListIterator {
private final long element;
private int curr;
public SingletonBigListIterator(final long element) {
this.element = element;
}
@Override
public boolean hasNext() {
return curr == 0;
}
@Override
public boolean hasPrevious() {
return curr == 1;
}
@Override
public long nextLong() {
if (!hasNext())
throw new NoSuchElementException();
curr = 1;
return element;
}
@Override
public long previousLong() {
if (!hasPrevious())
throw new NoSuchElementException();
curr = 0;
return element;
}
@Override
public long nextIndex() {
return curr;
}
@Override
public long previousIndex() {
return curr - 1;
}
}
public static LongBigListIterator singleton(final long element) {
return new SingletonBigListIterator(element);
}
public static class UnmodifiableBigListIterator implements LongBigListIterator {
protected final LongBigListIterator i;
public UnmodifiableBigListIterator(final LongBigListIterator i) {
this.i = i;
}
@Override
public boolean hasNext() {
return i.hasNext();
}
@Override
public boolean hasPrevious() {
return i.hasPrevious();
}
@Override
public long nextLong() {
return i.nextLong();
}
@Override
public long previousLong() {
return i.previousLong();
}
@Override
public long nextIndex() {
return i.nextIndex();
}
@Override
public long previousIndex() {
return i.previousIndex();
}
}
public static LongBigListIterator unmodifiable(final LongBigListIterator i) {
return new UnmodifiableBigListIterator(i);
}
public static class BigListIteratorListIterator implements LongBigListIterator {
protected final LongListIterator i;
protected BigListIteratorListIterator(final LongListIterator i) {
this.i = i;
}
private int intDisplacement(long n) {
if (n < Integer.MIN_VALUE || n > Integer.MAX_VALUE)
throw new IndexOutOfBoundsException("This big iterator is restricted to 32-bit displacements");
return (int) n;
}
@Override
public void set(long ok) {
i.set(ok);
}
@Override
public void add(long ok) {
i.add(ok);
}
@Override
public int back(int n) {
return i.back(n);
}
@Override
public long back(long n) {
return i.back(intDisplacement(n));
}
@Override
public void remove() {
i.remove();
}
@Override
public int skip(int n) {
return i.skip(n);
}
@Override
public long skip(long n) {
return i.skip(intDisplacement(n));
}
@Override
public boolean hasNext() {
return i.hasNext();
}
@Override
public boolean hasPrevious() {
return i.hasPrevious();
}
@Override
public long nextLong() {
return i.nextLong();
}
@Override
public long previousLong() {
return i.previousLong();
}
@Override
public long nextIndex() {
return i.nextIndex();
}
@Override
public long previousIndex() {
return i.previousIndex();
}
}
public static LongBigListIterator asBigListIterator(final LongListIterator i) {
return new BigListIteratorListIterator(i);
}
}