summaryrefslogtreecommitdiff
path: root/indra/newview
diff options
context:
space:
mode:
authorGraham Linden <graham@lindenlab.com>2013-09-09 13:26:13 -0700
committerGraham Linden <graham@lindenlab.com>2013-09-09 13:26:13 -0700
commit79836e32d575248642cfd6af837548aac054988f (patch)
treebc854e72ae489f3e8f774896f099e293671d25ca /indra/newview
parent2df58f775fdd1c846ec125a9736d6dd39dab2811 (diff)
MAINT-140 revert to simplified cleanDeadObjects to avoid accidental refcounting crashes
Diffstat (limited to 'indra/newview')
-rwxr-xr-xindra/newview/llviewerobjectlist.cpp28
1 files changed, 5 insertions, 23 deletions
diff --git a/indra/newview/llviewerobjectlist.cpp b/indra/newview/llviewerobjectlist.cpp
index 66615657d8..8a013a6d91 100755
--- a/indra/newview/llviewerobjectlist.cpp
+++ b/indra/newview/llviewerobjectlist.cpp
@@ -1324,45 +1324,27 @@ void LLViewerObjectList::cleanDeadObjects(BOOL use_timer)
return;
}
+ LLViewerObject *objectp = NULL;
S32 num_removed = 0;
- LLViewerObject *objectp;
-
- vobj_list_t::reverse_iterator target = mObjects.rbegin();
- vobj_list_t::iterator iter = mObjects.begin();
- for ( ; iter != mObjects.end(); )
+ vobj_list_t::iterator iter;
+ for (iter = mObjects.begin(); iter != mObjects.end();)
{
// Scan for all of the dead objects and put them all on the end of the list with no ref count ops
objectp = *iter;
- if (objectp == NULL)
- { //we caught up to the dead tail
- break;
- }
- if (objectp->isDead())
+ if (objectp && objectp->isDead())
{
- LLPointer<LLViewerObject>::swap(*iter, *target);
- *target = NULL;
- ++target;
+ iter = mObjects.erase(iter);
num_removed++;
-
- if (num_removed == mNumDeadObjects || iter->isNull())
- {
- // We've cleaned up all of the dead objects or caught up to the dead tail
- break;
- }
}
else
{
++iter;
}
}
-
llassert(num_removed == mNumDeadObjects);
- //erase as a block
- mObjects.erase(mObjects.begin()+(mObjects.size()-mNumDeadObjects), mObjects.end());
-
// We've cleaned the global object list, now let's do some paranoia testing on objects
// before blowing away the dead list.
mDeadObjects.clear();