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

gw.lang.reflect.interval.IIterableInterval Maven / Gradle / Ivy

There is a newer version: 1.18.2
Show newest version
/*
 * Copyright 2014 Guidewire Software, Inc.
 */

package gw.lang.reflect.interval;

import java.util.Iterator;

public interface IIterableInterval, S, U, ME extends IIterableInterval> extends Iterable, IInterval
{
  /**
   * @return An iterator that visits the elements in this interval in order, from left to right.
   *   Returns null if this interval does not support iteration.
   *
   * @see #iterateFromLeft()
   * @see #iterateFromRight()
   */
  Iterator iterator();

  /**
   * @return An iterator that visits the elements in this interval in order, from left to right.
   *   Returns null if this interval does not support iteration.
   *
   * @see #iterator()
   * @see #iterateFromRight()
   */
  Iterator iterateFromLeft();

  /**
   * @return An iterator that visits the elements in this interval in reverse order, from right to left.
   *   Returns null if this interval does not support iteration.
   *
   * @see #iterator()
   * @see #iterateFromLeft()
   */
  Iterator iterateFromRight();

  /**
   * @return The step (or increment) by which this interval visits elements in its set. Returns null
   *   if this interval cannot iterate its elements.
   * 

* For instance, if the interval is a set of decimal values, say [1..10], the step might be a decimal * increment, say 0.25. Similarly, if the interval is simply a set of integers the step might also be * an integer value, typically 1. Considering a date interval, say [4/5/10..5/20/10], the step could * be expressed in terms of a unit of time e.g., 10 seconds, 1 minute, 2 weeks, etc. *

* Note if non-null, the step is a positive (or absolute) increment. To iterate the interval * in reverse order use iterateFromRight(). */ S getStep(); ME step( S s ); U getUnit(); ME unit( U u ); /** * @param iStepIndex The index of the step from the left endpoint * @return The nth step from the left endpoint. Returns null if iStepIndex is out of bounds. * @thows IllegalArgumentException if iStepIndex is < 0 */ E getFromLeft( int iStepIndex ); /** * @param iStepIndex The index of the step from the right endpoint * @return The nth step from the right endpoint. Returns null if iStepIndex is out of bounds. * @thows IllegalArgumentException if iStepIndex is < 0 */ E getFromRight( int iStepIndex ); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy