jmud-0.11/
jmud-0.11/bin/
jmud-0.11/doc/
jmud-0.11/rec/
jmud-0.11/rec/mun/
jmud-0.11/rec/mun/grecia/
jmud-0.11/rec/mun/gunnar/
jmud-0.11/rec/qua/
jmud-0.11/src/bool/
jmud-0.11/src/clone/
jmud-0.11/src/integer/
jmud-0.11/src/misc/
jmud-0.11/src/string/
jmud-0.11/src/util/bit/
jmud-0.11/src/util/color/
jmud-0.11/src/util/file/
jmud-0.11/src/util/jgp/adaptor/
jmud-0.11/src/util/jgp/algorithm/
jmud-0.11/src/util/jgp/container/
jmud-0.11/src/util/jgp/functor/
jmud-0.11/src/util/jgp/interfaces/
jmud-0.11/src/util/jgp/predicate/
jmud-0.11/src/util/log/
jmud-0.11/src/util/state/
jmud-0.11/trash/
package util.list;

import java.util.NoSuchElementException;

public class QueueIterator implements Iterator {

  private Queue    myQueue = null;
  private ListLink cursor  = null;

  QueueIterator(Queue aQueue) {
    myQueue = aQueue;
    start();
  }

  public void start() {
    cursor = myQueue.getHead();
  }

  public boolean cont() {
    return cursor != null;
  }

  public void next() {
    cursor = cursor.getNext();
  }

  public Object getCurrent() {
    return cursor.getInfo();
  }

  public Object getNext() throws NoSuchElementException {
    if (!hasNext())
      throw new NoSuchElementException();
    
    return cursor.getNext().getInfo();
  }

  public boolean hasNext() {
    return (cont() && cursor.getNext() != null);
  }

  public void insertNext(Object info) {
    cursor.setNext(new ListLink(info, cursor.getNext()));

    ListLink last = myQueue.getTail().getNext();

    if (last != null)
      myQueue.setTail(last);
  }

  public void removeNext() throws NoSuchElementException {
    if (!hasNext())
      throw new NoSuchElementException();

    ListLink next = cursor.getNext();

    if (myQueue.getTail() == next)
      myQueue.setTail(cursor);

    cursor.setNext(next.getNext());
  }
}