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

net.sf.staccatocommons.collections.stream.impl.internal.delayed.ConsStream Maven / Gradle / Ivy

/*
 Copyright (c) 2011, The Staccato-Commons Team

 This program is free software; you can redistribute it and/or modify
 it under the terms of the GNU Lesser General Public License as published by
 the Free Software Foundation; version 3 of the License.

 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 Lesser General Public License for more details.
 */
package net.sf.staccatocommons.collections.stream.impl.internal.delayed;

import java.util.NoSuchElementException;

import net.sf.staccatocommons.collections.stream.Stream;
import net.sf.staccatocommons.defs.Thunk;
import net.sf.staccatocommons.iterators.thriter.AdvanceThriterator;
import net.sf.staccatocommons.iterators.thriter.Thriterator;
import net.sf.staccatocommons.lang.tuple.Pair;
import net.sf.staccatocommons.restrictions.check.NonNull;

/**
 * A {@link DelayedPrependStream} that iterates through its elements by
 * iteratively splitting it in head and tail.
 * 
 * @author flbulgarelli
 * 
 * @param 
 */
public final class ConsStream extends DelayedPrependStream {

  /**
   * Creates a new {@link ConsStream}
   */
  public ConsStream(@NonNull Thunk head, Stream tail) {
    super(head, tail);
  }

  public Thriterator iterator() {
    return new AdvanceThriterator() {

      private Thunk current = null;
      private Stream next = ConsStream.this;
      private boolean hasNext = true;

      public boolean hasNext() {

        return hasNext;
      }

      public void advanceNext() throws NoSuchElementException {
        if (!hasNext())
          throw new NoSuchElementException();
        Pair, Stream> decons = next.delayedDecons();
        current = decons.first();
        next = decons.second();
        hasNext = !next.isEmpty();
      }

      public A current() {
        return current.value();
      }

      public Thunk delayedCurrent() {
        return current;
      }
    };
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy