summaryrefslogtreecommitdiff
path: root/ace/Containers.cpp
diff options
context:
space:
mode:
authornw1 <nw1@ae88bc3d-4319-0410-8dbf-d08b4c9d3795>1997-11-05 06:28:21 +0000
committernw1 <nw1@ae88bc3d-4319-0410-8dbf-d08b4c9d3795>1997-11-05 06:28:21 +0000
commit4f46a27ae285f8253425963f4050ba6970fdb9af (patch)
tree76fb2d36409d8fc6013d6c6e0efe11f4ea52287f /ace/Containers.cpp
parentc6bc888bdd568316c1cd38529999fbc31754a6e0 (diff)
downloadATCD-4f46a27ae285f8253425963f4050ba6970fdb9af.tar.gz
Added more checks to ACE_Double_Linked_List::remove_element to prevent
double removal of elements.
Diffstat (limited to 'ace/Containers.cpp')
-rw-r--r--ace/Containers.cpp4
1 files changed, 3 insertions, 1 deletions
diff --git a/ace/Containers.cpp b/ace/Containers.cpp
index 0728099a65e..1a78ba29624 100644
--- a/ace/Containers.cpp
+++ b/ace/Containers.cpp
@@ -905,11 +905,13 @@ ACE_Double_Linked_List<T>::remove_element (T *item)
// Notice that you have to ensure that item is an element of this
// list. We can't do much checking here.
- if (item == this->head_ || this->size () == 0) // Can't remove head
+ if (item == this->head_ || item->next_ == 0
+ || item->prev_ == 0 || this->size () == 0) // Can't remove head
return -1;
item->prev_->next_ = item->next_;
item->next_->prev_ = item->prev_;
+ item->next_ = item->prev_ = 0; // reset pointers to prevent double removal.
this->size_--;
return 0;
}