diff options
| author | Andrey Kleshchev <andreykproductengine@lindenlab.com> | 2022-05-05 19:41:56 +0300 | 
|---|---|---|
| committer | Andrey Kleshchev <andreykproductengine@lindenlab.com> | 2022-05-05 19:41:56 +0300 | 
| commit | 43517c5adc69ecb1d8a5e031a9e2840b005eecf9 (patch) | |
| tree | 0bfb56fe055f700b66c73efffab741c69925e9f3 | |
| parent | f3add82a4c7f34bfff285302c34d952902451cad (diff) | |
SL-17244 Fix 'empty leaf' crashes
| -rw-r--r-- | indra/llmath/lloctree.h | 12 | ||||
| -rw-r--r-- | indra/llmath/llvolume.cpp | 4 | ||||
| -rw-r--r-- | indra/newview/llvieweroctree.cpp | 2 | 
3 files changed, 12 insertions, 6 deletions
| diff --git a/indra/llmath/lloctree.h b/indra/llmath/lloctree.h index 2283df1e1a..a9a54a8113 100644 --- a/indra/llmath/lloctree.h +++ b/indra/llmath/lloctree.h @@ -73,7 +73,7 @@ template <class T>  class LLOctreeTravelerDepthFirst : public LLOctreeTraveler<T>  {  public: -	virtual void traverse(const LLOctreeNode<T>* node); +	virtual void traverse(const LLOctreeNode<T>* node) override;  };  template <class T> @@ -696,7 +696,7 @@ public:  	{  	} -	bool balance() +	bool balance() override  	{	          //LL_PROFILE_ZONE_NAMED_COLOR("Octree::balance()",OCTREE_DEBUG_COLOR_BALANCE); @@ -732,7 +732,7 @@ public:  	}  	// LLOctreeRoot::insert -	bool insert(T* data) +	bool insert(T* data) override  	{  		if (data == NULL)   		{ @@ -835,6 +835,12 @@ public:  		return false;  	} + +    bool isLeaf() const override +    { +        // root can't be a leaf +        return false; +    }  };  //======================== diff --git a/indra/llmath/llvolume.cpp b/indra/llmath/llvolume.cpp index 3727ce85af..5099920f32 100644 --- a/indra/llmath/llvolume.cpp +++ b/indra/llmath/llvolume.cpp @@ -414,7 +414,7 @@ public:  				max.setMax(max, *tri->mV[2]);  			}  		} -		else if (!branch->isLeaf()) +		else if (branch->getChildCount() > 0)  		{ //no data, but child nodes exist  			LLVolumeOctreeListener* child = (LLVolumeOctreeListener*) branch->getChild(0)->getListener(0); @@ -424,7 +424,7 @@ public:  		}  		else  		{ -			LL_ERRS() << "Empty leaf" << LL_ENDL; +            llassert(!branch->isLeaf()); // Empty leaf  		}  		for (S32 i = 0; i < branch->getChildCount(); ++i) diff --git a/indra/newview/llvieweroctree.cpp b/indra/newview/llvieweroctree.cpp index 87e296012d..12624ec3a2 100644 --- a/indra/newview/llvieweroctree.cpp +++ b/indra/newview/llvieweroctree.cpp @@ -564,7 +564,7 @@ void LLViewerOctreeGroup::rebound()  		group->setState(SKIP_FRUSTUM_CHECK);  	} -	else if (mOctreeNode->isLeaf()) +	else if (mOctreeNode->getChildCount() == 0)  	{ //copy object bounding box if this is a leaf  		boundObjects(TRUE, mExtents[0], mExtents[1]);  		mBounds[0] = mObjectBounds[0]; | 
