diff options
| author | Callum Prentice <callum@mbp.localdomain> | 2022-12-12 11:05:24 -0800 | 
|---|---|---|
| committer | Callum Prentice <callum@mbp.localdomain> | 2022-12-12 11:05:24 -0800 | 
| commit | 6daa0a9ecba98fc805a3e76573c894f1d956da8a (patch) | |
| tree | 8dd833707caf512e580cbe8f2a265d4367103894 /indra/llmath/llvolume.cpp | |
| parent | a849c51837c9fad2a6929564f4b3a3446a2f4e9a (diff) | |
| parent | a0c3d69c620a92d73a1008f218680fb4d0ef9255 (diff) | |
Merge branch 'main' into DRTVWR-489-emoji
Diffstat (limited to 'indra/llmath/llvolume.cpp')
| -rw-r--r-- | indra/llmath/llvolume.cpp | 22 | 
1 files changed, 22 insertions, 0 deletions
| diff --git a/indra/llmath/llvolume.cpp b/indra/llmath/llvolume.cpp index f43d07ce5e..be25592d54 100644 --- a/indra/llmath/llvolume.cpp +++ b/indra/llmath/llvolume.cpp @@ -5013,6 +5013,17 @@ void LLVolumeFace::optimize(F32 angle_cutoff)  	{  		U16 index = mIndices[i]; +        if (index >= mNumVertices) +        { +            // invalid index +            // replace with a valid index to avoid crashes +            index = mNumVertices - 1; +            mIndices[i] = index; + +            // Needs better logging +            LL_DEBUGS_ONCE("LLVOLUME") << "Invalid index, substituting" << LL_ENDL; +        } +  		LLVolumeFace::VertexData cv;  		getVertexData(index, cv); @@ -5385,6 +5396,17 @@ bool LLVolumeFace::cacheOptimize()              U16 idx = mIndices[i];              U32 tri_idx = i / 3; +            if (idx >= mNumVertices) +            { +                // invalid index +                // replace with a valid index to avoid crashes +                idx = mNumVertices - 1; +                mIndices[i] = idx; + +                // Needs better logging +                LL_DEBUGS_ONCE("LLVOLUME") << "Invalid index, substituting" << LL_ENDL; +            } +              vertex_data[idx].mTriangles.push_back(&(triangle_data[tri_idx]));              vertex_data[idx].mIdx = idx;              triangle_data[tri_idx].mVertex[i % 3] = &(vertex_data[idx]); | 
