PCJ API
Version 1.2

bak.pcj.adapter
Class ListIteratorToByteListIteratorAdapter

java.lang.Object
  extended bybak.pcj.adapter.ListIteratorToByteListIteratorAdapter
All Implemented Interfaces:
ByteIterator, ByteListIterator

public class ListIteratorToByteListIteratorAdapter
extends Object
implements ByteListIterator

This class represents adaptions of Java Collections Framework list iterators to primitive list iterators over byte values.

Adapters from JCF collections to primitive collections will fail if the JCF collection contains null values or values of the wrong class. However, adapters are not fast failing in the case that the underlying collection should contain illegal values. To implement fast failure would require every operation to check every element of the underlying collection before doing anything. Instead validation methods are provided. They can be called using the assertion facility in the client code:

      CollectionToByteCollectionAdapter s;
      ...
      assert s.validate();
  
or by letting the adapter throw an exception on illegal values:
      CollectionToByteCollectionAdapter s;
      ...
      s.evalidate();  // Throws an exception on illegal values
  
Either way, validation must be invoked directly by the client code.

Since:
1.0

Field Summary
protected  ListIterator iterator
          The underlying iterator.
 
Constructor Summary
ListIteratorToByteListIteratorAdapter(ListIterator iterator)
          Creates a new adaption of a list iterator to a primitive list iterator over byte values.
 
Method Summary
 void add(byte v)
          Adds a specified element to the list at this iterator's current position.
 boolean hasNext()
          Indicates whether more byte values can be returned by this iterator.
 boolean hasPrevious()
          Indicates whether more byte values can be returned by this iterator by calling previous().
 byte next()
          Returns the next byte value of this iterator.
 int nextIndex()
          Returns the index of the element that would be returned by a call to next().
 byte previous()
          Returns the previous byte value of this iterator.
 int previousIndex()
          Returns the index of the element that would be returned by a call to previous().
 void remove()
          Removes the last byte value returned from the underlying collection.
 void set(byte v)
          Sets the last element returned to a specified value.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

iterator

protected ListIterator iterator
The underlying iterator.

Constructor Detail

ListIteratorToByteListIteratorAdapter

public ListIteratorToByteListIteratorAdapter(ListIterator iterator)
Creates a new adaption of a list iterator to a primitive list iterator over byte values.

Parameters:
iterator - the iterator to adapt to a primitive iterator.
Throws:
NullPointerException - if iterator is null.
Method Detail

add

public void add(byte v)
Description copied from interface: ByteListIterator
Adds a specified element to the list at this iterator's current position.

Specified by:
add in interface ByteListIterator
Parameters:
v - the element to add.

hasNext

public boolean hasNext()
Description copied from interface: ByteIterator
Indicates whether more byte values can be returned by this iterator.

Specified by:
hasNext in interface ByteIterator
Returns:
true if more byte values can be returned by this iterator; returns false otherwise.
See Also:
ByteIterator.next()

hasPrevious

public boolean hasPrevious()
Description copied from interface: ByteListIterator
Indicates whether more byte values can be returned by this iterator by calling previous().

Specified by:
hasPrevious in interface ByteListIterator
Returns:
true if more byte values can be returned by this iterator in backwards direction; returns false otherwise.
See Also:
ByteListIterator.previous()

next

public byte next()
Description copied from interface: ByteIterator
Returns the next byte value of this iterator.

Specified by:
next in interface ByteIterator
Returns:
the next byte value of this iterator.
See Also:
ByteIterator.hasNext()

nextIndex

public int nextIndex()
Description copied from interface: ByteListIterator
Returns the index of the element that would be returned by a call to next().

Specified by:
nextIndex in interface ByteListIterator
Returns:
the index of the element that would be returned by a call to next().
See Also:
ByteIterator.next()

previous

public byte previous()
Description copied from interface: ByteListIterator
Returns the previous byte value of this iterator.

Specified by:
previous in interface ByteListIterator
Returns:
the previous byte value of this iterator.
See Also:
ByteListIterator.hasPrevious()

previousIndex

public int previousIndex()
Description copied from interface: ByteListIterator
Returns the index of the element that would be returned by a call to previous().

Specified by:
previousIndex in interface ByteListIterator
Returns:
the index of the element that would be returned by a call to previous(); if no more elements are available in backwards direction, -1 is returned.
See Also:
ByteListIterator.previous()

remove

public void remove()
Description copied from interface: ByteIterator
Removes the last byte value returned from the underlying collection.

Specified by:
remove in interface ByteIterator

set

public void set(byte v)
Description copied from interface: ByteListIterator
Sets the last element returned to a specified value.

Specified by:
set in interface ByteListIterator
Parameters:
v - the new value of the element.

PCJ API
Version 1.2

Report a bug or request a feature.
Further information on the development and latest release of PCJ can be found at the project homepage.

Primitive Collections for Java is released under the GNU Lesser General Public License.
Copyright © 2002, 2003 Søren Bak. All Rights Reserved.

Hosted by SourceForge.net
SourceForge.net Logo