/* * #%L * gitools-core * %% * Copyright (C) 2013 Universitat Pompeu Fabra - Biomedical Genomics group * %% * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public * License along with this program. If not, see * <http://www.gnu.org/licenses/gpl-3.0.html>. * #L% */ package org.gitools.matrix.model.iterable; import org.gitools.api.matrix.IMatrixPredicate; import java.util.Iterator; import java.util.NoSuchElementException; public class FilterIterable<T> extends AbstractChainIterable<T, T> { private IMatrixPredicate<T> filter; public FilterIterable(AbstractIterable<T> parentIterable, IMatrixPredicate<T> filter) { super(parentIterable); this.filter = filter; } @Override public Iterator<T> iterator() { return new FilterIterator(newParentIterator()); } private class FilterIterator extends AbstractChainIterator<T, T> { private boolean hasNext = false; private T nextValue; public FilterIterator(Iterator<T> parentIterator) { super(parentIterator); } @Override public boolean hasNext() { if (super.hasNext()) { nextValue = parentNext(); while (!filter.apply(nextValue, getPosition())) { if (!super.hasNext()) { hasNext = false; return hasNext; } nextValue = parentNext(); } hasNext = true; } else { hasNext = false; } return hasNext; } @Override public T next() { if (!hasNext && !hasNext()) { throw new NoSuchElementException(); } return nextValue; } } }