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

org.osgl.util.ZippedListIterator Maven / Gradle / Ivy

The newest version!
package org.osgl.util;

/*-
 * #%L
 * Java Tool
 * %%
 * Copyright (C) 2014 - 2017 OSGL (Open Source General Library)
 * %%
 * 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.
 * #L%
 */

import org.osgl.$;

import java.util.ListIterator;
import java.util.NoSuchElementException;

public class ZippedListIterator implements ListIterator<$.Binary> {
    private ListIterator a;
    private ListIterator b;
    private $.Option defA = $.none();
    private $.Option defB = $.none();

    ZippedListIterator(ListIterator a, ListIterator b) {
        E.NPE(a, b);
        this.a = a;
        this.b = b;
    }

    ZippedListIterator(ListIterator a, ListIterator b, A defA, B defB) {
        this(a, b);
        this.defA = $.some(defA);
        this.defB = $.some(defB);
    }

    @Override
    public boolean hasNext() {
        boolean hasA = a.hasNext(), hasB = b.hasNext();
        if (hasA && hasB) {
            return true;
        }
        if (defA.isDefined()) {
            return hasA || hasB;
        } else {
            return false;
        }
    }

    @Override
    public boolean hasPrevious() {
        boolean hasA = a.hasPrevious(), hasB = b.hasPrevious();
        if (hasA && hasB) {
            return true;
        }
        if (defA.isDefined()) {
            return hasA || hasB;
        } else {
            return false;
        }
    }

    @Override
    public $.T2 next() {
        boolean hasA = a.hasNext(), hasB = b.hasNext();
        if (hasA && hasB) {
            return $.T2(a.next(), b.next());
        }
        if (defA.isDefined()) {
            if (hasA) {
                return $.T2(a.next(), defB.get());
            } else if (hasB) {
                return $.T2(defA.get(), b.next());
            } else {
                throw new NoSuchElementException();
            }
        } else {
            throw new NoSuchElementException();
        }
    }

    @Override
    public $.T2 previous() {
        boolean hasA = a.hasPrevious(), hasB = b.hasPrevious();
        if (hasA && hasB) {
            return $.T2(a.previous(), b.previous());
        }
        if (defA.isDefined()) {
            if (hasA) {
                return $.T2(a.previous(), defB.get());
            } else if (hasB) {
                return $.T2(defA.get(), b.previous());
            } else {
                throw new NoSuchElementException();
            }
        } else {
            throw new NoSuchElementException();
        }
    }

    @Override
    public int nextIndex() {
        int idA = a.nextIndex(), idB = b.nextIndex();
        if (defA.isDefined()) {
            return Math.max(idA, idB);
        } else {
            return Math.min(idA, idB);
        }
    }

    @Override
    public int previousIndex() {
        int idA = a.previousIndex(), idB = b.previousIndex();
        if (defA.isDefined()) {
            return Math.max(idA, idB);
        } else {
            return Math.min(idA, idB);
        }
    }

    @Override
    public void set($.Binary abt2) {
        throw new UnsupportedOperationException();
    }

    @Override
    public void add($.Binary abt2) {
        throw new UnsupportedOperationException();
    }

    @Override
    public void remove() {
        throw new UnsupportedOperationException();
    }
}