aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llhudmanager.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llhudmanager.cpp')
-rw-r--r--linden/indra/newview/llhudmanager.cpp25
1 files changed, 11 insertions, 14 deletions
diff --git a/linden/indra/newview/llhudmanager.cpp b/linden/indra/newview/llhudmanager.cpp
index 2c38943..5217893 100644
--- a/linden/indra/newview/llhudmanager.cpp
+++ b/linden/indra/newview/llhudmanager.cpp
@@ -42,8 +42,6 @@
42#include "llviewercontrol.h" 42#include "llviewercontrol.h"
43#include "llviewerobjectlist.h" 43#include "llviewerobjectlist.h"
44 44
45LLHUDManager *gHUDManager = NULL;
46
47extern BOOL gNoRender; 45extern BOOL gNoRender;
48 46
49// These are loaded from saved settings. 47// These are loaded from saved settings.
@@ -60,7 +58,6 @@ LLHUDManager::LLHUDManager()
60 58
61LLHUDManager::~LLHUDManager() 59LLHUDManager::~LLHUDManager()
62{ 60{
63 mHUDEffects.reset();
64} 61}
65 62
66 63
@@ -110,6 +107,12 @@ void LLHUDManager::sendEffects()
110 } 107 }
111} 108}
112 109
110//static
111void LLHUDManager::shutdownClass()
112{
113 getInstance()->mHUDEffects.reset();
114}
115
113void LLHUDManager::cleanupEffects() 116void LLHUDManager::cleanupEffects()
114{ 117{
115 S32 i = 0; 118 S32 i = 0;
@@ -155,12 +158,6 @@ void LLHUDManager::processViewerEffect(LLMessageSystem *mesgsys, void **user_dat
155 return; 158 return;
156 } 159 }
157 160
158 if (!gHUDManager)
159 {
160 llwarns << "No gHUDManager!" << llendl;
161 return;
162 }
163
164 LLHUDEffect *effectp = NULL; 161 LLHUDEffect *effectp = NULL;
165 LLUUID effect_id; 162 LLUUID effect_id;
166 U8 effect_type = 0; 163 U8 effect_type = 0;
@@ -172,20 +169,20 @@ void LLHUDManager::processViewerEffect(LLMessageSystem *mesgsys, void **user_dat
172 effectp = NULL; 169 effectp = NULL;
173 LLHUDEffect::getIDType(mesgsys, k, effect_id, effect_type); 170 LLHUDEffect::getIDType(mesgsys, k, effect_id, effect_type);
174 S32 i; 171 S32 i;
175 for (i = 0; i < gHUDManager->mHUDEffects.count(); i++) 172 for (i = 0; i < LLHUDManager::getInstance()->mHUDEffects.count(); i++)
176 { 173 {
177 LLHUDEffect *cur_effectp = gHUDManager->mHUDEffects[i]; 174 LLHUDEffect *cur_effectp = LLHUDManager::getInstance()->mHUDEffects[i];
178 if (!cur_effectp) 175 if (!cur_effectp)
179 { 176 {
180 llwarns << "Null effect in effect manager, skipping" << llendl; 177 llwarns << "Null effect in effect manager, skipping" << llendl;
181 gHUDManager->mHUDEffects.remove(i); 178 LLHUDManager::getInstance()->mHUDEffects.remove(i);
182 i--; 179 i--;
183 continue; 180 continue;
184 } 181 }
185 if (cur_effectp->isDead()) 182 if (cur_effectp->isDead())
186 { 183 {
187 // llwarns << "Dead effect in effect manager, removing" << llendl; 184 // llwarns << "Dead effect in effect manager, removing" << llendl;
188 gHUDManager->mHUDEffects.remove(i); 185 LLHUDManager::getInstance()->mHUDEffects.remove(i);
189 i--; 186 i--;
190 continue; 187 continue;
191 } 188 }
@@ -204,7 +201,7 @@ void LLHUDManager::processViewerEffect(LLMessageSystem *mesgsys, void **user_dat
204 { 201 {
205 if (!effectp) 202 if (!effectp)
206 { 203 {
207 effectp = gHUDManager->createViewerEffect(effect_type, FALSE, FALSE); 204 effectp = LLHUDManager::getInstance()->createViewerEffect(effect_type, FALSE, FALSE);
208 } 205 }
209 206
210 if (effectp) 207 if (effectp)