ix.IxWindow Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of ixjava Show documentation
Show all versions of ixjava Show documentation
ixjava developed by David Karnok
/*
* Copyright 2011-2016 David Karnok
*
* 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 ix;
import java.util.*;
final class IxWindow extends IxSource> {
final int size;
static final Object NULL = new Object();
IxWindow(Iterable source, int size) {
super(source);
this.size = size;
}
@Override
public Iterator> iterator() {
return new WindowIterator(source.iterator(), size);
}
static final class WindowIterator extends IxSourceIterator> {
final int size;
int index;
WindowIterable current;
WindowIterator(Iterator it, int size) {
super(it);
this.size = size;
}
@Override
protected boolean moveNext() {
int i = index;
for (;;) {
if (!it.hasNext()) {
done = true;
return false;
}
T v = it.next();
WindowIterable c;
if (i++ == 0) {
if (i == size) {
index = 0;
} else {
index = i;
}
c = new WindowIterable(this, size);
current = c;
c.iterator.queue.offer(v != null ? v : NULL);
value = c;
hasValue = true;
return true;
}
current.iterator.queue.offer(v != null ? v : NULL);
if (i == size) {
i = 0;
}
}
}
boolean moveInner() {
if (!it.hasNext()) {
return false;
}
T v = it.next();
current.iterator.queue.offer(v != null ? v : NULL);
int i = index + 1;
if (i == size) {
current = null;
index = 0;
} else {
index = i;
}
return true;
}
}
static final class WindowIterable extends Ix {
final WindowInnerIterator iterator;
boolean once;
WindowIterable(WindowIterator parent, int size) {
this.iterator = new WindowInnerIterator(parent, size);
}
@Override
public Iterator iterator() {
if (!once) {
once = true;
return iterator;
}
throw new IllegalStateException("This Window Ix iterable can be consumed only once.");
}
}
static final class WindowInnerIterator extends IxBaseIterator {
final WindowIterator parent;
final ArrayDeque
© 2015 - 2025 Weber Informatics LLC | Privacy Policy