#include <Containers_T.h>
Inheritance diagram for ACE_Double_Linked_List_Iterator_Base< T >:
Public Member Functions | |
int | next (T *&) const |
T * | next (void) const |
int | done (void) const |
Returns 1 when all items have been seen, else 0. | |
T & | operator * (void) const |
void | reset (ACE_Double_Linked_List< T > &) |
Public Attributes | |
ACE_ALLOC_HOOK_DECLARE | |
Declare the dynamic allocation hooks. | |
Protected Member Functions | |
ACE_Double_Linked_List_Iterator_Base (const ACE_Double_Linked_List< T > &) | |
Constructor. | |
ACE_Double_Linked_List_Iterator_Base (const ACE_Double_Linked_List_Iterator_Base< T > &iter) | |
Copy constructor. | |
int | go_head (void) |
int | go_tail (void) |
T * | not_done (void) const |
T * | do_advance (void) |
T * | do_retreat (void) |
void | dump_i (void) const |
Dump the state of an object. | |
Protected Attributes | |
T * | current_ |
Remember where we are. | |
const ACE_Double_Linked_List< T > * | dllist_ |
Definition at line 556 of file Containers_T.h.
ACE_Double_Linked_List_Iterator_Base< T >::ACE_Double_Linked_List_Iterator_Base | ( | const ACE_Double_Linked_List< T > & | ) | [protected] |
ACE_Double_Linked_List_Iterator_Base< T >::ACE_Double_Linked_List_Iterator_Base | ( | const ACE_Double_Linked_List_Iterator_Base< T > & | iter | ) | [protected] |
T * ACE_Double_Linked_List_Iterator_Base< T >::do_advance | ( | void | ) | [protected] |
Advance to the next element in the list. Return the address of the next element if there are more, 0 otherwise.
Definition at line 419 of file Containers_T.cpp.
References ACE_Double_Linked_List_Iterator_Base< T >::not_done().
Referenced by ACE_Double_Linked_List_Iterator< T >::advance(), ACE_Double_Linked_List_Iterator< T >::advance_and_remove(), ACE_Double_Linked_List_Iterator< T >::operator++(), and ACE_Double_Linked_List_Reverse_Iterator< T >::operator--().
00420 { 00421 if (this->not_done ()) 00422 { 00423 this->current_ = static_cast<T*> (this->current_->next_); 00424 return this->not_done (); 00425 } 00426 else 00427 return 0; 00428 }
T * ACE_Double_Linked_List_Iterator_Base< T >::do_retreat | ( | void | ) | [protected] |
Retreat to the previous element in the list. Return the address of the previous element if there are more, 0 otherwise.
Definition at line 431 of file Containers_T.cpp.
References ACE_Double_Linked_List_Iterator_Base< T >::not_done().
Referenced by ACE_Double_Linked_List_Reverse_Iterator< T >::advance(), ACE_Double_Linked_List_Reverse_Iterator< T >::advance_and_remove(), ACE_Double_Linked_List_Reverse_Iterator< T >::operator++(), and ACE_Double_Linked_List_Iterator< T >::operator--().
00432 { 00433 if (this->not_done ()) 00434 { 00435 this->current_ = static_cast<T*> (this->current_->prev_); 00436 return this->not_done (); 00437 } 00438 else 00439 return 0; 00440 }
int ACE_Double_Linked_List_Iterator_Base< T >::done | ( | void | ) | const |
Returns 1 when all items have been seen, else 0.
Definition at line 375 of file Containers_T.cpp.
References ACE_Double_Linked_List_Iterator_Base< T >::not_done().
Referenced by ACE_Thread_Manager::apply_all(), ACE_Thread_Manager::apply_grp(), ACE_Thread_Manager::apply_task(), ACE_Thread_Manager::dump(), ACE_Thread_Manager::find_hthread(), ACE_Thread_Manager::find_task(), ACE_Thread_Manager::find_thread(), ACE_Double_Linked_List< T >::get(), ACE_Thread_Manager::hthread_grp_list(), ACE_Thread_Manager::hthread_list(), ACE_Thread_Manager::hthread_within(), ACE_Thread_Manager::join(), ACE_Thread_Manager::num_tasks_in_group(), ACE_Thread_Manager::num_threads_in_task(), ACE_Thread_Manager::set_grp(), ACE_Thread_Manager::task_all_list(), ACE_Thread_Manager::task_list(), ACE_Thread_Manager::thread_all_list(), ACE_Thread_Manager::thread_grp_list(), ACE_Thread_Manager::thread_list(), ACE_Thread_Manager::thread_within(), ACE_Thread_Manager::wait(), ACE_Thread_Manager::wait_grp(), and ACE_Thread_Manager::wait_task().
00376 { 00377 return this->not_done () ? 0 : 1; 00378 }
void ACE_Double_Linked_List_Iterator_Base< T >::dump_i | ( | void | ) | const [protected] |
Dump the state of an object.
Definition at line 443 of file Containers_T.cpp.
References ACE_BEGIN_DUMP, ACE_DEBUG, ACE_END_DUMP, ACE_TEXT, and LM_DEBUG.
Referenced by ACE_Fixed_Set_Const_Iterator< T, ACE_SIZE >::dump(), ACE_Fixed_Set_Iterator< T, ACE_SIZE >::dump(), ACE_Double_Linked_List_Reverse_Iterator< T >::dump(), and ACE_Double_Linked_List_Iterator< T >::dump().
00444 { 00445 ACE_DEBUG ((LM_DEBUG, ACE_BEGIN_DUMP, this)); 00446 ACE_DEBUG ((LM_DEBUG, ACE_TEXT ("current_ = %x"), this->current_)); 00447 ACE_DEBUG ((LM_DEBUG, ACE_END_DUMP)); 00448 }
int ACE_Double_Linked_List_Iterator_Base< T >::go_head | ( | void | ) | [protected] |
Move to the first element of the list. Returns 0 if the list is empty, else 1.
Definition at line 396 of file Containers_T.cpp.
References ACE_Double_Linked_List_Iterator_Base< T >::current_, and ACE_Double_Linked_List_Iterator_Base< T >::dllist_.
Referenced by ACE_Double_Linked_List_Iterator< T >::first().
00397 { 00398 this->current_ = static_cast<T*> (dllist_->head_->next_); 00399 return this->current_ ? 1 : 0; 00400 }
int ACE_Double_Linked_List_Iterator_Base< T >::go_tail | ( | void | ) | [protected] |
Move to the last element of the list. Returns 0 if the list is empty, else 1.
Definition at line 403 of file Containers_T.cpp.
References ACE_Double_Linked_List_Iterator_Base< T >::current_, and ACE_Double_Linked_List_Iterator_Base< T >::dllist_.
Referenced by ACE_Double_Linked_List_Reverse_Iterator< T >::first().
00404 { 00405 this->current_ = static_cast<T*> (dllist_->head_->prev_); 00406 return this->current_ ? 1 : 0; 00407 }
T * ACE_Double_Linked_List_Iterator_Base< T >::next | ( | void | ) | const |
Reimplemented in ACE_DLList_Iterator< T >, and ACE_DLList_Reverse_Iterator< T >.
Definition at line 361 of file Containers_T.cpp.
References ACE_Double_Linked_List_Iterator_Base< T >::not_done().
Referenced by ACE_Double_Linked_List_Reverse_Iterator< T >::advance_and_remove(), ACE_Double_Linked_List_Iterator< T >::advance_and_remove(), ACE_DLList_Reverse_Iterator< T >::next(), and ACE_DLList_Reverse_Iterator< T >::remove().
00362 { 00363 return this->not_done (); 00364 }
int ACE_Double_Linked_List_Iterator_Base< T >::next | ( | T *& | ) | const |
Passes back the {entry} under the iterator. Returns 0 if the iteration has completed, otherwise 1
Definition at line 367 of file Containers_T.cpp.
References ACE_Double_Linked_List_Iterator_Base< T >::not_done().
Referenced by ACE_Thread_Manager::apply_all(), ACE_Thread_Manager::apply_grp(), ACE_Thread_Manager::apply_task(), ACE_Thread_Manager::dump(), ACE_Thread_Manager::find_hthread(), ACE_Thread_Manager::find_task(), ACE_Thread_Manager::find_thread(), ACE_Double_Linked_List< T >::get(), ACE_Thread_Manager::hthread_grp_list(), ACE_Thread_Manager::hthread_list(), ACE_Thread_Manager::hthread_within(), ACE_Thread_Manager::join(), ACE_Thread_Manager::num_tasks_in_group(), ACE_Thread_Manager::num_threads_in_task(), ACE_Thread_Manager::set_grp(), ACE_Thread_Manager::task_all_list(), ACE_Thread_Manager::task_list(), ACE_Thread_Manager::thread_all_list(), ACE_Thread_Manager::thread_grp_list(), ACE_Thread_Manager::thread_list(), ACE_Thread_Manager::thread_within(), ACE_Thread_Manager::wait(), ACE_Thread_Manager::wait_grp(), and ACE_Thread_Manager::wait_task().
00368 { 00369 ptr = this->not_done (); 00370 return ptr ? 1 : 0; 00371 }
T * ACE_Double_Linked_List_Iterator_Base< T >::not_done | ( | void | ) | const [protected] |
Check if we reach the end of the list. Can also be used to get the *current* element in the list. Return the address of the current item if there are still elements left , 0 if we run out of element.
Definition at line 410 of file Containers_T.cpp.
References ACE_Double_Linked_List_Iterator_Base< T >::current_.
Referenced by ACE_Double_Linked_List_Iterator_Base< T >::do_advance(), ACE_Double_Linked_List_Iterator_Base< T >::do_retreat(), ACE_Double_Linked_List_Iterator_Base< T >::done(), ACE_Double_Linked_List_Iterator_Base< T >::next(), and ACE_Double_Linked_List_Iterator_Base< T >::operator *().
00411 { 00412 if (this->current_ != this->dllist_->head_) 00413 return this->current_; 00414 else 00415 return 0; 00416 }
T & ACE_Double_Linked_List_Iterator_Base< T >::operator * | ( | void | ) | const |
STL-like iterator dereference operator: returns a reference to the node underneath the iterator.
Definition at line 381 of file Containers_T.cpp.
References ACE_Double_Linked_List_Iterator_Base< T >::not_done().
00382 { 00383 return *(this->not_done ()); 00384 }
void ACE_Double_Linked_List_Iterator_Base< T >::reset | ( | ACE_Double_Linked_List< T > & | ) |
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?
Reimplemented in ACE_Double_Linked_List_Iterator< T >, ACE_Double_Linked_List_Reverse_Iterator< T >, and ACE_Double_Linked_List_Iterator< ACE_DLList_Node >.
Definition at line 389 of file Containers_T.cpp.
References ACE_Double_Linked_List_Iterator_Base< T >::current_, and ACE_Double_Linked_List_Iterator_Base< T >::dllist_.
ACE_Double_Linked_List_Iterator_Base< T >::ACE_ALLOC_HOOK_DECLARE |
Declare the dynamic allocation hooks.
Reimplemented in ACE_Double_Linked_List_Iterator< T >, ACE_Double_Linked_List_Reverse_Iterator< T >, ACE_Double_Linked_List_Iterator< ACE_DLList_Node >, and ACE_Double_Linked_List_Reverse_Iterator< ACE_DLList_Node >.
Definition at line 589 of file Containers_T.h.
T* ACE_Double_Linked_List_Iterator_Base< T >::current_ [protected] |
Remember where we are.
Definition at line 635 of file Containers_T.h.
Referenced by ACE_Double_Linked_List_Iterator< T >::ACE_Double_Linked_List_Iterator(), ACE_Double_Linked_List_Reverse_Iterator< T >::ACE_Double_Linked_List_Reverse_Iterator(), ACE_Double_Linked_List_Iterator_Base< T >::go_head(), ACE_Double_Linked_List_Iterator_Base< T >::go_tail(), ACE_Double_Linked_List_Iterator_Base< T >::not_done(), ACE_Double_Linked_List_Reverse_Iterator< T >::reset(), ACE_Double_Linked_List_Iterator< T >::reset(), and ACE_Double_Linked_List_Iterator_Base< T >::reset().
const ACE_Double_Linked_List<T>* ACE_Double_Linked_List_Iterator_Base< T >::dllist_ [protected] |
Definition at line 637 of file Containers_T.h.
Referenced by ACE_Double_Linked_List_Reverse_Iterator< T >::advance_and_remove(), ACE_Double_Linked_List_Iterator< T >::advance_and_remove(), ACE_Double_Linked_List_Iterator_Base< T >::go_head(), ACE_Double_Linked_List_Iterator_Base< T >::go_tail(), and ACE_Double_Linked_List_Iterator_Base< T >::reset().