All Packages  Class Hierarchy  This Package  Previous  Next  Index
  Class jdsl.core.ref.VCSVectorCircularSequence
java.lang.Object
   |
   +----jdsl.core.ref.VCSVectorCircularSequence
  -  public class VCSVectorCircularSequence
  -  extends Object
  -  implements CircularSequence
A CircularSequence implemented with a java.util.Vector.
 In particular, since Vector allocates a new array and copies the old array
 into the new one whenever it runs out of space, calls like
 vec_.insertElementAt(object,index) are NOT constant-time operations.
   
  -   VCSVectorCircularSequence() VCSVectorCircularSequence()
-   Constructs a new sequence with an initial capacity of 12.
  
-   VCSVectorCircularSequence(int) VCSVectorCircularSequence(int)
-   Constructs a new sequence with an underlying Vector of size
 initialCapacity.
-   VCSVectorCircularSequence(int, int) VCSVectorCircularSequence(int, int)
-   Constructs a new sequence with an underlying Vector of size
 initialCapacity.
   
  -   after(Position) after(Position)
-   Gets the Positionafter a givenPositionin
 thisCircularSequence.
-   before(Position) before(Position)
-   Gets the Positionbefore a givenPositionin
 thisCircularSequence
-   elements() elements()
-   Returns an Enumerationof all the elements stored in this
 container.
-   insertAfter(Position, Object) insertAfter(Position, Object)
-   Inserts an element after a given position.
  
-   insertBefore(Position, Object) insertBefore(Position, Object)
-   Inserts an element before a given position.
  
-   insertInitial(Object) insertInitial(Object)
-  
 Inserts an element into an empty CircularSequence.
-   isEmpty() isEmpty()
-   Tests if this container is empty.
  
-   newContainer() newContainer()
-   Constructs a new CircularNodeSequence.
-   positions() positions()
-   Returns all the positions in this container.
  
-   remove(Position) remove(Position)
-   Removes the specified position.
  
-   replace(Position, Object) replace(Position, Object)
-  
 Replace the element at the specified position with a new element.
  
-   size() size()
-   Gets the number of elements in this container.
  
-   splice(Position, CircularSequence, Position) splice(Position, CircularSequence, Position)
-  
 Merges in another CircularNodeSequenceafter a given
 position.
-   split(Position, Position) split(Position, Position)
-  
 Snips out a chain of nodes from this CircularSequence,repairs thisCircularSequence,and makes a newCircularSequencewith the snipped-out nodes.
-   startingPosition() startingPosition()
-   Returns an arbitrary starting Positionin thisCircularSequence.
-   swap(Position, Position) swap(Position, Position)
-   Swaps the elements at two specified positions.
   
 VCSVectorCircularSequence
VCSVectorCircularSequence
 public VCSVectorCircularSequence()
  -  Constructs a new sequence with an initial capacity of 12.
 
 VCSVectorCircularSequence
VCSVectorCircularSequence
 public VCSVectorCircularSequence(int initialCapacity)
  -  Constructs a new sequence with an underlying Vector of size
 initialCapacity.
 
 VCSVectorCircularSequence
VCSVectorCircularSequence
 public VCSVectorCircularSequence(int initialCapacity,
                                  int capacityIncrement)
  -  Constructs a new sequence with an underlying Vector of size
 initialCapacity.  Every time the Vector resizes, it
 increases bycapicityIncrement.
 
   
 before
before
 public Position before(Position successor) throws InvalidPositionException
  -  Gets the Positionbefore a givenPositionin
 thisCircularSequence
   
- 
    -  Parameters:
    
-  successor - Any Positionin thisSequence.
-  Returns:
    
-  The Positionbeforesuccessor.
-  Throws: InvalidPositionException
    
-  if Positionis
 invalid, from a different container, ornull.
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 after
after
 public Position after(Position predecessor) throws InvalidPositionException
  -  Gets the Positionafter a givenPositionin
 thisCircularSequence.
   
- 
    -  Parameters:
    
-  predecessor - Any Positionin thisSequence.
-  Returns:
    
-  The Positionbeforepredecessor.
-  Throws: InvalidPositionException
    
-  if Positionis
 invalid, from a different container, ornull.
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 startingPosition
startingPosition
 public Position startingPosition() throws EmptyContainerException
  -  Returns an arbitrary starting Positionin thisCircularSequence.  Note:There is no guarantee what
 position this method returns, nor is there any guarantee that it remains
 static.
   
- 
    -  Returns:
    
-  an arbitrary Positionin this container.
-  Throws: EmptyContainerException
    
-  if this container is empty.
    
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 insertBefore
insertBefore
 public Position insertBefore(Position p,
                              Object element) throws InvalidPositionException
  -  Inserts an element before a given position.
   
- 
    -  Parameters:
    
-  p - The Positionto insert before.
-  element - The element to insert.
    
-  Returns:
    
-  the Positionholding the new element.
-  Throws: InvalidPositionException
    
-  if Positionis
 invalid, from a different container, ornull.
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 insertAfter
insertAfter
 public Position insertAfter(Position p,
                             Object element) throws InvalidPositionException
  -  Inserts an element after a given position.
   
- 
    -  Parameters:
    
-  p - The Positionto insert after.
-  element - The element to insert.
    
-  Returns:
    
-  the Positionholding the new element.
-  Throws: InvalidPositionException
    
-  if Positionis
 invalid, from a different container, ornull.
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 insertInitial
insertInitial
 public Position insertInitial(Object element)
  -  Inserts an element into an empty CircularSequence. The
 counterpart to startingPosition:  intended for use only in an empty
 circular sequence, where there is no position before or after which you
 can insert.
   
- 
    -  Parameters:
    
-  element - Any Object
-  Returns:
    
-  Positionof the object inserted
-  Throws: NotEmptyContainerException
    
-  if this sequence is not empty.
    
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 remove
remove
 public Object remove(Position p) throws EmptyContainerException, InvalidPositionException
  -  Removes the specified position.
   
- 
    -  Parameters:
    
-  p - The Positionof the element after the element to
 be removed.
-  Returns:
    
-  The removed element.
    
-  Throws: EmptyContainerException
    
-  If there are no elements in this
 container.
    
-  Throws: InvalidPositionException
    
-  if pisnullor not in thisCircularSequence
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 split
split
 public CircularSequence split(Position inNewA,
                               Position inNewB) throws EmptyContainerException, InvalidPositionException
  -  Snips out a chain of nodes from this CircularSequence,repairs thisCircularSequence,and makes a newCircularSequencewith the snipped-out nodes.  IfinNewA==inNewB,only that one Position is removed from thisCircularSequence.@param inNewA Start of sequence ofPositionsto be removed from thisCircularSequence.  This method takes constant time.
   
- 
    -  Parameters:
    
-  inNewA - Beginning of sequence of Positionsto be
 removed from.
-  inNewB - End of sequence of Positionsto be removed from
 thisCircularSequence.
-  Returns:
    
-  A new CircularSequenceholdinginNewA,inNewB,and all thePositionsbetween them
-  Throws: EmptyContainerException
    
-  if this container is empty.
    
-  Throws: InvalidPositionException
    
-  if inNewAorinNewBisnull, from a different container, or
 of an incompatible type.
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 splice
splice
 public void splice(Position afterWhich,
                    CircularSequence toMerge,
                    Position newSuccessor)
  -  Merges in another CircularNodeSequenceafter a given
 position.  That is, thisCircularNodeSequenceis snipped
 after a givenPosition,and the merged-inCircularSequenceis snipped before a given Position.toMergewill be invalidated
 after this method returns.  This method takes constant time.
   
- 
    -  Parameters:
    
-  afterWhich - Positionafter which to break thisCircularSequence
-  toMerge - CircularSequenceto be spliced into this one
-  newSuccessor - Positionfrom toMerge that will followPositionafterWhich from thisCircularSequence.
-  Throws: InvalidContainerException
    
-  If this container is invalid or if
 toMerge is invalid or of an incompatible type.
    -  Throws: InvalidArgumentException
    
-  if toMergeis the same
 container asspliceis called on.
-  Throws: InvalidPositionException
    
-  if afterWhichornewSuccessoris either null, or of the wrong type.
-  See Also:
    
-  size
  
 
 positions
positions
 public Enumeration positions()
  -  Returns all the positions in this container.
   
- 
    -  Returns:
    
-  An Enumerationof all positions in this container.
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 replace
replace
 public Object replace(Position p,
                       Object newElement) throws InvalidPositionException
  -  Replace the element at the specified position with a new element.
   
- 
    -  Parameters:
    
-  p - position at which the replacement is to occur
    -  newElement - new element to be stored at position p
    
-  Returns:
    
-  old element formerly stored at position p
    
-  Throws: InvalidPositionException
    
-  is thrown if the specified position
 does not belong to the container or if the position is null.
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 swap
swap
 public void swap(Position a,
                  Position b) throws InvalidPositionException
  -  Swaps the elements at two specified positions.
   
- 
    -  Parameters:
    
-  p - first position participating in the swap.
    -  q - second position participating in the swap.
    
-  Throws: InvalidPositionException
    
-  if thrown if on or both of the specified
 Positionsdoes not belong to this implementation ofContainer,or if eitherPositionisnull.
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 size
size
 public int size() throws InvalidContainerException
  -  Gets the number of elements in this container.  Each element is counted a
 number of times according to its multiplicity.  This is a linear time
 operation.
   
- 
    -  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 isEmpty
isEmpty
 public boolean isEmpty()
  -  Tests if this container is empty.
   
- 
    -  Returns:
    
-  trueif this container is empty,falseotherwise.
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 newContainer
newContainer
 public Container newContainer()
  -  Constructs a new CircularNodeSequence.
   
- 
    -  Returns:
    
-  a new, empty container identical to this one.
    
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
 elements
elements
 public Enumeration elements()
  -  Returns an Enumerationof all the elements stored in this
 container.  Duplicated elements appear as many times as they are in the
 container.  Elements are returned in the order they are inserted.
   
- 
    -  Returns:
    
-  An Enumerationof all elements in the container.
-  Throws: InvalidContainerException
    
-  if this container has been
 invalidated.
    
-  See Also:
    
-  splice
  
 
All Packages  Class Hierarchy  This Package  Previous  Next  Index