diff options
Diffstat (limited to 'ace/Containers.cpp')
-rw-r--r-- | ace/Containers.cpp | 60 |
1 files changed, 39 insertions, 21 deletions
diff --git a/ace/Containers.cpp b/ace/Containers.cpp index b8dce3c7546..005138df79e 100644 --- a/ace/Containers.cpp +++ b/ace/Containers.cpp @@ -347,7 +347,7 @@ ACE_Unbounded_Queue<T>::enqueue_head (const T &new_item) ACE_Node<T> *temp; // Create a new node that points to the original head. - ACE_NEW_RETURN (temp, ACE_Node<T> (new_item, this->head_->next_->next_), -1); + ACE_NEW_RETURN (temp, ACE_Node<T> (new_item, this->head_->next_), -1); // Link this pointer into the front of the list. this->head_->next_ = temp; @@ -439,28 +439,43 @@ ACE_Unbounded_Queue<T>::set (const T &item, ACE_Node<T> *curr = this->head_->next_; - int result = 1; size_t i; - for (i = 0; i <= index; i++) - { - if (i == this->cur_size_) - { - // We need to expand the list. + for (i = 0; + i < index && i < this->cur_size_; + i++) + curr = curr->next_; - result = 0; + if (i < this->cur_size_) + { + // We're in range, so everything's cool. + curr->item_ = item; + return 1; + } + else + { + // We need to expand the list. - // A common case will be increasing the set size by 1. - // Therefore, we'll optimize for this case. - if (i + i == index) - // Try to expand the size of the set by 1. - return this->enqueue_tail (item); + // A common case will be increasing the set size by 1. + // Therefore, we'll optimize for this case. + if (i == index) + { + // Try to expand the size of the set by 1. + if (this->enqueue_tail (item) == -1) + return -1; else - { - T dummy; + return 0; + } + else + { + T dummy; + // We need to expand the list by multiple (dummy) items. + for (; i < index; i++) + { // This head points to the existing dummy node, which is - // about to be overwritten when we add the new dummy node. + // about to be overwritten when we add the new dummy + // node. curr = this->head_; // Try to expand the size of the set by 1, but don't @@ -468,13 +483,11 @@ ACE_Unbounded_Queue<T>::set (const T &item, if (this->enqueue_tail (dummy) == -1) return -1; } + + curr->item_ = item; + return 0; } - else - curr = curr->next_; } - - curr->item_ = item; - return result; } template <class T> void @@ -936,6 +949,11 @@ ACE_Bounded_Set_Iterator<T>::next (T *&item) ACE_ALLOC_HOOK_DEFINE(ACE_Node) template <class T> +ACE_Node<T>::~ACE_Node (void) +{ +} + +template <class T> ACE_Node<T>::ACE_Node (const T &i, ACE_Node<T> *n) : next_ (n), item_ (i) |