PCJ API
Version 1.2

bak.pcj.adapter
Class SetToBooleanSetAdapter

java.lang.Object
  extended bybak.pcj.AbstractBooleanCollection
      extended bybak.pcj.set.AbstractBooleanSet
          extended bybak.pcj.adapter.SetToBooleanSetAdapter
All Implemented Interfaces:
BooleanCollection, BooleanSet
Direct Known Subclasses:
SortedSetToBooleanSortedSetAdapter

public class SetToBooleanSetAdapter
extends AbstractBooleanSet
implements BooleanSet

This class represents adaptions of Java Collections Framework sets to primitive sets of boolean values. The adapter is implemented as a wrapper around the set. Thus, changes to the underlying set are reflected by this set and vice versa.

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:

      SetToBooleanSetAdapter s;
      ...
      assert s.validate();
  
or by letting the adapter throw an exception on illegal values:
      SetToBooleanSetAdapter 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  Set set
          The underlying set.
 
Constructor Summary
SetToBooleanSetAdapter(Set set)
          Creates a new adaption to a set of boolean values.
SetToBooleanSetAdapter(Set set, boolean validate)
          Creates a new adaption to a set of boolean values.
 
Method Summary
 boolean add(boolean v)
          Adds an element to this collection.
 void clear()
          Clears this collection.
 boolean contains(boolean v)
          Indicates whether this collection contains a specified element.
 void evalidate()
          Validates the set underlying this adapter and throws an exception if it is invalid.
 int hashCode()
          Returns a hash code value for this collection.
 BooleanIterator iterator()
          Returns an iterator over this collection.
 boolean remove(boolean v)
          Removes a specified element from this collection.
 int size()
          Returns the number of elements in this collection.
 boolean validate()
          Indicates whether the underlying set is valid for this adapter.
 
Methods inherited from class bak.pcj.set.AbstractBooleanSet
equals
 
Methods inherited from class bak.pcj.AbstractBooleanCollection
addAll, containsAll, isEmpty, removeAll, retainAll, toArray, toArray, toString, trimToSize
 
Methods inherited from class java.lang.Object
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
 
Methods inherited from interface bak.pcj.BooleanCollection
addAll, containsAll, equals, isEmpty, removeAll, retainAll, toArray, toArray, trimToSize
 

Field Detail

set

protected Set set
The underlying set.

Constructor Detail

SetToBooleanSetAdapter

public SetToBooleanSetAdapter(Set set)
Creates a new adaption to a set of boolean values.

Parameters:
set - the underlying set. This set must consist of values of class Boolean. Otherwise a ClassCastException will be thrown by some methods.
Throws:
NullPointerException - if set is null.

SetToBooleanSetAdapter

public SetToBooleanSetAdapter(Set set,
                              boolean validate)
Creates a new adaption to a set of boolean values. The set to adapt is optionally validated.

Parameters:
set - the underlying set. This set must consist of values of class Boolean. Otherwise a ClassCastException will be thrown by some methods.
validate - indicates whether set should be checked for illegal values.
Throws:
NullPointerException - if set is null.
IllegalStateException - if validate is true and set contains a null value or a value that is not of class Boolean.
Method Detail

add

public boolean add(boolean v)
Description copied from interface: BooleanCollection
Adds an element to this collection.

Specified by:
add in interface BooleanCollection
Overrides:
add in class AbstractBooleanCollection

clear

public void clear()
Description copied from interface: BooleanCollection
Clears this collection.

Specified by:
clear in interface BooleanCollection
Overrides:
clear in class AbstractBooleanCollection

contains

public boolean contains(boolean v)
Description copied from interface: BooleanCollection
Indicates whether this collection contains a specified element.

Specified by:
contains in interface BooleanCollection
Overrides:
contains in class AbstractBooleanCollection

hashCode

public int hashCode()
Description copied from interface: BooleanCollection
Returns a hash code value for this collection.

Specified by:
hashCode in interface BooleanCollection
Overrides:
hashCode in class AbstractBooleanSet

iterator

public BooleanIterator iterator()
Description copied from interface: BooleanCollection
Returns an iterator over this collection.

Specified by:
iterator in interface BooleanCollection
Returns:
an iterator over this collection.

remove

public boolean remove(boolean v)
Description copied from interface: BooleanCollection
Removes a specified element from this collection.

Specified by:
remove in interface BooleanCollection
Overrides:
remove in class AbstractBooleanCollection

size

public int size()
Description copied from interface: BooleanCollection
Returns the number of elements in this collection.

Specified by:
size in interface BooleanCollection
Overrides:
size in class AbstractBooleanCollection

validate

public boolean validate()
Indicates whether the underlying set is valid for this adapter. For the underlying set to be valid, it can only contain Boolean values and no null values.

Returns:
true if the underlying set is valid; returns false otherwise.

evalidate

public void evalidate()
Validates the set underlying this adapter and throws an exception if it is invalid. For the underlying set to be valid, it can only contain Boolean values and no null values.

Throws:
IllegalStateException - if the underlying set is invalid.

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