aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llxml/llcontrol.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llxml/llcontrol.cpp')
-rw-r--r--linden/indra/llxml/llcontrol.cpp75
1 files changed, 38 insertions, 37 deletions
diff --git a/linden/indra/llxml/llcontrol.cpp b/linden/indra/llxml/llcontrol.cpp
index 79fd522..c365aed 100644
--- a/linden/indra/llxml/llcontrol.cpp
+++ b/linden/indra/llxml/llcontrol.cpp
@@ -132,7 +132,8 @@ void LLControlGroup::cleanup()
132 132
133LLControlBase* LLControlGroup::getControl(const LLString& name) 133LLControlBase* LLControlGroup::getControl(const LLString& name)
134{ 134{
135 return mNameTable[name]; 135 ctrl_name_table_t::iterator iter = mNameTable.find(name);
136 return iter == mNameTable.end() ? NULL : (LLControlBase*)iter->second;
136} 137}
137 138
138BOOL LLControlGroup::declareControl(const LLString& name, eControlType type, const LLSD initial_val, const LLString& comment, BOOL persist) 139BOOL LLControlGroup::declareControl(const LLString& name, eControlType type, const LLSD initial_val, const LLString& comment, BOOL persist)
@@ -143,9 +144,11 @@ BOOL LLControlGroup::declareControl(const LLString& name, eControlType type, con
143 LLControl* control = new LLControl(name, type, initial_val, comment, persist); 144 LLControl* control = new LLControl(name, type, initial_val, comment, persist);
144 mNameTable[name] = control; 145 mNameTable[name] = control;
145 return TRUE; 146 return TRUE;
146 } else 147 }
148 else
147 { 149 {
148 llwarns << "LLControlGroup::declareControl: Control named " << name << " already exists." << llendl; 150 llwarns << "LLControlGroup::declareControl: Control named " << name << " already exists." << llendl;
151 mNameTable.erase(name);
149 return FALSE; 152 return FALSE;
150 } 153 }
151} 154}
@@ -207,7 +210,7 @@ BOOL LLControlGroup::declareColor3(const LLString& name, const LLColor3 &initial
207 210
208LLSD LLControlGroup::registerListener(const LLString& name, LLSimpleListenerObservable *listener) 211LLSD LLControlGroup::registerListener(const LLString& name, LLSimpleListenerObservable *listener)
209{ 212{
210 LLControlBase *control = mNameTable[name]; 213 LLControlBase *control = getControl(name);
211 if (control) 214 if (control)
212 { 215 {
213 return control->registerListener(listener); 216 return control->registerListener(listener);
@@ -217,7 +220,7 @@ LLSD LLControlGroup::registerListener(const LLString& name, LLSimpleListenerObse
217 220
218BOOL LLControlGroup::getBOOL(const LLString& name) 221BOOL LLControlGroup::getBOOL(const LLString& name)
219{ 222{
220 LLControlBase* control = mNameTable[name]; 223 LLControlBase* control = getControl(name);
221 224
222 if (control && control->isType(TYPE_BOOLEAN)) 225 if (control && control->isType(TYPE_BOOLEAN))
223 return control->get().asBoolean(); 226 return control->get().asBoolean();
@@ -230,7 +233,7 @@ BOOL LLControlGroup::getBOOL(const LLString& name)
230 233
231S32 LLControlGroup::getS32(const LLString& name) 234S32 LLControlGroup::getS32(const LLString& name)
232{ 235{
233 LLControlBase* control = mNameTable[name]; 236 LLControlBase* control = getControl(name);
234 237
235 if (control && control->isType(TYPE_S32)) 238 if (control && control->isType(TYPE_S32))
236 return control->get().asInteger(); 239 return control->get().asInteger();
@@ -243,7 +246,7 @@ S32 LLControlGroup::getS32(const LLString& name)
243 246
244U32 LLControlGroup::getU32(const LLString& name) 247U32 LLControlGroup::getU32(const LLString& name)
245{ 248{
246 LLControlBase* control = mNameTable[name]; 249 LLControlBase* control = getControl(name);
247 250
248 if (control && control->isType(TYPE_U32)) 251 if (control && control->isType(TYPE_U32))
249 return control->get().asInteger(); 252 return control->get().asInteger();
@@ -256,7 +259,7 @@ U32 LLControlGroup::getU32(const LLString& name)
256 259
257F32 LLControlGroup::getF32(const LLString& name) 260F32 LLControlGroup::getF32(const LLString& name)
258{ 261{
259 LLControlBase* control = mNameTable[name]; 262 LLControlBase* control = getControl(name);
260 263
261 if (control && control->isType(TYPE_F32)) 264 if (control && control->isType(TYPE_F32))
262 return (F32) control->get().asReal(); 265 return (F32) control->get().asReal();
@@ -269,7 +272,7 @@ F32 LLControlGroup::getF32(const LLString& name)
269 272
270LLString LLControlGroup::findString(const LLString& name) 273LLString LLControlGroup::findString(const LLString& name)
271{ 274{
272 LLControlBase* control = mNameTable[name]; 275 LLControlBase* control = getControl(name);
273 276
274 if (control && control->isType(TYPE_STRING)) 277 if (control && control->isType(TYPE_STRING))
275 return control->get().asString(); 278 return control->get().asString();
@@ -278,7 +281,7 @@ LLString LLControlGroup::findString(const LLString& name)
278 281
279LLString LLControlGroup::getString(const LLString& name) 282LLString LLControlGroup::getString(const LLString& name)
280{ 283{
281 LLControlBase* control = mNameTable[name]; 284 LLControlBase* control = getControl(name);
282 285
283 if (control && control->isType(TYPE_STRING)) 286 if (control && control->isType(TYPE_STRING))
284 return control->get().asString(); 287 return control->get().asString();
@@ -304,7 +307,7 @@ LLString LLControlGroup::getText(const LLString& name)
304 307
305LLVector3 LLControlGroup::getVector3(const LLString& name) 308LLVector3 LLControlGroup::getVector3(const LLString& name)
306{ 309{
307 LLControlBase* control = mNameTable[name]; 310 LLControlBase* control = getControl(name);
308 311
309 if (control && control->isType(TYPE_VEC3)) 312 if (control && control->isType(TYPE_VEC3))
310 return control->get(); 313 return control->get();
@@ -317,7 +320,7 @@ LLVector3 LLControlGroup::getVector3(const LLString& name)
317 320
318LLVector3d LLControlGroup::getVector3d(const LLString& name) 321LLVector3d LLControlGroup::getVector3d(const LLString& name)
319{ 322{
320 LLControlBase* control = mNameTable[name]; 323 LLControlBase* control = getControl(name);
321 324
322 if (control && control->isType(TYPE_VEC3D)) 325 if (control && control->isType(TYPE_VEC3D))
323 return control->get(); 326 return control->get();
@@ -330,7 +333,7 @@ LLVector3d LLControlGroup::getVector3d(const LLString& name)
330 333
331LLRect LLControlGroup::getRect(const LLString& name) 334LLRect LLControlGroup::getRect(const LLString& name)
332{ 335{
333 LLControlBase* control = mNameTable[name]; 336 LLControlBase* control = getControl(name);
334 337
335 if (control && control->isType(TYPE_RECT)) 338 if (control && control->isType(TYPE_RECT))
336 return control->get(); 339 return control->get();
@@ -376,7 +379,7 @@ LLColor4 LLControlGroup::getColor(const LLString& name)
376 379
377LLColor4U LLControlGroup::getColor4U(const LLString& name) 380LLColor4U LLControlGroup::getColor4U(const LLString& name)
378{ 381{
379 LLControlBase* control = mNameTable[name]; 382 LLControlBase* control = getControl(name);
380 383
381 if (control && control->isType(TYPE_COL4U)) 384 if (control && control->isType(TYPE_COL4U))
382 return control->get(); 385 return control->get();
@@ -389,7 +392,7 @@ LLColor4U LLControlGroup::getColor4U(const LLString& name)
389 392
390LLColor4 LLControlGroup::getColor4(const LLString& name) 393LLColor4 LLControlGroup::getColor4(const LLString& name)
391{ 394{
392 LLControlBase* control = mNameTable[name]; 395 LLControlBase* control = getControl(name);
393 396
394 if (control && control->isType(TYPE_COL4)) 397 if (control && control->isType(TYPE_COL4))
395 return control->get(); 398 return control->get();
@@ -402,7 +405,7 @@ LLColor4 LLControlGroup::getColor4(const LLString& name)
402 405
403LLColor3 LLControlGroup::getColor3(const LLString& name) 406LLColor3 LLControlGroup::getColor3(const LLString& name)
404{ 407{
405 LLControlBase* control = mNameTable[name]; 408 LLControlBase* control = getControl(name);
406 409
407 if (control && control->isType(TYPE_COL3)) 410 if (control && control->isType(TYPE_COL3))
408 return control->get(); 411 return control->get();
@@ -415,9 +418,8 @@ LLColor3 LLControlGroup::getColor3(const LLString& name)
415 418
416BOOL LLControlGroup::controlExists(const LLString& name) 419BOOL LLControlGroup::controlExists(const LLString& name)
417{ 420{
418 void *control = mNameTable[name]; 421 ctrl_name_table_t::iterator iter = mNameTable.find(name);
419 422 return iter != mNameTable.end();
420 return (control != 0);
421} 423}
422 424
423//------------------------------------------------------------------- 425//-------------------------------------------------------------------
@@ -426,7 +428,7 @@ BOOL LLControlGroup::controlExists(const LLString& name)
426 428
427void LLControlGroup::setBOOL(const LLString& name, BOOL val) 429void LLControlGroup::setBOOL(const LLString& name, BOOL val)
428{ 430{
429 LLControlBase* control = mNameTable[name]; 431 LLControlBase* control = getControl(name);
430 432
431 if (control && control->isType(TYPE_BOOLEAN)) 433 if (control && control->isType(TYPE_BOOLEAN))
432 { 434 {
@@ -441,7 +443,7 @@ void LLControlGroup::setBOOL(const LLString& name, BOOL val)
441 443
442void LLControlGroup::setS32(const LLString& name, S32 val) 444void LLControlGroup::setS32(const LLString& name, S32 val)
443{ 445{
444 LLControlBase* control = mNameTable[name]; 446 LLControlBase* control = getControl(name);
445 447
446 if (control && control->isType(TYPE_S32)) 448 if (control && control->isType(TYPE_S32))
447 { 449 {
@@ -456,7 +458,7 @@ void LLControlGroup::setS32(const LLString& name, S32 val)
456 458
457void LLControlGroup::setF32(const LLString& name, F32 val) 459void LLControlGroup::setF32(const LLString& name, F32 val)
458{ 460{
459 LLControlBase* control = mNameTable[name]; 461 LLControlBase* control = getControl(name);
460 462
461 if (control && control->isType(TYPE_F32)) 463 if (control && control->isType(TYPE_F32))
462 { 464 {
@@ -471,7 +473,7 @@ void LLControlGroup::setF32(const LLString& name, F32 val)
471 473
472void LLControlGroup::setU32(const LLString& name, U32 val) 474void LLControlGroup::setU32(const LLString& name, U32 val)
473{ 475{
474 LLControlBase* control = mNameTable[name]; 476 LLControlBase* control = getControl(name);
475 477
476 if (control && control->isType(TYPE_U32)) 478 if (control && control->isType(TYPE_U32))
477 { 479 {
@@ -486,7 +488,7 @@ void LLControlGroup::setU32(const LLString& name, U32 val)
486 488
487void LLControlGroup::setString(const LLString& name, const LLString &val) 489void LLControlGroup::setString(const LLString& name, const LLString &val)
488{ 490{
489 LLControlBase* control = mNameTable[name]; 491 LLControlBase* control = getControl(name);
490 492
491 if (control && control->isType(TYPE_STRING)) 493 if (control && control->isType(TYPE_STRING))
492 { 494 {
@@ -501,7 +503,7 @@ void LLControlGroup::setString(const LLString& name, const LLString &val)
501 503
502void LLControlGroup::setVector3(const LLString& name, const LLVector3 &val) 504void LLControlGroup::setVector3(const LLString& name, const LLVector3 &val)
503{ 505{
504 LLControlBase* control = mNameTable[name]; 506 LLControlBase* control = getControl(name);
505 507
506 if (control && control->isType(TYPE_VEC3)) 508 if (control && control->isType(TYPE_VEC3))
507 { 509 {
@@ -515,7 +517,7 @@ void LLControlGroup::setVector3(const LLString& name, const LLVector3 &val)
515 517
516void LLControlGroup::setVector3d(const LLString& name, const LLVector3d &val) 518void LLControlGroup::setVector3d(const LLString& name, const LLVector3d &val)
517{ 519{
518 LLControlBase* control = mNameTable[name]; 520 LLControlBase* control = getControl(name);
519 521
520 if (control && control->isType(TYPE_VEC3D)) 522 if (control && control->isType(TYPE_VEC3D))
521 { 523 {
@@ -529,7 +531,7 @@ void LLControlGroup::setVector3d(const LLString& name, const LLVector3d &val)
529 531
530void LLControlGroup::setRect(const LLString& name, const LLRect &val) 532void LLControlGroup::setRect(const LLString& name, const LLRect &val)
531{ 533{
532 LLControlBase* control = mNameTable[name]; 534 LLControlBase* control = getControl(name);
533 535
534 if (control && control->isType(TYPE_RECT)) 536 if (control && control->isType(TYPE_RECT))
535 { 537 {
@@ -543,7 +545,7 @@ void LLControlGroup::setRect(const LLString& name, const LLRect &val)
543 545
544void LLControlGroup::setColor4U(const LLString& name, const LLColor4U &val) 546void LLControlGroup::setColor4U(const LLString& name, const LLColor4U &val)
545{ 547{
546 LLControlBase* control = mNameTable[name]; 548 LLControlBase* control = getControl(name);
547 549
548 if (control && control->isType(TYPE_COL4U)) 550 if (control && control->isType(TYPE_COL4U))
549 { 551 {
@@ -557,7 +559,7 @@ void LLControlGroup::setColor4U(const LLString& name, const LLColor4U &val)
557 559
558void LLControlGroup::setColor4(const LLString& name, const LLColor4 &val) 560void LLControlGroup::setColor4(const LLString& name, const LLColor4 &val)
559{ 561{
560 LLControlBase* control = mNameTable[name]; 562 LLControlBase* control = getControl(name);
561 563
562 if (control && control->isType(TYPE_COL4)) 564 if (control && control->isType(TYPE_COL4))
563 { 565 {
@@ -576,7 +578,7 @@ void LLControlGroup::setValue(const LLString& name, const LLSD& val)
576 return; 578 return;
577 } 579 }
578 580
579 LLControlBase* control = mNameTable[name]; 581 LLControlBase* control = getControl(name);
580 582
581 if (control) 583 if (control)
582 { 584 {
@@ -599,7 +601,7 @@ U32 LLControlGroup::loadFromFileLegacy(const LLString& filename, BOOL require_de
599 llifstream file; 601 llifstream file;
600 S32 version; 602 S32 version;
601 603
602 file.open(filename.c_str()); 604 file.open(filename.c_str()); /*Flawfinder: ignore*/
603 605
604 if (!file) 606 if (!file)
605 { 607 {
@@ -629,7 +631,7 @@ U32 LLControlGroup::loadFromFileLegacy(const LLString& filename, BOOL require_de
629 if (name.substr(0,2) == "//") 631 if (name.substr(0,2) == "//")
630 { 632 {
631 // This is a comment. 633 // This is a comment.
632 char buffer[MAX_STRING]; 634 char buffer[MAX_STRING]; /*Flawfinder: ignore*/
633 file.getline(buffer, MAX_STRING); 635 file.getline(buffer, MAX_STRING);
634 continue; 636 continue;
635 } 637 }
@@ -643,7 +645,7 @@ U32 LLControlGroup::loadFromFileLegacy(const LLString& filename, BOOL require_de
643 if (!name.empty()) 645 if (!name.empty())
644 { 646 {
645 //read in to end of line 647 //read in to end of line
646 char buffer[MAX_STRING]; 648 char buffer[MAX_STRING]; /*Flawfinder: ignore*/
647 file.getline(buffer, MAX_STRING); 649 file.getline(buffer, MAX_STRING);
648 llwarns << "LLControlGroup::loadFromFile() : Trying to set \"" << name << "\", setting doesn't exist." << llendl; 650 llwarns << "LLControlGroup::loadFromFile() : Trying to set \"" << name << "\", setting doesn't exist." << llendl;
649 } 651 }
@@ -709,7 +711,7 @@ U32 LLControlGroup::loadFromFileLegacy(const LLString& filename, BOOL require_de
709 break; 711 break;
710 case TYPE_BOOLEAN: 712 case TYPE_BOOLEAN:
711 { 713 {
712 char boolstring[256]; 714 char boolstring[256]; /*Flawfinder: ignore*/
713 BOOL valid = FALSE; 715 BOOL valid = FALSE;
714 BOOL initial = FALSE; 716 BOOL initial = FALSE;
715 717
@@ -858,7 +860,7 @@ U32 LLControlGroup::loadFromFile(const LLString& filename, BOOL require_declarat
858 { 860 {
859 name = child_nodep->getName(); 861 name = child_nodep->getName();
860 862
861 BOOL declared = (mNameTable[name].notNull()); 863 BOOL declared = controlExists(name);
862 864
863 if (require_declaration && !declared) 865 if (require_declaration && !declared)
864 { 866 {
@@ -1045,8 +1047,7 @@ U32 LLControlGroup::saveToFile(const LLString& filename, BOOL nondefault_only)
1045 break; 1047 break;
1046 } 1048 }
1047 1049
1048 LLControlBase* control = (LLControlBase *)mNameTable[name]; 1050 LLControlBase* control = (LLControlBase *)iter->second;
1049
1050 if (!control) 1051 if (!control)
1051 { 1052 {
1052 llwarns << "Tried to save invalid control: " << name << llendl; 1053 llwarns << "Tried to save invalid control: " << name << llendl;
@@ -1067,7 +1068,7 @@ U32 LLControlGroup::saveToFile(const LLString& filename, BOOL nondefault_only)
1067 } 1068 }
1068 1069
1069 llofstream file; 1070 llofstream file;
1070 file.open(filename.c_str()); 1071 file.open(filename.c_str()); /*Flawfinder: ignore*/
1071 1072
1072 if (!file.is_open()) 1073 if (!file.is_open())
1073 { 1074 {