All Downloads are FREE. Search and download functionalities are using the official Maven repository.

ix.IxReplaySize Maven / Gradle / Ivy

There is a newer version: 1.0.0
Show newest version
/*
 * 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.Iterator;

final class IxReplaySize extends IxSource {

    final int maxSize;

    Iterator it;

    Node head;

    Node tail;

    int size;

    IxReplaySize(Iterable source, int maxSize) {
        super(source);
        this.maxSize = maxSize;
        this.head = this.tail = new Node(null);
    }

    @Override
    public Iterator iterator() {
        if (it == null) {
            it = source.iterator();
        }
        return new ReplaySizeIterator(this, head);
    }

    boolean moveNext() {
        if (!it.hasNext()) {
            return false;
        }

        Node n = new Node(it.next());
        tail.next = n;
        tail = n;

        int s = size;
        if (s != maxSize) {
            size = s + 1;
        } else {
            head = head.next;
        }
        return true;
    }

    static final class Node {
        final T value;

        Node next;

        Node(T value) {
            this.value = value;
        }
    }

    static final class ReplaySizeIterator extends IxBaseIterator {
        final IxReplaySize parent;

        Node node;

        ReplaySizeIterator(IxReplaySize parent, Node node) {
            this.parent = parent;
            this.node = node;
        }

        @Override
        protected boolean moveNext() {
            Node n = node;

            if (n.next == null) {
                if (!parent.moveNext()) {
                    done = true;
                    return false;
                }
            }
            n = n.next;

            value = n.value;
            hasValue = true;
            node = n;

            return true;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy