#include <Containers_T.h>
Inheritance diagram for ACE_DLList_Reverse_Iterator< T >:
Public Member Functions | |
ACE_DLList_Reverse_Iterator (ACE_DLList< T > &l) | |
void | reset (ACE_DLList< T > &l) |
int | advance (void) |
int | next (T *&) |
T * | next (void) const |
int | remove (void) |
void | dump (void) const |
Delegates to ACE_Double_Linked_List_Iterator. | |
Private Attributes | |
ACE_DLList< T > * | list_ |
Friends | |
class | ACE_DLList< T > |
class | ACE_DLList_Node |
This implementation uses ACE_Double_Linked_List_Iterator to perform the logic behind this container class. It delegates all of its calls to ACE_Double_Linked_List_Iterator.
Definition at line 1150 of file Containers_T.h.
ACE_INLINE ACE_DLList_Reverse_Iterator< T >::ACE_DLList_Reverse_Iterator | ( | ACE_DLList< T > & | l | ) |
Definition at line 433 of file Containers_T.inl.
00434 : ACE_Double_Linked_List_Reverse_Iterator <ACE_DLList_Node> ((ACE_DLList_Base &)l), 00435 list_ (&l) 00436 { 00437 }
ACE_INLINE int ACE_DLList_Reverse_Iterator< T >::advance | ( | void | ) |
Move forward by one element in the list. Returns 0 when all the items in the list have been seen, else 1.
Reimplemented from ACE_Double_Linked_List_Reverse_Iterator< T >.
Definition at line 447 of file Containers_T.inl.
References ACE_Double_Linked_List_Reverse_Iterator< ACE_DLList_Node >::advance().
00448 { 00449 return ACE_Double_Linked_List_Reverse_Iterator <ACE_DLList_Node>::advance (); 00450 }
ACE_INLINE void ACE_DLList_Reverse_Iterator< T >::dump | ( | void | ) | const |
Delegates to ACE_Double_Linked_List_Iterator.
Reimplemented from ACE_Double_Linked_List_Reverse_Iterator< T >.
Definition at line 472 of file Containers_T.inl.
References ACE_Double_Linked_List_Reverse_Iterator< ACE_DLList_Node >::dump().
00473 { 00474 #if defined (ACE_HAS_DUMP) 00475 ACE_Double_Linked_List_Reverse_Iterator <ACE_DLList_Node>::dump (); 00476 #endif /* ACE_HAS_DUMP */ 00477 }
ACE_INLINE T * ACE_DLList_Reverse_Iterator< T >::next | ( | void | ) | const |
Reimplemented from ACE_Double_Linked_List_Iterator_Base< T >.
Definition at line 464 of file Containers_T.inl.
References ACE_DLList_Node::item_, and ACE_Double_Linked_List_Iterator_Base< T >::next().
00465 { 00466 ACE_DLList_Node *temp = ACE_Double_Linked_List_Reverse_Iterator <ACE_DLList_Node>::next (); 00467 return (T *) (temp ? temp->item_ : 0); 00468 }
ACE_INLINE int ACE_DLList_Reverse_Iterator< T >::next | ( | T *& | ) |
Pass back the {next_item} that hasn't been seen in the list. Returns 0 when all items have been seen, else 1.
Definition at line 453 of file Containers_T.inl.
References ACE_DLList_Node::item_, and ACE_Double_Linked_List_Iterator_Base< T >::next().
00454 { 00455 ACE_DLList_Node *temp = 00456 ACE_Double_Linked_List_Reverse_Iterator <ACE_DLList_Node>::next (); 00457 if (temp == 0) 00458 return 0; 00459 ptr = (T *) temp->item_; 00460 return 1; 00461 }
ACE_INLINE int ACE_DLList_Reverse_Iterator< T >::remove | ( | void | ) |
Removes the current item (i.e., {next}) from the list. Note that DLList iterators do not support {advance_and_remove} directly (defined in its base class) and you will need to release the element returned by it.
Definition at line 425 of file Containers_T.inl.
References ACE_Double_Linked_List_Reverse_Iterator< ACE_DLList_Node >::advance(), ACE_DLList_Reverse_Iterator< T >::list_, and ACE_Double_Linked_List_Iterator_Base< T >::next().
00426 { 00427 ACE_DLList_Node *temp = ACE_Double_Linked_List_Reverse_Iterator <ACE_DLList_Node>::next (); 00428 this->ACE_Double_Linked_List_Reverse_Iterator <ACE_DLList_Node>::advance (); 00429 return list_->remove (temp); 00430 }
ACE_INLINE void ACE_DLList_Reverse_Iterator< T >::reset | ( | ACE_DLList< T > & | l | ) |
Retasks the iterator to iterate over a new Double_Linked_List. This allows clients to reuse an iterator without incurring the constructor overhead. If you do use this, be aware that if there are more than one reference to this iterator, the other "clients" may be very bothered when their iterator changes. @ Here be dragons. Comments?
Definition at line 440 of file Containers_T.inl.
References ACE_DLList_Reverse_Iterator< T >::list_, and ACE_Double_Linked_List_Reverse_Iterator< ACE_DLList_Node >::reset().
00441 { 00442 list_ = &l; 00443 this->ACE_Double_Linked_List_Reverse_Iterator <ACE_DLList_Node>::reset ((ACE_DLList_Base &)l); 00444 }
friend class ACE_DLList< T > [friend] |
Definition at line 1153 of file Containers_T.h.
friend class ACE_DLList_Node [friend] |
Definition at line 1154 of file Containers_T.h.
ACE_DLList<T>* ACE_DLList_Reverse_Iterator< T >::list_ [private] |
Definition at line 1194 of file Containers_T.h.
Referenced by ACE_DLList_Reverse_Iterator< T >::remove(), and ACE_DLList_Reverse_Iterator< T >::reset().