diff options
| author | Dave Parks <davep@lindenlab.com> | 2011-07-18 23:50:50 -0500 | 
|---|---|---|
| committer | Dave Parks <davep@lindenlab.com> | 2011-07-18 23:50:50 -0500 | 
| commit | 7ef1550fbb01acfb0cba0e849f1933462612784a (patch) | |
| tree | dde820baa0134031d46b0c117ad34545d9e8cfe9 /indra/newview/llviewerobjectlist.cpp | |
| parent | 4dc0850da7469906e5ad052da71830b05005295b (diff) | |
| parent | e8b71e0585ab126f9e77da93d6830a1a73a7aa92 (diff) | |
merge
Diffstat (limited to 'indra/newview/llviewerobjectlist.cpp')
| -rw-r--r-- | indra/newview/llviewerobjectlist.cpp | 20 | 
1 files changed, 14 insertions, 6 deletions
diff --git a/indra/newview/llviewerobjectlist.cpp b/indra/newview/llviewerobjectlist.cpp index 9f882ee732..9d38954d8b 100644 --- a/indra/newview/llviewerobjectlist.cpp +++ b/indra/newview/llviewerobjectlist.cpp @@ -1071,10 +1071,12 @@ void LLViewerObjectList::fetchObjectCosts()  				LLSD id_list;  				U32 object_index = 0; +				U32 count = 0; +  				for (  					std::set<LLUUID>::iterator iter = mStaleObjectCost.begin();  					iter != mStaleObjectCost.end(); -					++iter) +					)  				{  					// Check to see if a request for this object  					// has already been made. @@ -1084,13 +1086,15 @@ void LLViewerObjectList::fetchObjectCosts()  						mPendingObjectCost.insert(*iter);  						id_list[object_index++] = *iter;  					} -				} -				// id_list should now contain all -				// requests in mStaleObjectCost before, so clear -				// it now -				mStaleObjectCost.clear(); +					mStaleObjectCost.erase(iter++); +					if (count++ >= 450) +					{ +						break; +					} +				} +									  				if ( id_list.size() > 0 )  				{  					LLSD post_data = LLSD::emptyMap(); @@ -1394,6 +1398,10 @@ void LLViewerObjectList::updateActive(LLViewerObject *objectp)  void LLViewerObjectList::updateObjectCost(LLViewerObject* object)  { +	if (!object->isRoot()) +	{ //always fetch cost for the parent when fetching cost for children +		mStaleObjectCost.insert(((LLViewerObject*)object->getParent())->getID()); +	}  	mStaleObjectCost.insert(object->getID());  }  | 
