aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llprimitive/llprimitive.cpp
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--linden/indra/llprimitive/llprimitive.cpp13
1 files changed, 9 insertions, 4 deletions
diff --git a/linden/indra/llprimitive/llprimitive.cpp b/linden/indra/llprimitive/llprimitive.cpp
index a906926..3ddf92e 100644
--- a/linden/indra/llprimitive/llprimitive.cpp
+++ b/linden/indra/llprimitive/llprimitive.cpp
@@ -32,6 +32,7 @@
32#include "linden_common.h" 32#include "linden_common.h"
33 33
34#include "material_codes.h" 34#include "material_codes.h"
35#include "llmemtype.h"
35#include "llerror.h" 36#include "llerror.h"
36#include "message.h" 37#include "message.h"
37#include "llprimitive.h" 38#include "llprimitive.h"
@@ -178,7 +179,7 @@ LLPrimitive::~LLPrimitive()
178 // Cleanup handled by volume manager 179 // Cleanup handled by volume manager
179 if (mVolumep) 180 if (mVolumep)
180 { 181 {
181 sVolumeManager->cleanupVolume(mVolumep); 182 sVolumeManager->unrefVolume(mVolumep);
182 } 183 }
183 mVolumep = NULL; 184 mVolumep = NULL;
184} 185}
@@ -187,6 +188,7 @@ LLPrimitive::~LLPrimitive()
187// static 188// static
188LLPrimitive *LLPrimitive::createPrimitive(LLPCode p_code) 189LLPrimitive *LLPrimitive::createPrimitive(LLPCode p_code)
189{ 190{
191 LLMemType m1(LLMemType::MTYPE_PRIMITIVE);
190 LLPrimitive *retval = new LLPrimitive(); 192 LLPrimitive *retval = new LLPrimitive();
191 193
192 if (retval) 194 if (retval)
@@ -204,6 +206,7 @@ LLPrimitive *LLPrimitive::createPrimitive(LLPCode p_code)
204//=============================================================== 206//===============================================================
205void LLPrimitive::init_primitive(LLPCode p_code) 207void LLPrimitive::init_primitive(LLPCode p_code)
206{ 208{
209 LLMemType m1(LLMemType::MTYPE_PRIMITIVE);
207 if (mNumTEs) 210 if (mNumTEs)
208 { 211 {
209 if (mTextureList) 212 if (mTextureList)
@@ -246,6 +249,7 @@ void LLPrimitive::setNumTEs(const U8 num_tes)
246 // Right now, we don't try and preserve entries when the number of faces 249 // Right now, we don't try and preserve entries when the number of faces
247 // changes. 250 // changes.
248 251
252 LLMemType m1(LLMemType::MTYPE_PRIMITIVE);
249 if (num_tes) 253 if (num_tes)
250 { 254 {
251 LLTextureEntry *new_tes; 255 LLTextureEntry *new_tes;
@@ -914,6 +918,7 @@ S32 face_index_from_id(LLFaceID face_ID, const std::vector<LLProfile::Face>& fac
914 918
915BOOL LLPrimitive::setVolume(const LLVolumeParams &volume_params, const S32 detail, bool unique_volume) 919BOOL LLPrimitive::setVolume(const LLVolumeParams &volume_params, const S32 detail, bool unique_volume)
916{ 920{
921 LLMemType m1(LLMemType::MTYPE_VOLUME);
917 LLVolume *volumep; 922 LLVolume *volumep;
918 if (unique_volume) 923 if (unique_volume)
919 { 924 {
@@ -935,10 +940,10 @@ BOOL LLPrimitive::setVolume(const LLVolumeParams &volume_params, const S32 detai
935 } 940 }
936 } 941 }
937 942
938 volumep = sVolumeManager->getVolume(volume_params, detail); 943 volumep = sVolumeManager->refVolume(volume_params, detail);
939 if (volumep == mVolumep) 944 if (volumep == mVolumep)
940 { 945 {
941 sVolumeManager->cleanupVolume( volumep ); // LLVolumeMgr::getVolume() creates a reference, but we don't need a second one. 946 sVolumeManager->unrefVolume( volumep ); // LLVolumeMgr::refVolume() creates a reference, but we don't need a second one.
942 return TRUE; 947 return TRUE;
943 } 948 }
944 } 949 }
@@ -981,7 +986,7 @@ BOOL LLPrimitive::setVolume(const LLVolumeParams &volume_params, const S32 detai
981 986
982 987
983 // build the new object 988 // build the new object
984 sVolumeManager->cleanupVolume(mVolumep); 989 sVolumeManager->unrefVolume(mVolumep);
985 mVolumep = volumep; 990 mVolumep = volumep;
986 991
987 U32 new_face_mask = mVolumep->mFaceMask; 992 U32 new_face_mask = mVolumep->mFaceMask;