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

groovy.stream.iterators.CollatingIterator Maven / Gradle / Ivy

Go to download

A collection of classes to give a fluent builder for Streams (Lazy Groovy Generators).

The newest version!
/*
 * Copyright 2013-2014 the original author or authors.
 *
 * 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 groovy.stream.iterators ;

import java.util.ArrayList ;
import java.util.Collection ;
import java.util.Iterator ;
import java.util.LinkedList ;
import java.util.List ;
import java.util.Queue ;
import java.util.NoSuchElementException ;

public class CollatingIterator extends AbstractIterator> {
    private final Queue> cache = new LinkedList>() ;
    private Iterator parent ;
    private int         size ;
    private int         step ;
    private boolean     keepRemainder ;
    private int         index = 0 ;

    public CollatingIterator( Iterator parent, int size ) {
        this( parent, size, size, true ) ;
    }

    public CollatingIterator( Iterator parent, int size, int step ) {
        this( parent, size, step, true ) ;
    }

    public CollatingIterator( Iterator parent, int size, boolean keepRemainder ) {
        this( parent, size, size, keepRemainder ) ;
    }

    public CollatingIterator( Iterator parent, int size, int step, boolean keepRemainder ) {
        super( null ) ;
        if( size < 1 ) {
            throw new IllegalArgumentException( "Collation size must be > 1" ) ;
        }
        if( step < 1 ) {
            throw new IllegalArgumentException( "Step size must be > 1" ) ;
        }
        this.parent = parent ;
        this.size = size ;
        this.step = step ;
        this.keepRemainder = keepRemainder ;
    }

    private void addElementToEachCachedList( T next ) {
        for( Collection item : cache ) {
            item.add( next ) ;
        }
    }

    private boolean isFinished() {
        if( !keepRemainder && ( current == null || current.size() < size ) ) {
            return true ;
        }
        return current == null && !parent.hasNext();
    }

    @Override
    protected void loadNext() {
        while( parent.hasNext() ) {
            T next = parent.next() ;
            if( index % step == 0 ) {
                cache.offer( new ArrayList() ) ;
            }
            index++ ;
            addElementToEachCachedList( next ) ;
            if( cache.peek().size() == size ) {
                break ;
            }
        }
        current = cache.poll() ;
        if( isFinished() ) {
            exhausted = true ;
        }
    }

    @Override
    public Collection next() {
        hasNext() ;
        if( exhausted ) {
            throw new NoSuchElementException( "CollatingIterator has been exhausted and contains no more elements" ) ;
        }
        List ret = new ArrayList( current ) ;
        loaded = false ;
        return ret ;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy