diff options
| author | Graham Linden <graham@lindenlab.com> | 2013-09-09 13:26:13 -0700 | 
|---|---|---|
| committer | Graham Linden <graham@lindenlab.com> | 2013-09-09 13:26:13 -0700 | 
| commit | 79836e32d575248642cfd6af837548aac054988f (patch) | |
| tree | bc854e72ae489f3e8f774896f099e293671d25ca | |
| parent | 2df58f775fdd1c846ec125a9736d6dd39dab2811 (diff) | |
MAINT-140 revert to simplified cleanDeadObjects to avoid accidental refcounting crashes
| -rwxr-xr-x | indra/newview/llviewerobjectlist.cpp | 28 | 
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(); | 
