ListIterator Class Reference

Class used to iterate the items of a list. More...

#include <yateclass.h>

List of all members.

Public Member Functions

 ListIterator (ObjList &list)
 ListIterator (HashList &list)
 ~ListIterator ()
unsigned int length () const
GenObjectget (unsigned int index) const
GenObjectget ()
bool eof () const
void reset ()

Detailed Description

Class used to iterate the items of a list.

An ObjList or HashList iterator that can be used even when list elements are changed while iterating. Note that it will not detect that an item was removed and another with the same address was inserted back in list.


Constructor & Destructor Documentation

ListIterator ( ObjList list  ) 

Constructor used to iterate trough an ObjList. The image of the list is frozen at the time the constructor executes

Parameters:
list List to get the objects from
ListIterator ( HashList list  ) 

Constructor used to iterate trough a HashList. The image of the list is frozen at the time the constructor executes

Parameters:
list List to get the objects from
~ListIterator (  ) 

Destructor - frees the allocated memory


Member Function Documentation

bool eof (  )  const [inline]

Check if the current pointer is past the end of the list

Returns:
True if there are no more entries left
GenObject* get (  ) 

Get the current element and advance the current index. Items that were removed from list or are not alive are skipped over. An example of typical usage:

 ListIterator iter(list);
 while (GenObject* obj = iter.get()) {
     do_something_with(obj);
 }
 
Returns:
Pointer to a list item or NULL if advanced past end (eof)
GenObject* get ( unsigned int  index  )  const

Get an arbitrary element in the iterator's list image. Items that were removed from list or are not alive are not returned.

Parameters:
index Position to get the item from
Returns:
Pointer to the list item or NULL if out of range or item removed
unsigned int length (  )  const [inline]

Get the number of elements in the list

Returns:
Count of items in the internal list
void reset (  )  [inline]

Reset the iterator index to the first position in the list


The documentation for this class was generated from the following file:
Generated on Thu Apr 8 18:19:41 2010 for Yate by  doxygen 1.6.3