diff options
Diffstat (limited to 'linden/indra/llxml')
-rw-r--r-- | linden/indra/llxml/CMakeLists.txt | 36 | ||||
-rw-r--r-- | linden/indra/llxml/files.lst | 4 | ||||
-rw-r--r-- | linden/indra/llxml/llcontrol.cpp | 158 | ||||
-rw-r--r-- | linden/indra/llxml/llcontrol.h | 126 | ||||
-rw-r--r-- | linden/indra/llxml/llxml.vcproj | 191 | ||||
-rw-r--r-- | linden/indra/llxml/llxml_vc8.vcproj | 279 | ||||
-rw-r--r-- | linden/indra/llxml/llxml_vc9.vcproj | 280 | ||||
-rw-r--r-- | linden/indra/llxml/llxmlnode.cpp | 233 | ||||
-rw-r--r-- | linden/indra/llxml/llxmlnode.h | 107 | ||||
-rw-r--r-- | linden/indra/llxml/llxmlparser.cpp | 14 | ||||
-rw-r--r-- | linden/indra/llxml/llxmlparser.h | 2 | ||||
-rw-r--r-- | linden/indra/llxml/llxmltree.cpp | 94 | ||||
-rw-r--r-- | linden/indra/llxml/llxmltree.h | 20 |
13 files changed, 419 insertions, 1125 deletions
diff --git a/linden/indra/llxml/CMakeLists.txt b/linden/indra/llxml/CMakeLists.txt new file mode 100644 index 0000000..d86bc0d --- /dev/null +++ b/linden/indra/llxml/CMakeLists.txt | |||
@@ -0,0 +1,36 @@ | |||
1 | # -*- cmake -*- | ||
2 | |||
3 | project(llxml) | ||
4 | |||
5 | include(00-Common) | ||
6 | include(LLCommon) | ||
7 | include(LLMath) | ||
8 | include(LLXML) | ||
9 | |||
10 | include_directories( | ||
11 | ${LLCOMMON_INCLUDE_DIRS} | ||
12 | ${LLMATH_INCLUDE_DIRS} | ||
13 | ) | ||
14 | |||
15 | set(llxml_SOURCE_FILES | ||
16 | llcontrol.cpp | ||
17 | llxmlnode.cpp | ||
18 | llxmlparser.cpp | ||
19 | llxmltree.cpp | ||
20 | ) | ||
21 | |||
22 | set(llxml_HEADER_FILES | ||
23 | CMakeLists.txt | ||
24 | |||
25 | llcontrol.h | ||
26 | llxmlnode.h | ||
27 | llxmlparser.h | ||
28 | llxmltree.h | ||
29 | ) | ||
30 | |||
31 | set_source_files_properties(${llxml_HEADER_FILES} | ||
32 | PROPERTIES HEADER_FILE_ONLY TRUE) | ||
33 | |||
34 | list(APPEND llxml_SOURCE_FILES ${llxml_HEADER_FILES}) | ||
35 | |||
36 | add_library (llxml ${llxml_SOURCE_FILES}) | ||
diff --git a/linden/indra/llxml/files.lst b/linden/indra/llxml/files.lst deleted file mode 100644 index 5fec309..0000000 --- a/linden/indra/llxml/files.lst +++ /dev/null | |||
@@ -1,4 +0,0 @@ | |||
1 | llxml/llcontrol.cpp | ||
2 | llxml/llxmlnode.cpp | ||
3 | llxml/llxmlparser.cpp | ||
4 | llxml/llxmltree.cpp | ||
diff --git a/linden/indra/llxml/llcontrol.cpp b/linden/indra/llxml/llcontrol.cpp index f88ac69..8fa58e8 100644 --- a/linden/indra/llxml/llcontrol.cpp +++ b/linden/indra/llxml/llcontrol.cpp | |||
@@ -49,7 +49,7 @@ | |||
49 | #include "llxmltree.h" | 49 | #include "llxmltree.h" |
50 | #include "llsdserialize.h" | 50 | #include "llsdserialize.h" |
51 | 51 | ||
52 | #if LL_RELEASE_FOR_DOWNLOAD | 52 | #if LL_RELEASE_WITH_DEBUG_INFO || LL_DEBUG |
53 | #define CONTROL_ERRS LL_WARNS("ControlErrors") | 53 | #define CONTROL_ERRS LL_WARNS("ControlErrors") |
54 | #else | 54 | #else |
55 | #define CONTROL_ERRS LL_ERRS("ControlErrors") | 55 | #define CONTROL_ERRS LL_ERRS("ControlErrors") |
@@ -99,8 +99,8 @@ bool LLControlVariable::llsd_compare(const LLSD& a, const LLSD & b) | |||
99 | return result; | 99 | return result; |
100 | } | 100 | } |
101 | 101 | ||
102 | LLControlVariable::LLControlVariable(const LLString& name, eControlType type, | 102 | LLControlVariable::LLControlVariable(const std::string& name, eControlType type, |
103 | LLSD initial, const LLString& comment, | 103 | LLSD initial, const std::string& comment, |
104 | bool persist) | 104 | bool persist) |
105 | : mName(name), | 105 | : mName(name), |
106 | mComment(comment), | 106 | mComment(comment), |
@@ -129,7 +129,7 @@ LLSD LLControlVariable::getComparableValue(const LLSD& value) | |||
129 | if(TYPE_BOOLEAN == type() && value.isString()) | 129 | if(TYPE_BOOLEAN == type() && value.isString()) |
130 | { | 130 | { |
131 | BOOL temp; | 131 | BOOL temp; |
132 | if(LLString::convertToBOOL(value.asString(), temp)) | 132 | if(LLStringUtil::convertToBOOL(value.asString(), temp)) |
133 | { | 133 | { |
134 | storable_value = (bool)temp; | 134 | storable_value = (bool)temp; |
135 | } | 135 | } |
@@ -246,7 +246,7 @@ LLSD LLControlVariable::getSaveValue() const | |||
246 | return mValues[0]; | 246 | return mValues[0]; |
247 | } | 247 | } |
248 | 248 | ||
249 | LLPointer<LLControlVariable> LLControlGroup::getControl(const LLString& name) | 249 | LLPointer<LLControlVariable> LLControlGroup::getControl(const std::string& name) |
250 | { | 250 | { |
251 | ctrl_name_table_t::iterator iter = mNameTable.find(name); | 251 | ctrl_name_table_t::iterator iter = mNameTable.find(name); |
252 | return iter == mNameTable.end() ? LLPointer<LLControlVariable>() : iter->second; | 252 | return iter == mNameTable.end() ? LLPointer<LLControlVariable>() : iter->second; |
@@ -281,7 +281,7 @@ void LLControlGroup::cleanup() | |||
281 | mNameTable.clear(); | 281 | mNameTable.clear(); |
282 | } | 282 | } |
283 | 283 | ||
284 | eControlType LLControlGroup::typeStringToEnum(const LLString& typestr) | 284 | eControlType LLControlGroup::typeStringToEnum(const std::string& typestr) |
285 | { | 285 | { |
286 | for(int i = 0; i < (int)TYPE_COUNT; ++i) | 286 | for(int i = 0; i < (int)TYPE_COUNT; ++i) |
287 | { | 287 | { |
@@ -290,12 +290,12 @@ eControlType LLControlGroup::typeStringToEnum(const LLString& typestr) | |||
290 | return (eControlType)-1; | 290 | return (eControlType)-1; |
291 | } | 291 | } |
292 | 292 | ||
293 | LLString LLControlGroup::typeEnumToString(eControlType typeenum) | 293 | std::string LLControlGroup::typeEnumToString(eControlType typeenum) |
294 | { | 294 | { |
295 | return mTypeString[typeenum]; | 295 | return mTypeString[typeenum]; |
296 | } | 296 | } |
297 | 297 | ||
298 | BOOL LLControlGroup::declareControl(const LLString& name, eControlType type, const LLSD initial_val, const LLString& comment, BOOL persist) | 298 | BOOL LLControlGroup::declareControl(const std::string& name, eControlType type, const LLSD initial_val, const std::string& comment, BOOL persist) |
299 | { | 299 | { |
300 | if(mNameTable.find(name) != mNameTable.end()) | 300 | if(mNameTable.find(name) != mNameTable.end()) |
301 | { | 301 | { |
@@ -310,67 +310,67 @@ BOOL LLControlGroup::declareControl(const LLString& name, eControlType type, con | |||
310 | return TRUE; | 310 | return TRUE; |
311 | } | 311 | } |
312 | 312 | ||
313 | BOOL LLControlGroup::declareU32(const LLString& name, const U32 initial_val, const LLString& comment, BOOL persist) | 313 | BOOL LLControlGroup::declareU32(const std::string& name, const U32 initial_val, const std::string& comment, BOOL persist) |
314 | { | 314 | { |
315 | return declareControl(name, TYPE_U32, (LLSD::Integer) initial_val, comment, persist); | 315 | return declareControl(name, TYPE_U32, (LLSD::Integer) initial_val, comment, persist); |
316 | } | 316 | } |
317 | 317 | ||
318 | BOOL LLControlGroup::declareS32(const LLString& name, const S32 initial_val, const LLString& comment, BOOL persist) | 318 | BOOL LLControlGroup::declareS32(const std::string& name, const S32 initial_val, const std::string& comment, BOOL persist) |
319 | { | 319 | { |
320 | return declareControl(name, TYPE_S32, initial_val, comment, persist); | 320 | return declareControl(name, TYPE_S32, initial_val, comment, persist); |
321 | } | 321 | } |
322 | 322 | ||
323 | BOOL LLControlGroup::declareF32(const LLString& name, const F32 initial_val, const LLString& comment, BOOL persist) | 323 | BOOL LLControlGroup::declareF32(const std::string& name, const F32 initial_val, const std::string& comment, BOOL persist) |
324 | { | 324 | { |
325 | return declareControl(name, TYPE_F32, initial_val, comment, persist); | 325 | return declareControl(name, TYPE_F32, initial_val, comment, persist); |
326 | } | 326 | } |
327 | 327 | ||
328 | BOOL LLControlGroup::declareBOOL(const LLString& name, const BOOL initial_val, const LLString& comment, BOOL persist) | 328 | BOOL LLControlGroup::declareBOOL(const std::string& name, const BOOL initial_val, const std::string& comment, BOOL persist) |
329 | { | 329 | { |
330 | return declareControl(name, TYPE_BOOLEAN, initial_val, comment, persist); | 330 | return declareControl(name, TYPE_BOOLEAN, initial_val, comment, persist); |
331 | } | 331 | } |
332 | 332 | ||
333 | BOOL LLControlGroup::declareString(const LLString& name, const LLString& initial_val, const LLString& comment, BOOL persist) | 333 | BOOL LLControlGroup::declareString(const std::string& name, const std::string& initial_val, const std::string& comment, BOOL persist) |
334 | { | 334 | { |
335 | return declareControl(name, TYPE_STRING, initial_val, comment, persist); | 335 | return declareControl(name, TYPE_STRING, initial_val, comment, persist); |
336 | } | 336 | } |
337 | 337 | ||
338 | BOOL LLControlGroup::declareVec3(const LLString& name, const LLVector3 &initial_val, const LLString& comment, BOOL persist) | 338 | BOOL LLControlGroup::declareVec3(const std::string& name, const LLVector3 &initial_val, const std::string& comment, BOOL persist) |
339 | { | 339 | { |
340 | return declareControl(name, TYPE_VEC3, initial_val.getValue(), comment, persist); | 340 | return declareControl(name, TYPE_VEC3, initial_val.getValue(), comment, persist); |
341 | } | 341 | } |
342 | 342 | ||
343 | BOOL LLControlGroup::declareVec3d(const LLString& name, const LLVector3d &initial_val, const LLString& comment, BOOL persist) | 343 | BOOL LLControlGroup::declareVec3d(const std::string& name, const LLVector3d &initial_val, const std::string& comment, BOOL persist) |
344 | { | 344 | { |
345 | return declareControl(name, TYPE_VEC3D, initial_val.getValue(), comment, persist); | 345 | return declareControl(name, TYPE_VEC3D, initial_val.getValue(), comment, persist); |
346 | } | 346 | } |
347 | 347 | ||
348 | BOOL LLControlGroup::declareRect(const LLString& name, const LLRect &initial_val, const LLString& comment, BOOL persist) | 348 | BOOL LLControlGroup::declareRect(const std::string& name, const LLRect &initial_val, const std::string& comment, BOOL persist) |
349 | { | 349 | { |
350 | return declareControl(name, TYPE_RECT, initial_val.getValue(), comment, persist); | 350 | return declareControl(name, TYPE_RECT, initial_val.getValue(), comment, persist); |
351 | } | 351 | } |
352 | 352 | ||
353 | BOOL LLControlGroup::declareColor4U(const LLString& name, const LLColor4U &initial_val, const LLString& comment, BOOL persist ) | 353 | BOOL LLControlGroup::declareColor4U(const std::string& name, const LLColor4U &initial_val, const std::string& comment, BOOL persist ) |
354 | { | 354 | { |
355 | return declareControl(name, TYPE_COL4U, initial_val.getValue(), comment, persist); | 355 | return declareControl(name, TYPE_COL4U, initial_val.getValue(), comment, persist); |
356 | } | 356 | } |
357 | 357 | ||
358 | BOOL LLControlGroup::declareColor4(const LLString& name, const LLColor4 &initial_val, const LLString& comment, BOOL persist ) | 358 | BOOL LLControlGroup::declareColor4(const std::string& name, const LLColor4 &initial_val, const std::string& comment, BOOL persist ) |
359 | { | 359 | { |
360 | return declareControl(name, TYPE_COL4, initial_val.getValue(), comment, persist); | 360 | return declareControl(name, TYPE_COL4, initial_val.getValue(), comment, persist); |
361 | } | 361 | } |
362 | 362 | ||
363 | BOOL LLControlGroup::declareColor3(const LLString& name, const LLColor3 &initial_val, const LLString& comment, BOOL persist ) | 363 | BOOL LLControlGroup::declareColor3(const std::string& name, const LLColor3 &initial_val, const std::string& comment, BOOL persist ) |
364 | { | 364 | { |
365 | return declareControl(name, TYPE_COL3, initial_val.getValue(), comment, persist); | 365 | return declareControl(name, TYPE_COL3, initial_val.getValue(), comment, persist); |
366 | } | 366 | } |
367 | 367 | ||
368 | BOOL LLControlGroup::declareLLSD(const LLString& name, const LLSD &initial_val, const LLString& comment, BOOL persist ) | 368 | BOOL LLControlGroup::declareLLSD(const std::string& name, const LLSD &initial_val, const std::string& comment, BOOL persist ) |
369 | { | 369 | { |
370 | return declareControl(name, TYPE_LLSD, initial_val, comment, persist); | 370 | return declareControl(name, TYPE_LLSD, initial_val, comment, persist); |
371 | } | 371 | } |
372 | 372 | ||
373 | BOOL LLControlGroup::getBOOL(const LLString& name) | 373 | BOOL LLControlGroup::getBOOL(const std::string& name) |
374 | { | 374 | { |
375 | LLControlVariable* control = getControl(name); | 375 | LLControlVariable* control = getControl(name); |
376 | 376 | ||
@@ -383,7 +383,7 @@ BOOL LLControlGroup::getBOOL(const LLString& name) | |||
383 | } | 383 | } |
384 | } | 384 | } |
385 | 385 | ||
386 | S32 LLControlGroup::getS32(const LLString& name) | 386 | S32 LLControlGroup::getS32(const std::string& name) |
387 | { | 387 | { |
388 | LLControlVariable* control = getControl(name); | 388 | LLControlVariable* control = getControl(name); |
389 | 389 | ||
@@ -396,7 +396,7 @@ S32 LLControlGroup::getS32(const LLString& name) | |||
396 | } | 396 | } |
397 | } | 397 | } |
398 | 398 | ||
399 | U32 LLControlGroup::getU32(const LLString& name) | 399 | U32 LLControlGroup::getU32(const std::string& name) |
400 | { | 400 | { |
401 | LLControlVariable* control = getControl(name); | 401 | LLControlVariable* control = getControl(name); |
402 | 402 | ||
@@ -409,7 +409,7 @@ U32 LLControlGroup::getU32(const LLString& name) | |||
409 | } | 409 | } |
410 | } | 410 | } |
411 | 411 | ||
412 | F32 LLControlGroup::getF32(const LLString& name) | 412 | F32 LLControlGroup::getF32(const std::string& name) |
413 | { | 413 | { |
414 | LLControlVariable* control = getControl(name); | 414 | LLControlVariable* control = getControl(name); |
415 | 415 | ||
@@ -422,16 +422,16 @@ F32 LLControlGroup::getF32(const LLString& name) | |||
422 | } | 422 | } |
423 | } | 423 | } |
424 | 424 | ||
425 | LLString LLControlGroup::findString(const LLString& name) | 425 | std::string LLControlGroup::findString(const std::string& name) |
426 | { | 426 | { |
427 | LLControlVariable* control = getControl(name); | 427 | LLControlVariable* control = getControl(name); |
428 | 428 | ||
429 | if (control && control->isType(TYPE_STRING)) | 429 | if (control && control->isType(TYPE_STRING)) |
430 | return control->get().asString(); | 430 | return control->get().asString(); |
431 | return LLString::null; | 431 | return LLStringUtil::null; |
432 | } | 432 | } |
433 | 433 | ||
434 | LLString LLControlGroup::getString(const LLString& name) | 434 | std::string LLControlGroup::getString(const std::string& name) |
435 | { | 435 | { |
436 | LLControlVariable* control = getControl(name); | 436 | LLControlVariable* control = getControl(name); |
437 | 437 | ||
@@ -440,24 +440,24 @@ LLString LLControlGroup::getString(const LLString& name) | |||
440 | else | 440 | else |
441 | { | 441 | { |
442 | CONTROL_ERRS << "Invalid string control " << name << llendl; | 442 | CONTROL_ERRS << "Invalid string control " << name << llendl; |
443 | return LLString::null; | 443 | return LLStringUtil::null; |
444 | } | 444 | } |
445 | } | 445 | } |
446 | 446 | ||
447 | LLWString LLControlGroup::getWString(const LLString& name) | 447 | LLWString LLControlGroup::getWString(const std::string& name) |
448 | { | 448 | { |
449 | return utf8str_to_wstring(getString(name)); | 449 | return utf8str_to_wstring(getString(name)); |
450 | } | 450 | } |
451 | 451 | ||
452 | LLString LLControlGroup::getText(const LLString& name) | 452 | std::string LLControlGroup::getText(const std::string& name) |
453 | { | 453 | { |
454 | LLString utf8_string = getString(name); | 454 | std::string utf8_string = getString(name); |
455 | LLString::replaceChar(utf8_string, '^', '\n'); | 455 | LLStringUtil::replaceChar(utf8_string, '^', '\n'); |
456 | LLString::replaceChar(utf8_string, '%', ' '); | 456 | LLStringUtil::replaceChar(utf8_string, '%', ' '); |
457 | return (utf8_string); | 457 | return (utf8_string); |
458 | } | 458 | } |
459 | 459 | ||
460 | LLVector3 LLControlGroup::getVector3(const LLString& name) | 460 | LLVector3 LLControlGroup::getVector3(const std::string& name) |
461 | { | 461 | { |
462 | LLControlVariable* control = getControl(name); | 462 | LLControlVariable* control = getControl(name); |
463 | 463 | ||
@@ -470,7 +470,7 @@ LLVector3 LLControlGroup::getVector3(const LLString& name) | |||
470 | } | 470 | } |
471 | } | 471 | } |
472 | 472 | ||
473 | LLVector3d LLControlGroup::getVector3d(const LLString& name) | 473 | LLVector3d LLControlGroup::getVector3d(const std::string& name) |
474 | { | 474 | { |
475 | LLControlVariable* control = getControl(name); | 475 | LLControlVariable* control = getControl(name); |
476 | 476 | ||
@@ -483,7 +483,7 @@ LLVector3d LLControlGroup::getVector3d(const LLString& name) | |||
483 | } | 483 | } |
484 | } | 484 | } |
485 | 485 | ||
486 | LLRect LLControlGroup::getRect(const LLString& name) | 486 | LLRect LLControlGroup::getRect(const std::string& name) |
487 | { | 487 | { |
488 | LLControlVariable* control = getControl(name); | 488 | LLControlVariable* control = getControl(name); |
489 | 489 | ||
@@ -497,7 +497,7 @@ LLRect LLControlGroup::getRect(const LLString& name) | |||
497 | } | 497 | } |
498 | 498 | ||
499 | 499 | ||
500 | LLColor4 LLControlGroup::getColor(const LLString& name) | 500 | LLColor4 LLControlGroup::getColor(const std::string& name) |
501 | { | 501 | { |
502 | ctrl_name_table_t::const_iterator i = mNameTable.find(name); | 502 | ctrl_name_table_t::const_iterator i = mNameTable.find(name); |
503 | 503 | ||
@@ -529,7 +529,7 @@ LLColor4 LLControlGroup::getColor(const LLString& name) | |||
529 | } | 529 | } |
530 | } | 530 | } |
531 | 531 | ||
532 | LLColor4U LLControlGroup::getColor4U(const LLString& name) | 532 | LLColor4U LLControlGroup::getColor4U(const std::string& name) |
533 | { | 533 | { |
534 | LLControlVariable* control = getControl(name); | 534 | LLControlVariable* control = getControl(name); |
535 | 535 | ||
@@ -542,7 +542,7 @@ LLColor4U LLControlGroup::getColor4U(const LLString& name) | |||
542 | } | 542 | } |
543 | } | 543 | } |
544 | 544 | ||
545 | LLColor4 LLControlGroup::getColor4(const LLString& name) | 545 | LLColor4 LLControlGroup::getColor4(const std::string& name) |
546 | { | 546 | { |
547 | LLControlVariable* control = getControl(name); | 547 | LLControlVariable* control = getControl(name); |
548 | 548 | ||
@@ -555,7 +555,7 @@ LLColor4 LLControlGroup::getColor4(const LLString& name) | |||
555 | } | 555 | } |
556 | } | 556 | } |
557 | 557 | ||
558 | LLColor3 LLControlGroup::getColor3(const LLString& name) | 558 | LLColor3 LLControlGroup::getColor3(const std::string& name) |
559 | { | 559 | { |
560 | LLControlVariable* control = getControl(name); | 560 | LLControlVariable* control = getControl(name); |
561 | 561 | ||
@@ -568,7 +568,7 @@ LLColor3 LLControlGroup::getColor3(const LLString& name) | |||
568 | } | 568 | } |
569 | } | 569 | } |
570 | 570 | ||
571 | LLSD LLControlGroup::getLLSD(const LLString& name) | 571 | LLSD LLControlGroup::getLLSD(const std::string& name) |
572 | { | 572 | { |
573 | LLControlVariable* control = getControl(name); | 573 | LLControlVariable* control = getControl(name); |
574 | 574 | ||
@@ -578,7 +578,7 @@ LLSD LLControlGroup::getLLSD(const LLString& name) | |||
578 | return LLSD(); | 578 | return LLSD(); |
579 | } | 579 | } |
580 | 580 | ||
581 | BOOL LLControlGroup::controlExists(const LLString& name) | 581 | BOOL LLControlGroup::controlExists(const std::string& name) |
582 | { | 582 | { |
583 | ctrl_name_table_t::iterator iter = mNameTable.find(name); | 583 | ctrl_name_table_t::iterator iter = mNameTable.find(name); |
584 | return iter != mNameTable.end(); | 584 | return iter != mNameTable.end(); |
@@ -588,7 +588,7 @@ BOOL LLControlGroup::controlExists(const LLString& name) | |||
588 | // Set functions | 588 | // Set functions |
589 | //------------------------------------------------------------------- | 589 | //------------------------------------------------------------------- |
590 | 590 | ||
591 | void LLControlGroup::setBOOL(const LLString& name, BOOL val) | 591 | void LLControlGroup::setBOOL(const std::string& name, BOOL val) |
592 | { | 592 | { |
593 | LLControlVariable* control = getControl(name); | 593 | LLControlVariable* control = getControl(name); |
594 | 594 | ||
@@ -603,7 +603,7 @@ void LLControlGroup::setBOOL(const LLString& name, BOOL val) | |||
603 | } | 603 | } |
604 | 604 | ||
605 | 605 | ||
606 | void LLControlGroup::setS32(const LLString& name, S32 val) | 606 | void LLControlGroup::setS32(const std::string& name, S32 val) |
607 | { | 607 | { |
608 | LLControlVariable* control = getControl(name); | 608 | LLControlVariable* control = getControl(name); |
609 | 609 | ||
@@ -618,7 +618,7 @@ void LLControlGroup::setS32(const LLString& name, S32 val) | |||
618 | } | 618 | } |
619 | 619 | ||
620 | 620 | ||
621 | void LLControlGroup::setF32(const LLString& name, F32 val) | 621 | void LLControlGroup::setF32(const std::string& name, F32 val) |
622 | { | 622 | { |
623 | LLControlVariable* control = getControl(name); | 623 | LLControlVariable* control = getControl(name); |
624 | 624 | ||
@@ -633,7 +633,7 @@ void LLControlGroup::setF32(const LLString& name, F32 val) | |||
633 | } | 633 | } |
634 | 634 | ||
635 | 635 | ||
636 | void LLControlGroup::setU32(const LLString& name, U32 val) | 636 | void LLControlGroup::setU32(const std::string& name, U32 val) |
637 | { | 637 | { |
638 | LLControlVariable* control = getControl(name); | 638 | LLControlVariable* control = getControl(name); |
639 | 639 | ||
@@ -648,7 +648,7 @@ void LLControlGroup::setU32(const LLString& name, U32 val) | |||
648 | } | 648 | } |
649 | 649 | ||
650 | 650 | ||
651 | void LLControlGroup::setString(const LLString& name, const LLString &val) | 651 | void LLControlGroup::setString(const std::string& name, const std::string &val) |
652 | { | 652 | { |
653 | LLControlVariable* control = getControl(name); | 653 | LLControlVariable* control = getControl(name); |
654 | 654 | ||
@@ -663,7 +663,7 @@ void LLControlGroup::setString(const LLString& name, const LLString &val) | |||
663 | } | 663 | } |
664 | 664 | ||
665 | 665 | ||
666 | void LLControlGroup::setVector3(const LLString& name, const LLVector3 &val) | 666 | void LLControlGroup::setVector3(const std::string& name, const LLVector3 &val) |
667 | { | 667 | { |
668 | LLControlVariable* control = getControl(name); | 668 | LLControlVariable* control = getControl(name); |
669 | 669 | ||
@@ -677,7 +677,7 @@ void LLControlGroup::setVector3(const LLString& name, const LLVector3 &val) | |||
677 | } | 677 | } |
678 | } | 678 | } |
679 | 679 | ||
680 | void LLControlGroup::setVector3d(const LLString& name, const LLVector3d &val) | 680 | void LLControlGroup::setVector3d(const std::string& name, const LLVector3d &val) |
681 | { | 681 | { |
682 | LLControlVariable* control = getControl(name); | 682 | LLControlVariable* control = getControl(name); |
683 | 683 | ||
@@ -691,7 +691,7 @@ void LLControlGroup::setVector3d(const LLString& name, const LLVector3d &val) | |||
691 | } | 691 | } |
692 | } | 692 | } |
693 | 693 | ||
694 | void LLControlGroup::setRect(const LLString& name, const LLRect &val) | 694 | void LLControlGroup::setRect(const std::string& name, const LLRect &val) |
695 | { | 695 | { |
696 | LLControlVariable* control = getControl(name); | 696 | LLControlVariable* control = getControl(name); |
697 | 697 | ||
@@ -705,7 +705,7 @@ void LLControlGroup::setRect(const LLString& name, const LLRect &val) | |||
705 | } | 705 | } |
706 | } | 706 | } |
707 | 707 | ||
708 | void LLControlGroup::setColor4U(const LLString& name, const LLColor4U &val) | 708 | void LLControlGroup::setColor4U(const std::string& name, const LLColor4U &val) |
709 | { | 709 | { |
710 | LLControlVariable* control = getControl(name); | 710 | LLControlVariable* control = getControl(name); |
711 | 711 | ||
@@ -719,7 +719,7 @@ void LLControlGroup::setColor4U(const LLString& name, const LLColor4U &val) | |||
719 | } | 719 | } |
720 | } | 720 | } |
721 | 721 | ||
722 | void LLControlGroup::setColor4(const LLString& name, const LLColor4 &val) | 722 | void LLControlGroup::setColor4(const std::string& name, const LLColor4 &val) |
723 | { | 723 | { |
724 | LLControlVariable* control = getControl(name); | 724 | LLControlVariable* control = getControl(name); |
725 | 725 | ||
@@ -733,7 +733,7 @@ void LLControlGroup::setColor4(const LLString& name, const LLColor4 &val) | |||
733 | } | 733 | } |
734 | } | 734 | } |
735 | 735 | ||
736 | void LLControlGroup::setLLSD(const LLString& name, const LLSD& val) | 736 | void LLControlGroup::setLLSD(const std::string& name, const LLSD& val) |
737 | { | 737 | { |
738 | LLControlVariable* control = getControl(name); | 738 | LLControlVariable* control = getControl(name); |
739 | 739 | ||
@@ -747,7 +747,7 @@ void LLControlGroup::setLLSD(const LLString& name, const LLSD& val) | |||
747 | } | 747 | } |
748 | } | 748 | } |
749 | 749 | ||
750 | void LLControlGroup::setValue(const LLString& name, const LLSD& val) | 750 | void LLControlGroup::setValue(const std::string& name, const LLSD& val) |
751 | { | 751 | { |
752 | if (name.empty()) | 752 | if (name.empty()) |
753 | { | 753 | { |
@@ -771,9 +771,9 @@ void LLControlGroup::setValue(const LLString& name, const LLSD& val) | |||
771 | //--------------------------------------------------------------- | 771 | //--------------------------------------------------------------- |
772 | 772 | ||
773 | // Returns number of controls loaded, so 0 if failure | 773 | // Returns number of controls loaded, so 0 if failure |
774 | U32 LLControlGroup::loadFromFileLegacy(const LLString& filename, BOOL require_declaration, eControlType declare_as) | 774 | U32 LLControlGroup::loadFromFileLegacy(const std::string& filename, BOOL require_declaration, eControlType declare_as) |
775 | { | 775 | { |
776 | LLString name; | 776 | std::string name; |
777 | 777 | ||
778 | LLXmlTree xml_controls; | 778 | LLXmlTree xml_controls; |
779 | 779 | ||
@@ -832,14 +832,14 @@ U32 LLControlGroup::loadFromFileLegacy(const LLString& filename, BOOL require_de | |||
832 | switch(declare_as) | 832 | switch(declare_as) |
833 | { | 833 | { |
834 | case TYPE_COL4: | 834 | case TYPE_COL4: |
835 | declareColor4(name, LLColor4::white, "", NO_PERSIST); | 835 | declareColor4(name, LLColor4::white, LLStringUtil::null, NO_PERSIST); |
836 | break; | 836 | break; |
837 | case TYPE_COL4U: | 837 | case TYPE_COL4U: |
838 | declareColor4U(name, LLColor4U::white, "", NO_PERSIST); | 838 | declareColor4U(name, LLColor4U::white, LLStringUtil::null, NO_PERSIST); |
839 | break; | 839 | break; |
840 | case TYPE_STRING: | 840 | case TYPE_STRING: |
841 | default: | 841 | default: |
842 | declareString(name, LLString::null, "", NO_PERSIST); | 842 | declareString(name, LLStringUtil::null, LLStringUtil::null, NO_PERSIST); |
843 | break; | 843 | break; |
844 | } | 844 | } |
845 | } | 845 | } |
@@ -891,12 +891,8 @@ U32 LLControlGroup::loadFromFileLegacy(const LLString& filename, BOOL require_de | |||
891 | break; | 891 | break; |
892 | case TYPE_STRING: | 892 | case TYPE_STRING: |
893 | { | 893 | { |
894 | LLString string; | 894 | std::string string; |
895 | child_nodep->getAttributeString("value", string); | 895 | child_nodep->getAttributeString("value", string); |
896 | if (string == LLString::null) | ||
897 | { | ||
898 | string = ""; | ||
899 | } | ||
900 | control->set(string); | 896 | control->set(string); |
901 | validitems++; | 897 | validitems++; |
902 | } | 898 | } |
@@ -923,7 +919,7 @@ U32 LLControlGroup::loadFromFileLegacy(const LLString& filename, BOOL require_de | |||
923 | case TYPE_RECT: | 919 | case TYPE_RECT: |
924 | { | 920 | { |
925 | //RN: hack to support reading rectangles from a string | 921 | //RN: hack to support reading rectangles from a string |
926 | LLString rect_string; | 922 | std::string rect_string; |
927 | 923 | ||
928 | child_nodep->getAttributeString("value", rect_string); | 924 | child_nodep->getAttributeString("value", rect_string); |
929 | std::istringstream istream(rect_string); | 925 | std::istringstream istream(rect_string); |
@@ -977,7 +973,7 @@ U32 LLControlGroup::loadFromFileLegacy(const LLString& filename, BOOL require_de | |||
977 | return validitems; | 973 | return validitems; |
978 | } | 974 | } |
979 | 975 | ||
980 | U32 LLControlGroup::saveToFile(const LLString& filename, BOOL nondefault_only) | 976 | U32 LLControlGroup::saveToFile(const std::string& filename, BOOL nondefault_only) |
981 | { | 977 | { |
982 | LLSD settings; | 978 | LLSD settings; |
983 | int num_saved = 0; | 979 | int num_saved = 0; |
@@ -1007,7 +1003,7 @@ U32 LLControlGroup::saveToFile(const LLString& filename, BOOL nondefault_only) | |||
1007 | } | 1003 | } |
1008 | } | 1004 | } |
1009 | llofstream file; | 1005 | llofstream file; |
1010 | file.open(filename.c_str()); | 1006 | file.open(filename); |
1011 | if (file.is_open()) | 1007 | if (file.is_open()) |
1012 | { | 1008 | { |
1013 | LLSDSerialize::toPrettyXML(settings, file); | 1009 | LLSDSerialize::toPrettyXML(settings, file); |
@@ -1023,13 +1019,13 @@ U32 LLControlGroup::saveToFile(const LLString& filename, BOOL nondefault_only) | |||
1023 | return num_saved; | 1019 | return num_saved; |
1024 | } | 1020 | } |
1025 | 1021 | ||
1026 | U32 LLControlGroup::loadFromFile(const LLString& filename, bool set_default_values) | 1022 | U32 LLControlGroup::loadFromFile(const std::string& filename, bool set_default_values) |
1027 | { | 1023 | { |
1028 | LLString name; | 1024 | std::string name; |
1029 | LLSD settings; | 1025 | LLSD settings; |
1030 | LLSD control_map; | 1026 | LLSD control_map; |
1031 | llifstream infile; | 1027 | llifstream infile; |
1032 | infile.open(filename.c_str()); | 1028 | infile.open(filename); |
1033 | if(!infile.is_open()) | 1029 | if(!infile.is_open()) |
1034 | { | 1030 | { |
1035 | llwarns << "Cannot find file " << filename << " to load." << llendl; | 1031 | llwarns << "Cannot find file " << filename << " to load." << llendl; |
@@ -1127,10 +1123,10 @@ void LLControlGroup::applyToAll(ApplyFunctor* func) | |||
1127 | //============================================================================ | 1123 | //============================================================================ |
1128 | // First-use | 1124 | // First-use |
1129 | 1125 | ||
1130 | static LLString get_warn_name(const LLString& name) | 1126 | static std::string get_warn_name(const std::string& name) |
1131 | { | 1127 | { |
1132 | LLString warnname = "Warn" + name; | 1128 | std::string warnname = "Warn" + name; |
1133 | for (LLString::iterator iter = warnname.begin(); iter != warnname.end(); ++iter) | 1129 | for (std::string::iterator iter = warnname.begin(); iter != warnname.end(); ++iter) |
1134 | { | 1130 | { |
1135 | char c = *iter; | 1131 | char c = *iter; |
1136 | if (!isalnum(c)) | 1132 | if (!isalnum(c)) |
@@ -1141,32 +1137,32 @@ static LLString get_warn_name(const LLString& name) | |||
1141 | return warnname; | 1137 | return warnname; |
1142 | } | 1138 | } |
1143 | 1139 | ||
1144 | void LLControlGroup::addWarning(const LLString& name) | 1140 | void LLControlGroup::addWarning(const std::string& name) |
1145 | { | 1141 | { |
1146 | LLString warnname = get_warn_name(name); | 1142 | std::string warnname = get_warn_name(name); |
1147 | if(mNameTable.find(warnname) == mNameTable.end()) | 1143 | if(mNameTable.find(warnname) == mNameTable.end()) |
1148 | { | 1144 | { |
1149 | LLString comment = LLString("Enables ") + name + LLString(" warning dialog"); | 1145 | std::string comment = std::string("Enables ") + name + std::string(" warning dialog"); |
1150 | declareBOOL(warnname, TRUE, comment); | 1146 | declareBOOL(warnname, TRUE, comment); |
1151 | mWarnings.insert(warnname); | 1147 | mWarnings.insert(warnname); |
1152 | } | 1148 | } |
1153 | } | 1149 | } |
1154 | 1150 | ||
1155 | BOOL LLControlGroup::getWarning(const LLString& name) | 1151 | BOOL LLControlGroup::getWarning(const std::string& name) |
1156 | { | 1152 | { |
1157 | LLString warnname = get_warn_name(name); | 1153 | std::string warnname = get_warn_name(name); |
1158 | return getBOOL(warnname); | 1154 | return getBOOL(warnname); |
1159 | } | 1155 | } |
1160 | 1156 | ||
1161 | void LLControlGroup::setWarning(const LLString& name, BOOL val) | 1157 | void LLControlGroup::setWarning(const std::string& name, BOOL val) |
1162 | { | 1158 | { |
1163 | LLString warnname = get_warn_name(name); | 1159 | std::string warnname = get_warn_name(name); |
1164 | setBOOL(warnname, val); | 1160 | setBOOL(warnname, val); |
1165 | } | 1161 | } |
1166 | 1162 | ||
1167 | void LLControlGroup::resetWarnings() | 1163 | void LLControlGroup::resetWarnings() |
1168 | { | 1164 | { |
1169 | for (std::set<LLString>::iterator iter = mWarnings.begin(); | 1165 | for (std::set<std::string>::iterator iter = mWarnings.begin(); |
1170 | iter != mWarnings.end(); ++iter) | 1166 | iter != mWarnings.end(); ++iter) |
1171 | { | 1167 | { |
1172 | setBOOL(*iter, TRUE); | 1168 | setBOOL(*iter, TRUE); |
diff --git a/linden/indra/llxml/llcontrol.h b/linden/indra/llxml/llcontrol.h index 2500ae0..6205964 100644 --- a/linden/indra/llxml/llcontrol.h +++ b/linden/indra/llxml/llcontrol.h | |||
@@ -89,8 +89,8 @@ class LLControlVariable : public LLRefCount | |||
89 | typedef boost::signal<void(const LLSD&)> signal_t; | 89 | typedef boost::signal<void(const LLSD&)> signal_t; |
90 | 90 | ||
91 | private: | 91 | private: |
92 | LLString mName; | 92 | std::string mName; |
93 | LLString mComment; | 93 | std::string mComment; |
94 | eControlType mType; | 94 | eControlType mType; |
95 | bool mPersist; | 95 | bool mPersist; |
96 | std::vector<LLSD> mValues; | 96 | std::vector<LLSD> mValues; |
@@ -98,14 +98,14 @@ private: | |||
98 | signal_t mSignal; | 98 | signal_t mSignal; |
99 | 99 | ||
100 | public: | 100 | public: |
101 | LLControlVariable(const LLString& name, eControlType type, | 101 | LLControlVariable(const std::string& name, eControlType type, |
102 | LLSD initial, const LLString& comment, | 102 | LLSD initial, const std::string& comment, |
103 | bool persist = true); | 103 | bool persist = true); |
104 | 104 | ||
105 | virtual ~LLControlVariable(); | 105 | virtual ~LLControlVariable(); |
106 | 106 | ||
107 | const LLString& getName() const { return mName; } | 107 | const std::string& getName() const { return mName; } |
108 | const LLString& getComment() const { return mComment; } | 108 | const std::string& getComment() const { return mComment; } |
109 | 109 | ||
110 | eControlType type() { return mType; } | 110 | eControlType type() { return mType; } |
111 | bool isType(eControlType tp) { return tp == mType; } | 111 | bool isType(eControlType tp) { return tp == mType; } |
@@ -142,95 +142,95 @@ private: | |||
142 | class LLControlGroup | 142 | class LLControlGroup |
143 | { | 143 | { |
144 | protected: | 144 | protected: |
145 | typedef std::map<LLString, LLPointer<LLControlVariable> > ctrl_name_table_t; | 145 | typedef std::map<std::string, LLPointer<LLControlVariable> > ctrl_name_table_t; |
146 | ctrl_name_table_t mNameTable; | 146 | ctrl_name_table_t mNameTable; |
147 | std::set<LLString> mWarnings; | 147 | std::set<std::string> mWarnings; |
148 | LLString mTypeString[TYPE_COUNT]; | 148 | std::string mTypeString[TYPE_COUNT]; |
149 | 149 | ||
150 | eControlType typeStringToEnum(const LLString& typestr); | 150 | eControlType typeStringToEnum(const std::string& typestr); |
151 | LLString typeEnumToString(eControlType typeenum); | 151 | std::string typeEnumToString(eControlType typeenum); |
152 | public: | 152 | public: |
153 | LLControlGroup(); | 153 | LLControlGroup(); |
154 | ~LLControlGroup(); | 154 | ~LLControlGroup(); |
155 | void cleanup(); | 155 | void cleanup(); |
156 | 156 | ||
157 | LLPointer<LLControlVariable> getControl(const LLString& name); | 157 | LLPointer<LLControlVariable> getControl(const std::string& name); |
158 | 158 | ||
159 | struct ApplyFunctor | 159 | struct ApplyFunctor |
160 | { | 160 | { |
161 | virtual ~ApplyFunctor() {}; | 161 | virtual ~ApplyFunctor() {}; |
162 | virtual void apply(const LLString& name, LLControlVariable* control) = 0; | 162 | virtual void apply(const std::string& name, LLControlVariable* control) = 0; |
163 | }; | 163 | }; |
164 | void applyToAll(ApplyFunctor* func); | 164 | void applyToAll(ApplyFunctor* func); |
165 | 165 | ||
166 | BOOL declareControl(const LLString& name, eControlType type, const LLSD initial_val, const LLString& comment, BOOL persist); | 166 | BOOL declareControl(const std::string& name, eControlType type, const LLSD initial_val, const std::string& comment, BOOL persist); |
167 | BOOL declareU32(const LLString& name, U32 initial_val, const LLString& comment, BOOL persist = TRUE); | 167 | BOOL declareU32(const std::string& name, U32 initial_val, const std::string& comment, BOOL persist = TRUE); |
168 | BOOL declareS32(const LLString& name, S32 initial_val, const LLString& comment, BOOL persist = TRUE); | 168 | BOOL declareS32(const std::string& name, S32 initial_val, const std::string& comment, BOOL persist = TRUE); |
169 | BOOL declareF32(const LLString& name, F32 initial_val, const LLString& comment, BOOL persist = TRUE); | 169 | BOOL declareF32(const std::string& name, F32 initial_val, const std::string& comment, BOOL persist = TRUE); |
170 | BOOL declareBOOL(const LLString& name, BOOL initial_val, const LLString& comment, BOOL persist = TRUE); | 170 | BOOL declareBOOL(const std::string& name, BOOL initial_val, const std::string& comment, BOOL persist = TRUE); |
171 | BOOL declareString(const LLString& name, const LLString &initial_val, const LLString& comment, BOOL persist = TRUE); | 171 | BOOL declareString(const std::string& name, const std::string &initial_val, const std::string& comment, BOOL persist = TRUE); |
172 | BOOL declareVec3(const LLString& name, const LLVector3 &initial_val,const LLString& comment, BOOL persist = TRUE); | 172 | BOOL declareVec3(const std::string& name, const LLVector3 &initial_val,const std::string& comment, BOOL persist = TRUE); |
173 | BOOL declareVec3d(const LLString& name, const LLVector3d &initial_val, const LLString& comment, BOOL persist = TRUE); | 173 | BOOL declareVec3d(const std::string& name, const LLVector3d &initial_val, const std::string& comment, BOOL persist = TRUE); |
174 | BOOL declareRect(const LLString& name, const LLRect &initial_val, const LLString& comment, BOOL persist = TRUE); | 174 | BOOL declareRect(const std::string& name, const LLRect &initial_val, const std::string& comment, BOOL persist = TRUE); |
175 | BOOL declareColor4U(const LLString& name, const LLColor4U &initial_val, const LLString& comment, BOOL persist = TRUE); | 175 | BOOL declareColor4U(const std::string& name, const LLColor4U &initial_val, const std::string& comment, BOOL persist = TRUE); |
176 | BOOL declareColor4(const LLString& name, const LLColor4 &initial_val, const LLString& comment, BOOL persist = TRUE); | 176 | BOOL declareColor4(const std::string& name, const LLColor4 &initial_val, const std::string& comment, BOOL persist = TRUE); |
177 | BOOL declareColor3(const LLString& name, const LLColor3 &initial_val, const LLString& comment, BOOL persist = TRUE); | 177 | BOOL declareColor3(const std::string& name, const LLColor3 &initial_val, const std::string& comment, BOOL persist = TRUE); |
178 | BOOL declareLLSD(const LLString& name, const LLSD &initial_val, const LLString& comment, BOOL persist = TRUE); | 178 | BOOL declareLLSD(const std::string& name, const LLSD &initial_val, const std::string& comment, BOOL persist = TRUE); |
179 | 179 | ||
180 | LLString findString(const LLString& name); | 180 | std::string findString(const std::string& name); |
181 | 181 | ||
182 | LLString getString(const LLString& name); | 182 | std::string getString(const std::string& name); |
183 | LLWString getWString(const LLString& name); | 183 | LLWString getWString(const std::string& name); |
184 | LLString getText(const LLString& name); | 184 | std::string getText(const std::string& name); |
185 | LLVector3 getVector3(const LLString& name); | 185 | LLVector3 getVector3(const std::string& name); |
186 | LLVector3d getVector3d(const LLString& name); | 186 | LLVector3d getVector3d(const std::string& name); |
187 | LLRect getRect(const LLString& name); | 187 | LLRect getRect(const std::string& name); |
188 | BOOL getBOOL(const LLString& name); | 188 | BOOL getBOOL(const std::string& name); |
189 | S32 getS32(const LLString& name); | 189 | S32 getS32(const std::string& name); |
190 | F32 getF32(const LLString& name); | 190 | F32 getF32(const std::string& name); |
191 | U32 getU32(const LLString& name); | 191 | U32 getU32(const std::string& name); |
192 | LLSD getLLSD(const LLString& name); | 192 | LLSD getLLSD(const std::string& name); |
193 | 193 | ||
194 | 194 | ||
195 | // Note: If an LLColor4U control exists, it will cast it to the correct | 195 | // Note: If an LLColor4U control exists, it will cast it to the correct |
196 | // LLColor4 for you. | 196 | // LLColor4 for you. |
197 | LLColor4 getColor(const LLString& name); | 197 | LLColor4 getColor(const std::string& name); |
198 | LLColor4U getColor4U(const LLString& name); | 198 | LLColor4U getColor4U(const std::string& name); |
199 | LLColor4 getColor4(const LLString& name); | 199 | LLColor4 getColor4(const std::string& name); |
200 | LLColor3 getColor3(const LLString& name); | 200 | LLColor3 getColor3(const std::string& name); |
201 | 201 | ||
202 | void setBOOL(const LLString& name, BOOL val); | 202 | void setBOOL(const std::string& name, BOOL val); |
203 | void setS32(const LLString& name, S32 val); | 203 | void setS32(const std::string& name, S32 val); |
204 | void setF32(const LLString& name, F32 val); | 204 | void setF32(const std::string& name, F32 val); |
205 | void setU32(const LLString& name, U32 val); | 205 | void setU32(const std::string& name, U32 val); |
206 | void setString(const LLString& name, const LLString& val); | 206 | void setString(const std::string& name, const std::string& val); |
207 | void setVector3(const LLString& name, const LLVector3 &val); | 207 | void setVector3(const std::string& name, const LLVector3 &val); |
208 | void setVector3d(const LLString& name, const LLVector3d &val); | 208 | void setVector3d(const std::string& name, const LLVector3d &val); |
209 | void setRect(const LLString& name, const LLRect &val); | 209 | void setRect(const std::string& name, const LLRect &val); |
210 | void setColor4U(const LLString& name, const LLColor4U &val); | 210 | void setColor4U(const std::string& name, const LLColor4U &val); |
211 | void setColor4(const LLString& name, const LLColor4 &val); | 211 | void setColor4(const std::string& name, const LLColor4 &val); |
212 | void setColor3(const LLString& name, const LLColor3 &val); | 212 | void setColor3(const std::string& name, const LLColor3 &val); |
213 | void setLLSD(const LLString& name, const LLSD& val); | 213 | void setLLSD(const std::string& name, const LLSD& val); |
214 | void setValue(const LLString& name, const LLSD& val); | 214 | void setValue(const std::string& name, const LLSD& val); |
215 | 215 | ||
216 | 216 | ||
217 | BOOL controlExists(const LLString& name); | 217 | BOOL controlExists(const std::string& name); |
218 | 218 | ||
219 | // Returns number of controls loaded, 0 if failed | 219 | // Returns number of controls loaded, 0 if failed |
220 | // If require_declaration is false, will auto-declare controls it finds | 220 | // If require_declaration is false, will auto-declare controls it finds |
221 | // as the given type. | 221 | // as the given type. |
222 | U32 loadFromFileLegacy(const LLString& filename, BOOL require_declaration = TRUE, eControlType declare_as = TYPE_STRING); | 222 | U32 loadFromFileLegacy(const std::string& filename, BOOL require_declaration = TRUE, eControlType declare_as = TYPE_STRING); |
223 | U32 saveToFile(const LLString& filename, BOOL nondefault_only); | 223 | U32 saveToFile(const std::string& filename, BOOL nondefault_only); |
224 | U32 loadFromFile(const LLString& filename, bool default_values = false); | 224 | U32 loadFromFile(const std::string& filename, bool default_values = false); |
225 | void resetToDefaults(); | 225 | void resetToDefaults(); |
226 | 226 | ||
227 | 227 | ||
228 | // Ignorable Warnings | 228 | // Ignorable Warnings |
229 | 229 | ||
230 | // Add a config variable to be reset on resetWarnings() | 230 | // Add a config variable to be reset on resetWarnings() |
231 | void addWarning(const LLString& name); | 231 | void addWarning(const std::string& name); |
232 | BOOL getWarning(const LLString& name); | 232 | BOOL getWarning(const std::string& name); |
233 | void setWarning(const LLString& name, BOOL val); | 233 | void setWarning(const std::string& name, BOOL val); |
234 | 234 | ||
235 | // Resets all ignorables | 235 | // Resets all ignorables |
236 | void resetWarnings(); | 236 | void resetWarnings(); |
diff --git a/linden/indra/llxml/llxml.vcproj b/linden/indra/llxml/llxml.vcproj deleted file mode 100644 index be4ff97..0000000 --- a/linden/indra/llxml/llxml.vcproj +++ /dev/null | |||
@@ -1,191 +0,0 @@ | |||
1 | <?xml version="1.0" encoding="Windows-1252"?> | ||
2 | <VisualStudioProject | ||
3 | ProjectType="Visual C++" | ||
4 | Version="7.10" | ||
5 | Name="llxml" | ||
6 | ProjectGUID="{A5470DA6-0C3A-4602-B930-43DB25511A59}" | ||
7 | Keyword="Win32Proj"> | ||
8 | <Platforms> | ||
9 | <Platform | ||
10 | Name="Win32"/> | ||
11 | </Platforms> | ||
12 | <Configurations> | ||
13 | <Configuration | ||
14 | Name="Debug|Win32" | ||
15 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
16 | IntermediateDirectory="Debug" | ||
17 | ConfigurationType="4" | ||
18 | CharacterSet="1"> | ||
19 | <Tool | ||
20 | Name="VCCLCompilerTool" | ||
21 | Optimization="0" | ||
22 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
23 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;LL_DEBUG" | ||
24 | MinimalRebuild="TRUE" | ||
25 | BasicRuntimeChecks="3" | ||
26 | RuntimeLibrary="1" | ||
27 | StructMemberAlignment="4" | ||
28 | ForceConformanceInForLoopScope="TRUE" | ||
29 | UsePrecompiledHeader="0" | ||
30 | WarningLevel="3" | ||
31 | WarnAsError="TRUE" | ||
32 | Detect64BitPortabilityProblems="FALSE" | ||
33 | DebugInformationFormat="4"/> | ||
34 | <Tool | ||
35 | Name="VCCustomBuildTool"/> | ||
36 | <Tool | ||
37 | Name="VCLibrarianTool" | ||
38 | OutputFile="$(OutDir)/llxml.lib"/> | ||
39 | <Tool | ||
40 | Name="VCMIDLTool"/> | ||
41 | <Tool | ||
42 | Name="VCPostBuildEventTool"/> | ||
43 | <Tool | ||
44 | Name="VCPreBuildEventTool"/> | ||
45 | <Tool | ||
46 | Name="VCPreLinkEventTool"/> | ||
47 | <Tool | ||
48 | Name="VCResourceCompilerTool"/> | ||
49 | <Tool | ||
50 | Name="VCWebServiceProxyGeneratorTool"/> | ||
51 | <Tool | ||
52 | Name="VCXMLDataGeneratorTool"/> | ||
53 | <Tool | ||
54 | Name="VCManagedWrapperGeneratorTool"/> | ||
55 | <Tool | ||
56 | Name="VCAuxiliaryManagedWrapperGeneratorTool"/> | ||
57 | </Configuration> | ||
58 | <Configuration | ||
59 | Name="Release|Win32" | ||
60 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
61 | IntermediateDirectory="Release" | ||
62 | ConfigurationType="4" | ||
63 | CharacterSet="1"> | ||
64 | <Tool | ||
65 | Name="VCCLCompilerTool" | ||
66 | AdditionalOptions="/Oy-" | ||
67 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
68 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" | ||
69 | RuntimeLibrary="0" | ||
70 | StructMemberAlignment="0" | ||
71 | ForceConformanceInForLoopScope="TRUE" | ||
72 | UsePrecompiledHeader="0" | ||
73 | WarningLevel="3" | ||
74 | WarnAsError="TRUE" | ||
75 | Detect64BitPortabilityProblems="FALSE" | ||
76 | DebugInformationFormat="3"/> | ||
77 | <Tool | ||
78 | Name="VCCustomBuildTool"/> | ||
79 | <Tool | ||
80 | Name="VCLibrarianTool" | ||
81 | OutputFile="$(OutDir)/llxml.lib"/> | ||
82 | <Tool | ||
83 | Name="VCMIDLTool"/> | ||
84 | <Tool | ||
85 | Name="VCPostBuildEventTool"/> | ||
86 | <Tool | ||
87 | Name="VCPreBuildEventTool"/> | ||
88 | <Tool | ||
89 | Name="VCPreLinkEventTool"/> | ||
90 | <Tool | ||
91 | Name="VCResourceCompilerTool"/> | ||
92 | <Tool | ||
93 | Name="VCWebServiceProxyGeneratorTool"/> | ||
94 | <Tool | ||
95 | Name="VCXMLDataGeneratorTool"/> | ||
96 | <Tool | ||
97 | Name="VCManagedWrapperGeneratorTool"/> | ||
98 | <Tool | ||
99 | Name="VCAuxiliaryManagedWrapperGeneratorTool"/> | ||
100 | </Configuration> | ||
101 | <Configuration | ||
102 | Name="ReleaseNoOpt|Win32" | ||
103 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
104 | IntermediateDirectory="$(ConfigurationName)" | ||
105 | ConfigurationType="4" | ||
106 | CharacterSet="1"> | ||
107 | <Tool | ||
108 | Name="VCCLCompilerTool" | ||
109 | AdditionalOptions="/Oy-" | ||
110 | Optimization="0" | ||
111 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
112 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;LL_RELEASE" | ||
113 | RuntimeLibrary="0" | ||
114 | StructMemberAlignment="0" | ||
115 | ForceConformanceInForLoopScope="TRUE" | ||
116 | UsePrecompiledHeader="0" | ||
117 | WarningLevel="3" | ||
118 | WarnAsError="TRUE" | ||
119 | Detect64BitPortabilityProblems="FALSE" | ||
120 | DebugInformationFormat="3"/> | ||
121 | <Tool | ||
122 | Name="VCCustomBuildTool"/> | ||
123 | <Tool | ||
124 | Name="VCLibrarianTool" | ||
125 | OutputFile="$(OutDir)/llxml.lib"/> | ||
126 | <Tool | ||
127 | Name="VCMIDLTool"/> | ||
128 | <Tool | ||
129 | Name="VCPostBuildEventTool"/> | ||
130 | <Tool | ||
131 | Name="VCPreBuildEventTool"/> | ||
132 | <Tool | ||
133 | Name="VCPreLinkEventTool"/> | ||
134 | <Tool | ||
135 | Name="VCResourceCompilerTool"/> | ||
136 | <Tool | ||
137 | Name="VCWebServiceProxyGeneratorTool"/> | ||
138 | <Tool | ||
139 | Name="VCXMLDataGeneratorTool"/> | ||
140 | <Tool | ||
141 | Name="VCManagedWrapperGeneratorTool"/> | ||
142 | <Tool | ||
143 | Name="VCAuxiliaryManagedWrapperGeneratorTool"/> | ||
144 | </Configuration> | ||
145 | </Configurations> | ||
146 | <References> | ||
147 | </References> | ||
148 | <Files> | ||
149 | <Filter | ||
150 | Name="Source Files" | ||
151 | Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx" | ||
152 | UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}"> | ||
153 | <File | ||
154 | RelativePath=".\llcontrol.cpp"> | ||
155 | </File> | ||
156 | <File | ||
157 | RelativePath=".\llxmlnode.cpp"> | ||
158 | </File> | ||
159 | <File | ||
160 | RelativePath=".\llxmlparser.cpp"> | ||
161 | </File> | ||
162 | <File | ||
163 | RelativePath=".\llxmltree.cpp"> | ||
164 | </File> | ||
165 | </Filter> | ||
166 | <Filter | ||
167 | Name="Header Files" | ||
168 | Filter="h;hpp;hxx;hm;inl;inc;xsd" | ||
169 | UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}"> | ||
170 | <File | ||
171 | RelativePath=".\llcontrol.h"> | ||
172 | </File> | ||
173 | <File | ||
174 | RelativePath=".\llxmlnode.h"> | ||
175 | </File> | ||
176 | <File | ||
177 | RelativePath=".\llxmlparser.h"> | ||
178 | </File> | ||
179 | <File | ||
180 | RelativePath=".\llxmltree.h"> | ||
181 | </File> | ||
182 | </Filter> | ||
183 | <Filter | ||
184 | Name="Resource Files" | ||
185 | Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx" | ||
186 | UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}"> | ||
187 | </Filter> | ||
188 | </Files> | ||
189 | <Globals> | ||
190 | </Globals> | ||
191 | </VisualStudioProject> | ||
diff --git a/linden/indra/llxml/llxml_vc8.vcproj b/linden/indra/llxml/llxml_vc8.vcproj deleted file mode 100644 index b39ae53..0000000 --- a/linden/indra/llxml/llxml_vc8.vcproj +++ /dev/null | |||
@@ -1,279 +0,0 @@ | |||
1 | <?xml version="1.0" encoding="Windows-1252"?> | ||
2 | <VisualStudioProject | ||
3 | ProjectType="Visual C++" | ||
4 | Version="8.00" | ||
5 | Name="llxml" | ||
6 | ProjectGUID="{A5470DA6-0C3A-4602-B930-43DB25511A59}" | ||
7 | RootNamespace="llxml" | ||
8 | Keyword="Win32Proj" | ||
9 | > | ||
10 | <Platforms> | ||
11 | <Platform | ||
12 | Name="Win32" | ||
13 | /> | ||
14 | </Platforms> | ||
15 | <ToolFiles> | ||
16 | </ToolFiles> | ||
17 | <Configurations> | ||
18 | <Configuration | ||
19 | Name="Debug|Win32" | ||
20 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
21 | IntermediateDirectory="Debug" | ||
22 | ConfigurationType="4" | ||
23 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
24 | CharacterSet="1" | ||
25 | > | ||
26 | <Tool | ||
27 | Name="VCPreBuildEventTool" | ||
28 | /> | ||
29 | <Tool | ||
30 | Name="VCCustomBuildTool" | ||
31 | /> | ||
32 | <Tool | ||
33 | Name="VCXMLDataGeneratorTool" | ||
34 | /> | ||
35 | <Tool | ||
36 | Name="VCWebServiceProxyGeneratorTool" | ||
37 | /> | ||
38 | <Tool | ||
39 | Name="VCMIDLTool" | ||
40 | /> | ||
41 | <Tool | ||
42 | Name="VCCLCompilerTool" | ||
43 | Optimization="0" | ||
44 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
45 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_DEBUG" | ||
46 | MinimalRebuild="true" | ||
47 | BasicRuntimeChecks="3" | ||
48 | RuntimeLibrary="1" | ||
49 | StructMemberAlignment="4" | ||
50 | TreatWChar_tAsBuiltInType="false" | ||
51 | ForceConformanceInForLoopScope="true" | ||
52 | UsePrecompiledHeader="0" | ||
53 | WarningLevel="3" | ||
54 | WarnAsError="true" | ||
55 | Detect64BitPortabilityProblems="false" | ||
56 | DebugInformationFormat="4" | ||
57 | /> | ||
58 | <Tool | ||
59 | Name="VCManagedResourceCompilerTool" | ||
60 | /> | ||
61 | <Tool | ||
62 | Name="VCResourceCompilerTool" | ||
63 | /> | ||
64 | <Tool | ||
65 | Name="VCPreLinkEventTool" | ||
66 | /> | ||
67 | <Tool | ||
68 | Name="VCLibrarianTool" | ||
69 | OutputFile="$(OutDir)/llxml.lib" | ||
70 | /> | ||
71 | <Tool | ||
72 | Name="VCALinkTool" | ||
73 | /> | ||
74 | <Tool | ||
75 | Name="VCXDCMakeTool" | ||
76 | /> | ||
77 | <Tool | ||
78 | Name="VCBscMakeTool" | ||
79 | /> | ||
80 | <Tool | ||
81 | Name="VCFxCopTool" | ||
82 | /> | ||
83 | <Tool | ||
84 | Name="VCPostBuildEventTool" | ||
85 | /> | ||
86 | </Configuration> | ||
87 | <Configuration | ||
88 | Name="Release|Win32" | ||
89 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
90 | IntermediateDirectory="Release" | ||
91 | ConfigurationType="4" | ||
92 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
93 | CharacterSet="1" | ||
94 | > | ||
95 | <Tool | ||
96 | Name="VCPreBuildEventTool" | ||
97 | /> | ||
98 | <Tool | ||
99 | Name="VCCustomBuildTool" | ||
100 | /> | ||
101 | <Tool | ||
102 | Name="VCXMLDataGeneratorTool" | ||
103 | /> | ||
104 | <Tool | ||
105 | Name="VCWebServiceProxyGeneratorTool" | ||
106 | /> | ||
107 | <Tool | ||
108 | Name="VCMIDLTool" | ||
109 | /> | ||
110 | <Tool | ||
111 | Name="VCCLCompilerTool" | ||
112 | AdditionalOptions="/Oy-" | ||
113 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
114 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
115 | RuntimeLibrary="0" | ||
116 | StructMemberAlignment="0" | ||
117 | TreatWChar_tAsBuiltInType="false" | ||
118 | ForceConformanceInForLoopScope="true" | ||
119 | UsePrecompiledHeader="0" | ||
120 | WarningLevel="3" | ||
121 | WarnAsError="true" | ||
122 | Detect64BitPortabilityProblems="false" | ||
123 | DebugInformationFormat="3" | ||
124 | /> | ||
125 | <Tool | ||
126 | Name="VCManagedResourceCompilerTool" | ||
127 | /> | ||
128 | <Tool | ||
129 | Name="VCResourceCompilerTool" | ||
130 | /> | ||
131 | <Tool | ||
132 | Name="VCPreLinkEventTool" | ||
133 | /> | ||
134 | <Tool | ||
135 | Name="VCLibrarianTool" | ||
136 | OutputFile="$(OutDir)/llxml.lib" | ||
137 | /> | ||
138 | <Tool | ||
139 | Name="VCALinkTool" | ||
140 | /> | ||
141 | <Tool | ||
142 | Name="VCXDCMakeTool" | ||
143 | /> | ||
144 | <Tool | ||
145 | Name="VCBscMakeTool" | ||
146 | /> | ||
147 | <Tool | ||
148 | Name="VCFxCopTool" | ||
149 | /> | ||
150 | <Tool | ||
151 | Name="VCPostBuildEventTool" | ||
152 | /> | ||
153 | </Configuration> | ||
154 | <Configuration | ||
155 | Name="ReleaseNoOpt|Win32" | ||
156 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
157 | IntermediateDirectory="$(ConfigurationName)" | ||
158 | ConfigurationType="4" | ||
159 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
160 | CharacterSet="1" | ||
161 | > | ||
162 | <Tool | ||
163 | Name="VCPreBuildEventTool" | ||
164 | /> | ||
165 | <Tool | ||
166 | Name="VCCustomBuildTool" | ||
167 | /> | ||
168 | <Tool | ||
169 | Name="VCXMLDataGeneratorTool" | ||
170 | /> | ||
171 | <Tool | ||
172 | Name="VCWebServiceProxyGeneratorTool" | ||
173 | /> | ||
174 | <Tool | ||
175 | Name="VCMIDLTool" | ||
176 | /> | ||
177 | <Tool | ||
178 | Name="VCCLCompilerTool" | ||
179 | AdditionalOptions="/Oy-" | ||
180 | Optimization="0" | ||
181 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
182 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
183 | RuntimeLibrary="0" | ||
184 | StructMemberAlignment="0" | ||
185 | TreatWChar_tAsBuiltInType="false" | ||
186 | ForceConformanceInForLoopScope="true" | ||
187 | UsePrecompiledHeader="0" | ||
188 | WarningLevel="3" | ||
189 | WarnAsError="true" | ||
190 | Detect64BitPortabilityProblems="false" | ||
191 | DebugInformationFormat="3" | ||
192 | /> | ||
193 | <Tool | ||
194 | Name="VCManagedResourceCompilerTool" | ||
195 | /> | ||
196 | <Tool | ||
197 | Name="VCResourceCompilerTool" | ||
198 | /> | ||
199 | <Tool | ||
200 | Name="VCPreLinkEventTool" | ||
201 | /> | ||
202 | <Tool | ||
203 | Name="VCLibrarianTool" | ||
204 | OutputFile="$(OutDir)/llxml.lib" | ||
205 | /> | ||
206 | <Tool | ||
207 | Name="VCALinkTool" | ||
208 | /> | ||
209 | <Tool | ||
210 | Name="VCXDCMakeTool" | ||
211 | /> | ||
212 | <Tool | ||
213 | Name="VCBscMakeTool" | ||
214 | /> | ||
215 | <Tool | ||
216 | Name="VCFxCopTool" | ||
217 | /> | ||
218 | <Tool | ||
219 | Name="VCPostBuildEventTool" | ||
220 | /> | ||
221 | </Configuration> | ||
222 | </Configurations> | ||
223 | <References> | ||
224 | </References> | ||
225 | <Files> | ||
226 | <Filter | ||
227 | Name="Source Files" | ||
228 | Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx" | ||
229 | UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}" | ||
230 | > | ||
231 | <File | ||
232 | RelativePath=".\llcontrol.cpp" | ||
233 | > | ||
234 | </File> | ||
235 | <File | ||
236 | RelativePath=".\llxmlnode.cpp" | ||
237 | > | ||
238 | </File> | ||
239 | <File | ||
240 | RelativePath=".\llxmlparser.cpp" | ||
241 | > | ||
242 | </File> | ||
243 | <File | ||
244 | RelativePath=".\llxmltree.cpp" | ||
245 | > | ||
246 | </File> | ||
247 | </Filter> | ||
248 | <Filter | ||
249 | Name="Header Files" | ||
250 | Filter="h;hpp;hxx;hm;inl;inc;xsd" | ||
251 | UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}" | ||
252 | > | ||
253 | <File | ||
254 | RelativePath=".\llcontrol.h" | ||
255 | > | ||
256 | </File> | ||
257 | <File | ||
258 | RelativePath=".\llxmlnode.h" | ||
259 | > | ||
260 | </File> | ||
261 | <File | ||
262 | RelativePath=".\llxmlparser.h" | ||
263 | > | ||
264 | </File> | ||
265 | <File | ||
266 | RelativePath=".\llxmltree.h" | ||
267 | > | ||
268 | </File> | ||
269 | </Filter> | ||
270 | <Filter | ||
271 | Name="Resource Files" | ||
272 | Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx" | ||
273 | UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}" | ||
274 | > | ||
275 | </Filter> | ||
276 | </Files> | ||
277 | <Globals> | ||
278 | </Globals> | ||
279 | </VisualStudioProject> | ||
diff --git a/linden/indra/llxml/llxml_vc9.vcproj b/linden/indra/llxml/llxml_vc9.vcproj deleted file mode 100644 index eb719c9..0000000 --- a/linden/indra/llxml/llxml_vc9.vcproj +++ /dev/null | |||
@@ -1,280 +0,0 @@ | |||
1 | <?xml version="1.0" encoding="Windows-1252"?> | ||
2 | <VisualStudioProject | ||
3 | ProjectType="Visual C++" | ||
4 | Version="9.00" | ||
5 | Name="llxml" | ||
6 | ProjectGUID="{A5470DA6-0C3A-4602-B930-43DB25511A59}" | ||
7 | RootNamespace="llxml" | ||
8 | Keyword="Win32Proj" | ||
9 | TargetFrameworkVersion="131072" | ||
10 | > | ||
11 | <Platforms> | ||
12 | <Platform | ||
13 | Name="Win32" | ||
14 | /> | ||
15 | </Platforms> | ||
16 | <ToolFiles> | ||
17 | </ToolFiles> | ||
18 | <Configurations> | ||
19 | <Configuration | ||
20 | Name="Debug|Win32" | ||
21 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
22 | IntermediateDirectory="Debug" | ||
23 | ConfigurationType="4" | ||
24 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
25 | CharacterSet="1" | ||
26 | > | ||
27 | <Tool | ||
28 | Name="VCPreBuildEventTool" | ||
29 | /> | ||
30 | <Tool | ||
31 | Name="VCCustomBuildTool" | ||
32 | /> | ||
33 | <Tool | ||
34 | Name="VCXMLDataGeneratorTool" | ||
35 | /> | ||
36 | <Tool | ||
37 | Name="VCWebServiceProxyGeneratorTool" | ||
38 | /> | ||
39 | <Tool | ||
40 | Name="VCMIDLTool" | ||
41 | /> | ||
42 | <Tool | ||
43 | Name="VCCLCompilerTool" | ||
44 | Optimization="0" | ||
45 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
46 | PreprocessorDefinitions="WIN32;_DEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_DEBUG" | ||
47 | MinimalRebuild="true" | ||
48 | BasicRuntimeChecks="3" | ||
49 | RuntimeLibrary="1" | ||
50 | StructMemberAlignment="4" | ||
51 | TreatWChar_tAsBuiltInType="false" | ||
52 | ForceConformanceInForLoopScope="true" | ||
53 | UsePrecompiledHeader="0" | ||
54 | WarningLevel="3" | ||
55 | WarnAsError="true" | ||
56 | Detect64BitPortabilityProblems="false" | ||
57 | DebugInformationFormat="4" | ||
58 | /> | ||
59 | <Tool | ||
60 | Name="VCManagedResourceCompilerTool" | ||
61 | /> | ||
62 | <Tool | ||
63 | Name="VCResourceCompilerTool" | ||
64 | /> | ||
65 | <Tool | ||
66 | Name="VCPreLinkEventTool" | ||
67 | /> | ||
68 | <Tool | ||
69 | Name="VCLibrarianTool" | ||
70 | OutputFile="$(OutDir)/llxml.lib" | ||
71 | /> | ||
72 | <Tool | ||
73 | Name="VCALinkTool" | ||
74 | /> | ||
75 | <Tool | ||
76 | Name="VCXDCMakeTool" | ||
77 | /> | ||
78 | <Tool | ||
79 | Name="VCBscMakeTool" | ||
80 | /> | ||
81 | <Tool | ||
82 | Name="VCFxCopTool" | ||
83 | /> | ||
84 | <Tool | ||
85 | Name="VCPostBuildEventTool" | ||
86 | /> | ||
87 | </Configuration> | ||
88 | <Configuration | ||
89 | Name="Release|Win32" | ||
90 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
91 | IntermediateDirectory="Release" | ||
92 | ConfigurationType="4" | ||
93 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
94 | CharacterSet="1" | ||
95 | > | ||
96 | <Tool | ||
97 | Name="VCPreBuildEventTool" | ||
98 | /> | ||
99 | <Tool | ||
100 | Name="VCCustomBuildTool" | ||
101 | /> | ||
102 | <Tool | ||
103 | Name="VCXMLDataGeneratorTool" | ||
104 | /> | ||
105 | <Tool | ||
106 | Name="VCWebServiceProxyGeneratorTool" | ||
107 | /> | ||
108 | <Tool | ||
109 | Name="VCMIDLTool" | ||
110 | /> | ||
111 | <Tool | ||
112 | Name="VCCLCompilerTool" | ||
113 | AdditionalOptions="/Oy-" | ||
114 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
115 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
116 | RuntimeLibrary="0" | ||
117 | StructMemberAlignment="0" | ||
118 | TreatWChar_tAsBuiltInType="false" | ||
119 | ForceConformanceInForLoopScope="true" | ||
120 | UsePrecompiledHeader="0" | ||
121 | WarningLevel="3" | ||
122 | WarnAsError="true" | ||
123 | Detect64BitPortabilityProblems="false" | ||
124 | DebugInformationFormat="3" | ||
125 | /> | ||
126 | <Tool | ||
127 | Name="VCManagedResourceCompilerTool" | ||
128 | /> | ||
129 | <Tool | ||
130 | Name="VCResourceCompilerTool" | ||
131 | /> | ||
132 | <Tool | ||
133 | Name="VCPreLinkEventTool" | ||
134 | /> | ||
135 | <Tool | ||
136 | Name="VCLibrarianTool" | ||
137 | OutputFile="$(OutDir)/llxml.lib" | ||
138 | /> | ||
139 | <Tool | ||
140 | Name="VCALinkTool" | ||
141 | /> | ||
142 | <Tool | ||
143 | Name="VCXDCMakeTool" | ||
144 | /> | ||
145 | <Tool | ||
146 | Name="VCBscMakeTool" | ||
147 | /> | ||
148 | <Tool | ||
149 | Name="VCFxCopTool" | ||
150 | /> | ||
151 | <Tool | ||
152 | Name="VCPostBuildEventTool" | ||
153 | /> | ||
154 | </Configuration> | ||
155 | <Configuration | ||
156 | Name="ReleaseNoOpt|Win32" | ||
157 | OutputDirectory="../lib_$(ConfigurationName)/i686-win32" | ||
158 | IntermediateDirectory="$(ConfigurationName)" | ||
159 | ConfigurationType="4" | ||
160 | InheritedPropertySheets="$(VCInstallDir)VCProjectDefaults\UpgradeFromVC71.vsprops" | ||
161 | CharacterSet="1" | ||
162 | > | ||
163 | <Tool | ||
164 | Name="VCPreBuildEventTool" | ||
165 | /> | ||
166 | <Tool | ||
167 | Name="VCCustomBuildTool" | ||
168 | /> | ||
169 | <Tool | ||
170 | Name="VCXMLDataGeneratorTool" | ||
171 | /> | ||
172 | <Tool | ||
173 | Name="VCWebServiceProxyGeneratorTool" | ||
174 | /> | ||
175 | <Tool | ||
176 | Name="VCMIDLTool" | ||
177 | /> | ||
178 | <Tool | ||
179 | Name="VCCLCompilerTool" | ||
180 | AdditionalOptions="/Oy-" | ||
181 | Optimization="0" | ||
182 | AdditionalIncludeDirectories="..\llcommon;..\llmath;..\..\libraries\i686-win32\include;..\..\libraries\include\" | ||
183 | PreprocessorDefinitions="WIN32;NDEBUG;_LIB;LL_WINDOWS;_CRT_SECURE_NO_DEPRECATE;_CRT_NONSTDC_NO_DEPRECATE;_USE_32BIT_TIME_T;LL_RELEASE" | ||
184 | RuntimeLibrary="0" | ||
185 | StructMemberAlignment="0" | ||
186 | TreatWChar_tAsBuiltInType="false" | ||
187 | ForceConformanceInForLoopScope="true" | ||
188 | UsePrecompiledHeader="0" | ||
189 | WarningLevel="3" | ||
190 | WarnAsError="true" | ||
191 | Detect64BitPortabilityProblems="false" | ||
192 | DebugInformationFormat="3" | ||
193 | /> | ||
194 | <Tool | ||
195 | Name="VCManagedResourceCompilerTool" | ||
196 | /> | ||
197 | <Tool | ||
198 | Name="VCResourceCompilerTool" | ||
199 | /> | ||
200 | <Tool | ||
201 | Name="VCPreLinkEventTool" | ||
202 | /> | ||
203 | <Tool | ||
204 | Name="VCLibrarianTool" | ||
205 | OutputFile="$(OutDir)/llxml.lib" | ||
206 | /> | ||
207 | <Tool | ||
208 | Name="VCALinkTool" | ||
209 | /> | ||
210 | <Tool | ||
211 | Name="VCXDCMakeTool" | ||
212 | /> | ||
213 | <Tool | ||
214 | Name="VCBscMakeTool" | ||
215 | /> | ||
216 | <Tool | ||
217 | Name="VCFxCopTool" | ||
218 | /> | ||
219 | <Tool | ||
220 | Name="VCPostBuildEventTool" | ||
221 | /> | ||
222 | </Configuration> | ||
223 | </Configurations> | ||
224 | <References> | ||
225 | </References> | ||
226 | <Files> | ||
227 | <Filter | ||
228 | Name="Source Files" | ||
229 | Filter="cpp;c;cxx;def;odl;idl;hpj;bat;asm;asmx" | ||
230 | UniqueIdentifier="{4FC737F1-C7A5-4376-A066-2A32D752A2FF}" | ||
231 | > | ||
232 | <File | ||
233 | RelativePath=".\llcontrol.cpp" | ||
234 | > | ||
235 | </File> | ||
236 | <File | ||
237 | RelativePath=".\llxmlnode.cpp" | ||
238 | > | ||
239 | </File> | ||
240 | <File | ||
241 | RelativePath=".\llxmlparser.cpp" | ||
242 | > | ||
243 | </File> | ||
244 | <File | ||
245 | RelativePath=".\llxmltree.cpp" | ||
246 | > | ||
247 | </File> | ||
248 | </Filter> | ||
249 | <Filter | ||
250 | Name="Header Files" | ||
251 | Filter="h;hpp;hxx;hm;inl;inc;xsd" | ||
252 | UniqueIdentifier="{93995380-89BD-4b04-88EB-625FBE52EBFB}" | ||
253 | > | ||
254 | <File | ||
255 | RelativePath=".\llcontrol.h" | ||
256 | > | ||
257 | </File> | ||
258 | <File | ||
259 | RelativePath=".\llxmlnode.h" | ||
260 | > | ||
261 | </File> | ||
262 | <File | ||
263 | RelativePath=".\llxmlparser.h" | ||
264 | > | ||
265 | </File> | ||
266 | <File | ||
267 | RelativePath=".\llxmltree.h" | ||
268 | > | ||
269 | </File> | ||
270 | </Filter> | ||
271 | <Filter | ||
272 | Name="Resource Files" | ||
273 | Filter="rc;ico;cur;bmp;dlg;rc2;rct;bin;rgs;gif;jpg;jpeg;jpe;resx" | ||
274 | UniqueIdentifier="{67DA6AB6-F800-4c08-8B7A-83BB121AAD01}" | ||
275 | > | ||
276 | </Filter> | ||
277 | </Files> | ||
278 | <Globals> | ||
279 | </Globals> | ||
280 | </VisualStudioProject> | ||
diff --git a/linden/indra/llxml/llxmlnode.cpp b/linden/indra/llxml/llxmlnode.cpp index f9852d3..145e6e0 100644 --- a/linden/indra/llxml/llxmlnode.cpp +++ b/linden/indra/llxml/llxmlnode.cpp | |||
@@ -55,6 +55,7 @@ BOOL LLXMLNode::sStripWhitespaceValues = FALSE; | |||
55 | 55 | ||
56 | LLXMLNode::LLXMLNode() : | 56 | LLXMLNode::LLXMLNode() : |
57 | mID(""), | 57 | mID(""), |
58 | mParser(NULL), | ||
58 | mIsAttribute(FALSE), | 59 | mIsAttribute(FALSE), |
59 | mVersionMajor(0), | 60 | mVersionMajor(0), |
60 | mVersionMinor(0), | 61 | mVersionMinor(0), |
@@ -70,8 +71,9 @@ LLXMLNode::LLXMLNode() : | |||
70 | { | 71 | { |
71 | } | 72 | } |
72 | 73 | ||
73 | LLXMLNode::LLXMLNode(const LLString& name, BOOL is_attribute) : | 74 | LLXMLNode::LLXMLNode(const char* name, BOOL is_attribute) : |
74 | mID(""), | 75 | mID(""), |
76 | mParser(NULL), | ||
75 | mIsAttribute(is_attribute), | 77 | mIsAttribute(is_attribute), |
76 | mVersionMajor(0), | 78 | mVersionMajor(0), |
77 | mVersionMinor(0), | 79 | mVersionMinor(0), |
@@ -89,6 +91,7 @@ LLXMLNode::LLXMLNode(const LLString& name, BOOL is_attribute) : | |||
89 | 91 | ||
90 | LLXMLNode::LLXMLNode(LLStringTableEntry* name, BOOL is_attribute) : | 92 | LLXMLNode::LLXMLNode(LLStringTableEntry* name, BOOL is_attribute) : |
91 | mID(""), | 93 | mID(""), |
94 | mParser(NULL), | ||
92 | mIsAttribute(is_attribute), | 95 | mIsAttribute(is_attribute), |
93 | mVersionMajor(0), | 96 | mVersionMajor(0), |
94 | mVersionMinor(0), | 97 | mVersionMinor(0), |
@@ -212,7 +215,7 @@ void LLXMLNode::addChild(LLXMLNodePtr new_child) | |||
212 | new_child->mParent = this; | 215 | new_child->mParent = this; |
213 | if (new_child->mIsAttribute) | 216 | if (new_child->mIsAttribute) |
214 | { | 217 | { |
215 | mAttributes.insert(std::pair<LLStringTableEntry*, LLXMLNodePtr>(new_child->mName, new_child)); | 218 | mAttributes.insert(std::make_pair(new_child->mName, new_child)); |
216 | } | 219 | } |
217 | else | 220 | else |
218 | { | 221 | { |
@@ -222,7 +225,7 @@ void LLXMLNode::addChild(LLXMLNodePtr new_child) | |||
222 | mChildren->head = new_child; | 225 | mChildren->head = new_child; |
223 | mChildren->tail = new_child; | 226 | mChildren->tail = new_child; |
224 | } | 227 | } |
225 | mChildren->map.insert(std::pair<LLStringTableEntry*, LLXMLNodePtr>(new_child->mName, new_child)); | 228 | mChildren->map.insert(std::make_pair(new_child->mName, new_child)); |
226 | 229 | ||
227 | if (mChildren->tail != new_child) | 230 | if (mChildren->tail != new_child) |
228 | { | 231 | { |
@@ -236,7 +239,7 @@ void LLXMLNode::addChild(LLXMLNodePtr new_child) | |||
236 | } | 239 | } |
237 | 240 | ||
238 | // virtual | 241 | // virtual |
239 | LLXMLNodePtr LLXMLNode::createChild(const LLString& name, BOOL is_attribute) | 242 | LLXMLNodePtr LLXMLNode::createChild(const char* name, BOOL is_attribute) |
240 | { | 243 | { |
241 | return createChild(gStringTable.addStringEntry(name), is_attribute); | 244 | return createChild(gStringTable.addStringEntry(name), is_attribute); |
242 | } | 245 | } |
@@ -245,7 +248,7 @@ LLXMLNodePtr LLXMLNode::createChild(const LLString& name, BOOL is_attribute) | |||
245 | LLXMLNodePtr LLXMLNode::createChild(LLStringTableEntry* name, BOOL is_attribute) | 248 | LLXMLNodePtr LLXMLNode::createChild(LLStringTableEntry* name, BOOL is_attribute) |
246 | { | 249 | { |
247 | LLXMLNode* ret = new LLXMLNode(name, is_attribute); | 250 | LLXMLNode* ret = new LLXMLNode(name, is_attribute); |
248 | ret->mID = ""; | 251 | ret->mID.clear(); |
249 | addChild(ret); | 252 | addChild(ret); |
250 | return ret; | 253 | return ret; |
251 | } | 254 | } |
@@ -309,7 +312,7 @@ void XMLCALL StartXMLNode(void *userData, | |||
309 | // Create a new node | 312 | // Create a new node |
310 | LLXMLNode *new_node_ptr = new LLXMLNode(name, FALSE); | 313 | LLXMLNode *new_node_ptr = new LLXMLNode(name, FALSE); |
311 | LLXMLNodePtr new_node = new_node_ptr; | 314 | LLXMLNodePtr new_node = new_node_ptr; |
312 | new_node->mID = ""; | 315 | new_node->mID.clear(); |
313 | LLXMLNodePtr ptr_new_node = new_node; | 316 | LLXMLNodePtr ptr_new_node = new_node; |
314 | 317 | ||
315 | // Set the parent-child relationship with the current active node | 318 | // Set the parent-child relationship with the current active node |
@@ -331,8 +334,8 @@ void XMLCALL StartXMLNode(void *userData, | |||
331 | U32 pos = 0; | 334 | U32 pos = 0; |
332 | while (atts[pos] != NULL) | 335 | while (atts[pos] != NULL) |
333 | { | 336 | { |
334 | LLString attr_name = atts[pos]; | 337 | std::string attr_name = atts[pos]; |
335 | LLString attr_value = atts[pos+1]; | 338 | std::string attr_value = atts[pos+1]; |
336 | 339 | ||
337 | // Special cases | 340 | // Special cases |
338 | if ('i' == attr_name[0] && "id" == attr_name) | 341 | if ('i' == attr_name[0] && "id" == attr_name) |
@@ -410,9 +413,9 @@ void XMLCALL StartXMLNode(void *userData, | |||
410 | 413 | ||
411 | // only one attribute child per description | 414 | // only one attribute child per description |
412 | LLXMLNodePtr attr_node; | 415 | LLXMLNodePtr attr_node; |
413 | if (!new_node->getAttribute(attr_name, attr_node, FALSE)) | 416 | if (!new_node->getAttribute(attr_name.c_str(), attr_node, FALSE)) |
414 | { | 417 | { |
415 | attr_node = new LLXMLNode(attr_name, TRUE); | 418 | attr_node = new LLXMLNode(attr_name.c_str(), TRUE); |
416 | } | 419 | } |
417 | attr_node->setValue(attr_value); | 420 | attr_node->setValue(attr_value); |
418 | new_node->addChild(attr_node); | 421 | new_node->addChild(attr_node); |
@@ -436,7 +439,7 @@ void XMLCALL EndXMLNode(void *userData, | |||
436 | // SJB: total hack: | 439 | // SJB: total hack: |
437 | if (LLXMLNode::sStripWhitespaceValues) | 440 | if (LLXMLNode::sStripWhitespaceValues) |
438 | { | 441 | { |
439 | LLString value = node->getValue(); | 442 | std::string value = node->getValue(); |
440 | BOOL is_empty = TRUE; | 443 | BOOL is_empty = TRUE; |
441 | for (std::string::size_type s = 0; s < value.length(); s++) | 444 | for (std::string::size_type s = 0; s < value.length(); s++) |
442 | { | 445 | { |
@@ -460,13 +463,13 @@ void XMLCALL XMLData(void *userData, | |||
460 | int len) | 463 | int len) |
461 | { | 464 | { |
462 | LLXMLNode* current_node = (LLXMLNode *)userData; | 465 | LLXMLNode* current_node = (LLXMLNode *)userData; |
463 | LLString value = current_node->getValue(); | 466 | std::string value = current_node->getValue(); |
464 | if (LLXMLNode::sStripEscapedStrings) | 467 | if (LLXMLNode::sStripEscapedStrings) |
465 | { | 468 | { |
466 | if (s[0] == '\"' && s[len-1] == '\"') | 469 | if (s[0] == '\"' && s[len-1] == '\"') |
467 | { | 470 | { |
468 | // Special-case: Escaped string. | 471 | // Special-case: Escaped string. |
469 | LLString unescaped_string; | 472 | std::string unescaped_string; |
470 | for (S32 pos=1; pos<len-1; ++pos) | 473 | for (S32 pos=1; pos<len-1; ++pos) |
471 | { | 474 | { |
472 | if (s[pos] == '\\' && s[pos+1] == '\\') | 475 | if (s[pos] == '\\' && s[pos+1] == '\\') |
@@ -489,7 +492,7 @@ void XMLCALL XMLData(void *userData, | |||
489 | return; | 492 | return; |
490 | } | 493 | } |
491 | } | 494 | } |
492 | value.append(LLString(s, 0, len)); | 495 | value.append(std::string(s, len)); |
493 | current_node->setValue(value); | 496 | current_node->setValue(value); |
494 | } | 497 | } |
495 | 498 | ||
@@ -537,8 +540,8 @@ bool LLXMLNode::updateNode( | |||
537 | { | 540 | { |
538 | for (child = node->getFirstChild(); child.notNull(); child = child->getNextSibling()) | 541 | for (child = node->getFirstChild(); child.notNull(); child = child->getNextSibling()) |
539 | { | 542 | { |
540 | LLString nodeName; | 543 | std::string nodeName; |
541 | LLString updateName; | 544 | std::string updateName; |
542 | 545 | ||
543 | updateChild->getAttributeString("name", updateName); | 546 | updateChild->getAttributeString("name", updateName); |
544 | child->getAttributeString("name", nodeName); | 547 | child->getAttributeString("name", nodeName); |
@@ -566,13 +569,11 @@ bool LLXMLNode::updateNode( | |||
566 | 569 | ||
567 | 570 | ||
568 | // static | 571 | // static |
569 | bool LLXMLNode::parseFile( | 572 | bool LLXMLNode::parseFile(const std::string& filename, LLXMLNodePtr& node, LLXMLNode* defaults_tree) |
570 | LLString filename, | ||
571 | LLXMLNodePtr& node, | ||
572 | LLXMLNode* defaults_tree) | ||
573 | { | 573 | { |
574 | // Read file | 574 | // Read file |
575 | LLFILE* fp = LLFile::fopen(filename.c_str(), "rb"); /* Flawfinder: ignore */ | 575 | LL_DEBUGS("XMLNode") << "parsing XML file: " << filename << LL_ENDL; |
576 | LLFILE* fp = LLFile::fopen(filename, "rb"); /* Flawfinder: ignore */ | ||
576 | if (fp == NULL) | 577 | if (fp == NULL) |
577 | { | 578 | { |
578 | node = new LLXMLNode(); | 579 | node = new LLXMLNode(); |
@@ -746,7 +747,7 @@ void LLXMLNode::writeHeaderToFile(LLFILE *fOut) | |||
746 | fprintf(fOut, "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"yes\" ?>\n"); | 747 | fprintf(fOut, "<?xml version=\"1.0\" encoding=\"utf-8\" standalone=\"yes\" ?>\n"); |
747 | } | 748 | } |
748 | 749 | ||
749 | void LLXMLNode::writeToFile(LLFILE *fOut, LLString indent) | 750 | void LLXMLNode::writeToFile(LLFILE *fOut, const std::string& indent) |
750 | { | 751 | { |
751 | if (isFullyDefault()) | 752 | if (isFullyDefault()) |
752 | { | 753 | { |
@@ -756,14 +757,14 @@ void LLXMLNode::writeToFile(LLFILE *fOut, LLString indent) | |||
756 | 757 | ||
757 | std::ostringstream ostream; | 758 | std::ostringstream ostream; |
758 | writeToOstream(ostream, indent); | 759 | writeToOstream(ostream, indent); |
759 | LLString outstring = ostream.str(); | 760 | std::string outstring = ostream.str(); |
760 | if (fwrite(outstring.c_str(), 1, outstring.length(), fOut) != outstring.length()) | 761 | if (fwrite(outstring.c_str(), 1, outstring.length(), fOut) != outstring.length()) |
761 | { | 762 | { |
762 | llwarns << "Short write" << llendl; | 763 | llwarns << "Short write" << llendl; |
763 | } | 764 | } |
764 | } | 765 | } |
765 | 766 | ||
766 | void LLXMLNode::writeToOstream(std::ostream& output_stream, const LLString& indent) | 767 | void LLXMLNode::writeToOstream(std::ostream& output_stream, const std::string& indent) |
767 | { | 768 | { |
768 | if (isFullyDefault()) | 769 | if (isFullyDefault()) |
769 | { | 770 | { |
@@ -777,12 +778,12 @@ void LLXMLNode::writeToOstream(std::ostream& output_stream, const LLString& inde | |||
777 | BOOL has_default_length = mDefault.isNull()?FALSE:(mLength == mDefault->mLength); | 778 | BOOL has_default_length = mDefault.isNull()?FALSE:(mLength == mDefault->mLength); |
778 | 779 | ||
779 | // stream the name | 780 | // stream the name |
780 | output_stream << indent.c_str() << "<" << mName->mString; | 781 | output_stream << indent << "<" << mName->mString; |
781 | 782 | ||
782 | // ID | 783 | // ID |
783 | if (mID != "") | 784 | if (mID != "") |
784 | { | 785 | { |
785 | output_stream << " id=\"" << mID.c_str() << "\""; | 786 | output_stream << " id=\"" << mID << "\""; |
786 | } | 787 | } |
787 | 788 | ||
788 | // Type | 789 | // Type |
@@ -862,7 +863,7 @@ void LLXMLNode::writeToOstream(std::ostream& output_stream, const LLString& inde | |||
862 | LLXMLNodePtr child = (*attr_itr).second; | 863 | LLXMLNodePtr child = (*attr_itr).second; |
863 | if (child->mDefault.isNull() || child->mDefault->mValue != child->mValue) | 864 | if (child->mDefault.isNull() || child->mDefault->mValue != child->mValue) |
864 | { | 865 | { |
865 | LLString attr = child->mName->mString; | 866 | std::string attr = child->mName->mString; |
866 | if (attr == "id" || | 867 | if (attr == "id" || |
867 | attr == "type" || | 868 | attr == "type" || |
868 | attr == "encoding" || | 869 | attr == "encoding" || |
@@ -873,7 +874,7 @@ void LLXMLNode::writeToOstream(std::ostream& output_stream, const LLString& inde | |||
873 | continue; // skip built-in attributes | 874 | continue; // skip built-in attributes |
874 | } | 875 | } |
875 | 876 | ||
876 | LLString attr_str = llformat(" %s=\"%s\"", | 877 | std::string attr_str = llformat(" %s=\"%s\"", |
877 | attr.c_str(), | 878 | attr.c_str(), |
878 | escapeXML(child->mValue).c_str()); | 879 | escapeXML(child->mValue).c_str()); |
879 | if (col_pos + (S32)attr_str.length() > MAX_COLUMN_WIDTH) | 880 | if (col_pos + (S32)attr_str.length() > MAX_COLUMN_WIDTH) |
@@ -898,7 +899,7 @@ void LLXMLNode::writeToOstream(std::ostream& output_stream, const LLString& inde | |||
898 | if (mChildren) | 899 | if (mChildren) |
899 | { | 900 | { |
900 | // stream non-attributes | 901 | // stream non-attributes |
901 | LLString next_indent = indent + "\t"; | 902 | std::string next_indent = indent + "\t"; |
902 | for (LLXMLNode* child = getFirstChild(); child; child = child->getNextSibling()) | 903 | for (LLXMLNode* child = getFirstChild(); child; child = child->getNextSibling()) |
903 | { | 904 | { |
904 | child->writeToOstream(output_stream, next_indent); | 905 | child->writeToOstream(output_stream, next_indent); |
@@ -906,19 +907,19 @@ void LLXMLNode::writeToOstream(std::ostream& output_stream, const LLString& inde | |||
906 | } | 907 | } |
907 | if (!mValue.empty()) | 908 | if (!mValue.empty()) |
908 | { | 909 | { |
909 | LLString contents = getTextContents(); | 910 | std::string contents = getTextContents(); |
910 | output_stream << indent.c_str() << "\t" << escapeXML(contents) << "\n"; | 911 | output_stream << indent << "\t" << escapeXML(contents) << "\n"; |
911 | } | 912 | } |
912 | output_stream << indent.c_str() << "</" << mName->mString << ">\n"; | 913 | output_stream << indent << "</" << mName->mString << ">\n"; |
913 | } | 914 | } |
914 | } | 915 | } |
915 | 916 | ||
916 | void LLXMLNode::findName(const LLString& name, LLXMLNodeList &results) | 917 | void LLXMLNode::findName(const std::string& name, LLXMLNodeList &results) |
917 | { | 918 | { |
918 | LLStringTableEntry* name_entry = gStringTable.checkStringEntry(name); | 919 | LLStringTableEntry* name_entry = gStringTable.checkStringEntry(name); |
919 | if (name_entry == mName) | 920 | if (name_entry == mName) |
920 | { | 921 | { |
921 | results.insert(std::pair<LLString, LLXMLNode*>(this->mName->mString, this)); | 922 | results.insert(std::make_pair(this->mName->mString, this)); |
922 | return; | 923 | return; |
923 | } | 924 | } |
924 | if (mChildren) | 925 | if (mChildren) |
@@ -937,7 +938,7 @@ void LLXMLNode::findName(LLStringTableEntry* name, LLXMLNodeList &results) | |||
937 | { | 938 | { |
938 | if (name == mName) | 939 | if (name == mName) |
939 | { | 940 | { |
940 | results.insert(std::pair<LLString, LLXMLNode*>(this->mName->mString, this)); | 941 | results.insert(std::make_pair(this->mName->mString, this)); |
941 | return; | 942 | return; |
942 | } | 943 | } |
943 | if (mChildren) | 944 | if (mChildren) |
@@ -952,11 +953,11 @@ void LLXMLNode::findName(LLStringTableEntry* name, LLXMLNodeList &results) | |||
952 | } | 953 | } |
953 | } | 954 | } |
954 | 955 | ||
955 | void LLXMLNode::findID(const LLString& id, LLXMLNodeList &results) | 956 | void LLXMLNode::findID(const std::string& id, LLXMLNodeList &results) |
956 | { | 957 | { |
957 | if (id == mID) | 958 | if (id == mID) |
958 | { | 959 | { |
959 | results.insert(std::pair<LLString, LLXMLNode*>(this->mName->mString, this)); | 960 | results.insert(std::make_pair(this->mName->mString, this)); |
960 | return; | 961 | return; |
961 | } | 962 | } |
962 | if (mChildren) | 963 | if (mChildren) |
@@ -1015,7 +1016,7 @@ void LLXMLNode::scrubToTree(LLXMLNode *tree) | |||
1015 | } | 1016 | } |
1016 | } | 1017 | } |
1017 | 1018 | ||
1018 | bool LLXMLNode::getChild(const LLString& name, LLXMLNodePtr& node, BOOL use_default_if_missing) | 1019 | bool LLXMLNode::getChild(const char* name, LLXMLNodePtr& node, BOOL use_default_if_missing) |
1019 | { | 1020 | { |
1020 | return getChild(gStringTable.checkStringEntry(name), node, use_default_if_missing); | 1021 | return getChild(gStringTable.checkStringEntry(name), node, use_default_if_missing); |
1021 | } | 1022 | } |
@@ -1039,7 +1040,7 @@ bool LLXMLNode::getChild(const LLStringTableEntry* name, LLXMLNodePtr& node, BOO | |||
1039 | return false; | 1040 | return false; |
1040 | } | 1041 | } |
1041 | 1042 | ||
1042 | void LLXMLNode::getChildren(const LLString& name, LLXMLNodeList &children, BOOL use_default_if_missing) const | 1043 | void LLXMLNode::getChildren(const char* name, LLXMLNodeList &children, BOOL use_default_if_missing) const |
1043 | { | 1044 | { |
1044 | getChildren(gStringTable.checkStringEntry(name), children, use_default_if_missing); | 1045 | getChildren(gStringTable.checkStringEntry(name), children, use_default_if_missing); |
1045 | } | 1046 | } |
@@ -1059,7 +1060,7 @@ void LLXMLNode::getChildren(const LLStringTableEntry* name, LLXMLNodeList &child | |||
1059 | { | 1060 | { |
1060 | break; | 1061 | break; |
1061 | } | 1062 | } |
1062 | children.insert(std::pair<LLString, LLXMLNodePtr>(child->mName->mString, child)); | 1063 | children.insert(std::make_pair(child->mName->mString, child)); |
1063 | child_itr++; | 1064 | child_itr++; |
1064 | } | 1065 | } |
1065 | } | 1066 | } |
@@ -1070,7 +1071,7 @@ void LLXMLNode::getChildren(const LLStringTableEntry* name, LLXMLNodeList &child | |||
1070 | } | 1071 | } |
1071 | } | 1072 | } |
1072 | 1073 | ||
1073 | bool LLXMLNode::getAttribute(const LLString& name, LLXMLNodePtr& node, BOOL use_default_if_missing) | 1074 | bool LLXMLNode::getAttribute(const char* name, LLXMLNodePtr& node, BOOL use_default_if_missing) |
1074 | { | 1075 | { |
1075 | return getAttribute(gStringTable.checkStringEntry(name), node, use_default_if_missing); | 1076 | return getAttribute(gStringTable.checkStringEntry(name), node, use_default_if_missing); |
1076 | } | 1077 | } |
@@ -1091,7 +1092,7 @@ bool LLXMLNode::getAttribute(const LLStringTableEntry* name, LLXMLNodePtr& node, | |||
1091 | return false; | 1092 | return false; |
1092 | } | 1093 | } |
1093 | 1094 | ||
1094 | bool LLXMLNode::setAttributeString(const LLString& attr, const LLString& value) | 1095 | bool LLXMLNode::setAttributeString(const char* attr, const std::string& value) |
1095 | { | 1096 | { |
1096 | LLStringTableEntry* name = gStringTable.checkStringEntry(attr); | 1097 | LLStringTableEntry* name = gStringTable.checkStringEntry(attr); |
1097 | LLXMLAttribList::const_iterator child_itr = mAttributes.find(name); | 1098 | LLXMLAttribList::const_iterator child_itr = mAttributes.find(name); |
@@ -1104,25 +1105,25 @@ bool LLXMLNode::setAttributeString(const LLString& attr, const LLString& value) | |||
1104 | return false; | 1105 | return false; |
1105 | } | 1106 | } |
1106 | 1107 | ||
1107 | BOOL LLXMLNode::hasAttribute(const LLString& name ) | 1108 | BOOL LLXMLNode::hasAttribute(const char* name ) |
1108 | { | 1109 | { |
1109 | LLXMLNodePtr node; | 1110 | LLXMLNodePtr node; |
1110 | return getAttribute(name, node); | 1111 | return getAttribute(name, node); |
1111 | } | 1112 | } |
1112 | 1113 | ||
1113 | BOOL LLXMLNode::getAttributeBOOL(const LLString& name, BOOL& value ) | 1114 | BOOL LLXMLNode::getAttributeBOOL(const char* name, BOOL& value ) |
1114 | { | 1115 | { |
1115 | LLXMLNodePtr node; | 1116 | LLXMLNodePtr node; |
1116 | return (getAttribute(name, node) && node->getBoolValue(1, &value)); | 1117 | return (getAttribute(name, node) && node->getBoolValue(1, &value)); |
1117 | } | 1118 | } |
1118 | 1119 | ||
1119 | BOOL LLXMLNode::getAttributeU8(const LLString& name, U8& value ) | 1120 | BOOL LLXMLNode::getAttributeU8(const char* name, U8& value ) |
1120 | { | 1121 | { |
1121 | LLXMLNodePtr node; | 1122 | LLXMLNodePtr node; |
1122 | return (getAttribute(name, node) && node->getByteValue(1, &value)); | 1123 | return (getAttribute(name, node) && node->getByteValue(1, &value)); |
1123 | } | 1124 | } |
1124 | 1125 | ||
1125 | BOOL LLXMLNode::getAttributeS8(const LLString& name, S8& value ) | 1126 | BOOL LLXMLNode::getAttributeS8(const char* name, S8& value ) |
1126 | { | 1127 | { |
1127 | LLXMLNodePtr node; | 1128 | LLXMLNodePtr node; |
1128 | S32 val; | 1129 | S32 val; |
@@ -1134,7 +1135,7 @@ BOOL LLXMLNode::getAttributeS8(const LLString& name, S8& value ) | |||
1134 | return true; | 1135 | return true; |
1135 | } | 1136 | } |
1136 | 1137 | ||
1137 | BOOL LLXMLNode::getAttributeU16(const LLString& name, U16& value ) | 1138 | BOOL LLXMLNode::getAttributeU16(const char* name, U16& value ) |
1138 | { | 1139 | { |
1139 | LLXMLNodePtr node; | 1140 | LLXMLNodePtr node; |
1140 | U32 val; | 1141 | U32 val; |
@@ -1146,7 +1147,7 @@ BOOL LLXMLNode::getAttributeU16(const LLString& name, U16& value ) | |||
1146 | return true; | 1147 | return true; |
1147 | } | 1148 | } |
1148 | 1149 | ||
1149 | BOOL LLXMLNode::getAttributeS16(const LLString& name, S16& value ) | 1150 | BOOL LLXMLNode::getAttributeS16(const char* name, S16& value ) |
1150 | { | 1151 | { |
1151 | LLXMLNodePtr node; | 1152 | LLXMLNodePtr node; |
1152 | S32 val; | 1153 | S32 val; |
@@ -1158,73 +1159,73 @@ BOOL LLXMLNode::getAttributeS16(const LLString& name, S16& value ) | |||
1158 | return true; | 1159 | return true; |
1159 | } | 1160 | } |
1160 | 1161 | ||
1161 | BOOL LLXMLNode::getAttributeU32(const LLString& name, U32& value ) | 1162 | BOOL LLXMLNode::getAttributeU32(const char* name, U32& value ) |
1162 | { | 1163 | { |
1163 | LLXMLNodePtr node; | 1164 | LLXMLNodePtr node; |
1164 | return (getAttribute(name, node) && node->getUnsignedValue(1, &value)); | 1165 | return (getAttribute(name, node) && node->getUnsignedValue(1, &value)); |
1165 | } | 1166 | } |
1166 | 1167 | ||
1167 | BOOL LLXMLNode::getAttributeS32(const LLString& name, S32& value ) | 1168 | BOOL LLXMLNode::getAttributeS32(const char* name, S32& value ) |
1168 | { | 1169 | { |
1169 | LLXMLNodePtr node; | 1170 | LLXMLNodePtr node; |
1170 | return (getAttribute(name, node) && node->getIntValue(1, &value)); | 1171 | return (getAttribute(name, node) && node->getIntValue(1, &value)); |
1171 | } | 1172 | } |
1172 | 1173 | ||
1173 | BOOL LLXMLNode::getAttributeF32(const LLString& name, F32& value ) | 1174 | BOOL LLXMLNode::getAttributeF32(const char* name, F32& value ) |
1174 | { | 1175 | { |
1175 | LLXMLNodePtr node; | 1176 | LLXMLNodePtr node; |
1176 | return (getAttribute(name, node) && node->getFloatValue(1, &value)); | 1177 | return (getAttribute(name, node) && node->getFloatValue(1, &value)); |
1177 | } | 1178 | } |
1178 | 1179 | ||
1179 | BOOL LLXMLNode::getAttributeF64(const LLString& name, F64& value ) | 1180 | BOOL LLXMLNode::getAttributeF64(const char* name, F64& value ) |
1180 | { | 1181 | { |
1181 | LLXMLNodePtr node; | 1182 | LLXMLNodePtr node; |
1182 | return (getAttribute(name, node) && node->getDoubleValue(1, &value)); | 1183 | return (getAttribute(name, node) && node->getDoubleValue(1, &value)); |
1183 | } | 1184 | } |
1184 | 1185 | ||
1185 | BOOL LLXMLNode::getAttributeColor(const LLString& name, LLColor4& value ) | 1186 | BOOL LLXMLNode::getAttributeColor(const char* name, LLColor4& value ) |
1186 | { | 1187 | { |
1187 | LLXMLNodePtr node; | 1188 | LLXMLNodePtr node; |
1188 | return (getAttribute(name, node) && node->getFloatValue(4, value.mV)); | 1189 | return (getAttribute(name, node) && node->getFloatValue(4, value.mV)); |
1189 | } | 1190 | } |
1190 | 1191 | ||
1191 | BOOL LLXMLNode::getAttributeColor4(const LLString& name, LLColor4& value ) | 1192 | BOOL LLXMLNode::getAttributeColor4(const char* name, LLColor4& value ) |
1192 | { | 1193 | { |
1193 | LLXMLNodePtr node; | 1194 | LLXMLNodePtr node; |
1194 | return (getAttribute(name, node) && node->getFloatValue(4, value.mV)); | 1195 | return (getAttribute(name, node) && node->getFloatValue(4, value.mV)); |
1195 | } | 1196 | } |
1196 | 1197 | ||
1197 | BOOL LLXMLNode::getAttributeColor4U(const LLString& name, LLColor4U& value ) | 1198 | BOOL LLXMLNode::getAttributeColor4U(const char* name, LLColor4U& value ) |
1198 | { | 1199 | { |
1199 | LLXMLNodePtr node; | 1200 | LLXMLNodePtr node; |
1200 | return (getAttribute(name, node) && node->getByteValue(4, value.mV)); | 1201 | return (getAttribute(name, node) && node->getByteValue(4, value.mV)); |
1201 | } | 1202 | } |
1202 | 1203 | ||
1203 | BOOL LLXMLNode::getAttributeVector3(const LLString& name, LLVector3& value ) | 1204 | BOOL LLXMLNode::getAttributeVector3(const char* name, LLVector3& value ) |
1204 | { | 1205 | { |
1205 | LLXMLNodePtr node; | 1206 | LLXMLNodePtr node; |
1206 | return (getAttribute(name, node) && node->getFloatValue(3, value.mV)); | 1207 | return (getAttribute(name, node) && node->getFloatValue(3, value.mV)); |
1207 | } | 1208 | } |
1208 | 1209 | ||
1209 | BOOL LLXMLNode::getAttributeVector3d(const LLString& name, LLVector3d& value ) | 1210 | BOOL LLXMLNode::getAttributeVector3d(const char* name, LLVector3d& value ) |
1210 | { | 1211 | { |
1211 | LLXMLNodePtr node; | 1212 | LLXMLNodePtr node; |
1212 | return (getAttribute(name, node) && node->getDoubleValue(3, value.mdV)); | 1213 | return (getAttribute(name, node) && node->getDoubleValue(3, value.mdV)); |
1213 | } | 1214 | } |
1214 | 1215 | ||
1215 | BOOL LLXMLNode::getAttributeQuat(const LLString& name, LLQuaternion& value ) | 1216 | BOOL LLXMLNode::getAttributeQuat(const char* name, LLQuaternion& value ) |
1216 | { | 1217 | { |
1217 | LLXMLNodePtr node; | 1218 | LLXMLNodePtr node; |
1218 | return (getAttribute(name, node) && node->getFloatValue(4, value.mQ)); | 1219 | return (getAttribute(name, node) && node->getFloatValue(4, value.mQ)); |
1219 | } | 1220 | } |
1220 | 1221 | ||
1221 | BOOL LLXMLNode::getAttributeUUID(const LLString& name, LLUUID& value ) | 1222 | BOOL LLXMLNode::getAttributeUUID(const char* name, LLUUID& value ) |
1222 | { | 1223 | { |
1223 | LLXMLNodePtr node; | 1224 | LLXMLNodePtr node; |
1224 | return (getAttribute(name, node) && node->getUUIDValue(1, &value)); | 1225 | return (getAttribute(name, node) && node->getUUIDValue(1, &value)); |
1225 | } | 1226 | } |
1226 | 1227 | ||
1227 | BOOL LLXMLNode::getAttributeString(const LLString& name, LLString& value ) | 1228 | BOOL LLXMLNode::getAttributeString(const char* name, std::string& value ) |
1228 | { | 1229 | { |
1229 | LLXMLNodePtr node; | 1230 | LLXMLNodePtr node; |
1230 | if (!getAttribute(name, node)) | 1231 | if (!getAttribute(name, node)) |
@@ -1536,14 +1537,14 @@ U32 LLXMLNode::getBoolValue(U32 expected_length, BOOL *array) | |||
1536 | return 0; | 1537 | return 0; |
1537 | } | 1538 | } |
1538 | 1539 | ||
1539 | LLString *str_array = new LLString[expected_length]; | 1540 | std::string *str_array = new std::string[expected_length]; |
1540 | 1541 | ||
1541 | U32 length = getStringValue(expected_length, str_array); | 1542 | U32 length = getStringValue(expected_length, str_array); |
1542 | 1543 | ||
1543 | U32 ret_length = 0; | 1544 | U32 ret_length = 0; |
1544 | for (U32 i=0; i<length; ++i) | 1545 | for (U32 i=0; i<length; ++i) |
1545 | { | 1546 | { |
1546 | LLString::toLower(str_array[i]); | 1547 | LLStringUtil::toLower(str_array[i]); |
1547 | if (str_array[i] == "false") | 1548 | if (str_array[i] == "false") |
1548 | { | 1549 | { |
1549 | array[ret_length++] = FALSE; | 1550 | array[ret_length++] = FALSE; |
@@ -1872,7 +1873,7 @@ U32 LLXMLNode::getDoubleValue(U32 expected_length, F64 *array, Encoding encoding | |||
1872 | return i; | 1873 | return i; |
1873 | } | 1874 | } |
1874 | 1875 | ||
1875 | U32 LLXMLNode::getStringValue(U32 expected_length, LLString *array) | 1876 | U32 LLXMLNode::getStringValue(U32 expected_length, std::string *array) |
1876 | { | 1877 | { |
1877 | llassert(array); | 1878 | llassert(array); |
1878 | 1879 | ||
@@ -1947,7 +1948,7 @@ U32 LLXMLNode::getUUIDValue(U32 expected_length, LLUUID *array) | |||
1947 | memcpy(uuid_string, value_string, (UUID_STR_LENGTH-1)); /* Flawfinder: ignore */ | 1948 | memcpy(uuid_string, value_string, (UUID_STR_LENGTH-1)); /* Flawfinder: ignore */ |
1948 | uuid_string[(UUID_STR_LENGTH-1)] = 0; | 1949 | uuid_string[(UUID_STR_LENGTH-1)] = 0; |
1949 | 1950 | ||
1950 | if (!LLUUID::parseUUID(uuid_string, &uuid_value)) | 1951 | if (!LLUUID::parseUUID(std::string(uuid_string), &uuid_value)) |
1951 | { | 1952 | { |
1952 | break; | 1953 | break; |
1953 | } | 1954 | } |
@@ -1975,7 +1976,7 @@ U32 LLXMLNode::getNodeRefValue(U32 expected_length, LLXMLNode **array) | |||
1975 | return 0; | 1976 | return 0; |
1976 | } | 1977 | } |
1977 | 1978 | ||
1978 | LLString *string_array = new LLString[expected_length]; | 1979 | std::string *string_array = new std::string[expected_length]; |
1979 | 1980 | ||
1980 | U32 num_strings = getStringValue(expected_length, string_array); | 1981 | U32 num_strings = getStringValue(expected_length, string_array); |
1981 | 1982 | ||
@@ -2015,7 +2016,7 @@ void LLXMLNode::setBoolValue(U32 length, const BOOL *array) | |||
2015 | { | 2016 | { |
2016 | if (length == 0) return; | 2017 | if (length == 0) return; |
2017 | 2018 | ||
2018 | LLString new_value; | 2019 | std::string new_value; |
2019 | for (U32 pos=0; pos<length; ++pos) | 2020 | for (U32 pos=0; pos<length; ++pos) |
2020 | { | 2021 | { |
2021 | if (pos > 0) | 2022 | if (pos > 0) |
@@ -2038,7 +2039,7 @@ void LLXMLNode::setByteValue(U32 length, const U8* const array, Encoding encodin | |||
2038 | { | 2039 | { |
2039 | if (length == 0) return; | 2040 | if (length == 0) return; |
2040 | 2041 | ||
2041 | LLString new_value; | 2042 | std::string new_value; |
2042 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) | 2043 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) |
2043 | { | 2044 | { |
2044 | for (U32 pos=0; pos<length; ++pos) | 2045 | for (U32 pos=0; pos<length; ++pos) |
@@ -2081,7 +2082,7 @@ void LLXMLNode::setIntValue(U32 length, const S32 *array, Encoding encoding) | |||
2081 | { | 2082 | { |
2082 | if (length == 0) return; | 2083 | if (length == 0) return; |
2083 | 2084 | ||
2084 | LLString new_value; | 2085 | std::string new_value; |
2085 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) | 2086 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) |
2086 | { | 2087 | { |
2087 | for (U32 pos=0; pos<length; ++pos) | 2088 | for (U32 pos=0; pos<length; ++pos) |
@@ -2128,7 +2129,7 @@ void LLXMLNode::setUnsignedValue(U32 length, const U32* array, Encoding encoding | |||
2128 | { | 2129 | { |
2129 | if (length == 0) return; | 2130 | if (length == 0) return; |
2130 | 2131 | ||
2131 | LLString new_value; | 2132 | std::string new_value; |
2132 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) | 2133 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) |
2133 | { | 2134 | { |
2134 | for (U32 pos=0; pos<length; ++pos) | 2135 | for (U32 pos=0; pos<length; ++pos) |
@@ -2177,7 +2178,7 @@ void LLXMLNode::setLongValue(U32 length, const U64* array, Encoding encoding) | |||
2177 | { | 2178 | { |
2178 | if (length == 0) return; | 2179 | if (length == 0) return; |
2179 | 2180 | ||
2180 | LLString new_value; | 2181 | std::string new_value; |
2181 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) | 2182 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) |
2182 | { | 2183 | { |
2183 | for (U32 pos=0; pos<length; ++pos) | 2184 | for (U32 pos=0; pos<length; ++pos) |
@@ -2226,21 +2227,21 @@ void LLXMLNode::setFloatValue(U32 length, const F32 *array, Encoding encoding, U | |||
2226 | { | 2227 | { |
2227 | if (length == 0) return; | 2228 | if (length == 0) return; |
2228 | 2229 | ||
2229 | LLString new_value; | 2230 | std::string new_value; |
2230 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) | 2231 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) |
2231 | { | 2232 | { |
2232 | char format_string[10]; /* Flawfinder: ignore */ | 2233 | std::string format_string; |
2233 | if (precision > 0) | 2234 | if (precision > 0) |
2234 | { | 2235 | { |
2235 | if (precision > 25) | 2236 | if (precision > 25) |
2236 | { | 2237 | { |
2237 | precision = 25; | 2238 | precision = 25; |
2238 | } | 2239 | } |
2239 | snprintf(format_string, sizeof(format_string), "%%.%dg", precision); /* Flawfinder: ignore */ | 2240 | format_string = llformat( "%%.%dg", precision); |
2240 | } | 2241 | } |
2241 | else | 2242 | else |
2242 | { | 2243 | { |
2243 | snprintf(format_string, sizeof(format_string), "%%g"); /* Flawfinder: ignore */ | 2244 | format_string = llformat( "%%g"); |
2244 | } | 2245 | } |
2245 | 2246 | ||
2246 | for (U32 pos=0; pos<length; ++pos) | 2247 | for (U32 pos=0; pos<length; ++pos) |
@@ -2248,11 +2249,11 @@ void LLXMLNode::setFloatValue(U32 length, const F32 *array, Encoding encoding, U | |||
2248 | if (pos > 0) | 2249 | if (pos > 0) |
2249 | { | 2250 | { |
2250 | new_value.append(" "); | 2251 | new_value.append(" "); |
2251 | new_value.append(llformat(format_string, array[pos])); | 2252 | new_value.append(llformat(format_string.c_str(), array[pos])); |
2252 | } | 2253 | } |
2253 | else | 2254 | else |
2254 | { | 2255 | { |
2255 | new_value.assign(llformat(format_string, array[pos])); | 2256 | new_value.assign(llformat(format_string.c_str(), array[pos])); |
2256 | } | 2257 | } |
2257 | } | 2258 | } |
2258 | mValue = new_value; | 2259 | mValue = new_value; |
@@ -2277,32 +2278,32 @@ void LLXMLNode::setDoubleValue(U32 length, const F64 *array, Encoding encoding, | |||
2277 | { | 2278 | { |
2278 | if (length == 0) return; | 2279 | if (length == 0) return; |
2279 | 2280 | ||
2280 | LLString new_value; | 2281 | std::string new_value; |
2281 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) | 2282 | if (encoding == ENCODING_DEFAULT || encoding == ENCODING_DECIMAL) |
2282 | { | 2283 | { |
2283 | char format_string[10]; /* Flawfinder: ignore */ | 2284 | std::string format_string; |
2284 | if (precision > 0) | 2285 | if (precision > 0) |
2285 | { | 2286 | { |
2286 | if (precision > 25) | 2287 | if (precision > 25) |
2287 | { | 2288 | { |
2288 | precision = 25; | 2289 | precision = 25; |
2289 | } | 2290 | } |
2290 | snprintf(format_string, sizeof(format_string), "%%.%dg", precision); /* Flawfinder: ignore */ | 2291 | format_string = llformat( "%%.%dg", precision); |
2291 | } | 2292 | } |
2292 | else | 2293 | else |
2293 | { | 2294 | { |
2294 | snprintf(format_string, sizeof(format_string), "%%g"); /* Flawfinder: ignore */ | 2295 | format_string = llformat( "%%g"); |
2295 | } | 2296 | } |
2296 | for (U32 pos=0; pos<length; ++pos) | 2297 | for (U32 pos=0; pos<length; ++pos) |
2297 | { | 2298 | { |
2298 | if (pos > 0) | 2299 | if (pos > 0) |
2299 | { | 2300 | { |
2300 | new_value.append(" "); | 2301 | new_value.append(" "); |
2301 | new_value.append(llformat(format_string, array[pos])); | 2302 | new_value.append(llformat(format_string.c_str(), array[pos])); |
2302 | } | 2303 | } |
2303 | else | 2304 | else |
2304 | { | 2305 | { |
2305 | new_value.assign(llformat(format_string, array[pos])); | 2306 | new_value.assign(llformat(format_string.c_str(), array[pos])); |
2306 | } | 2307 | } |
2307 | } | 2308 | } |
2308 | mValue = new_value; | 2309 | mValue = new_value; |
@@ -2325,10 +2326,10 @@ void LLXMLNode::setDoubleValue(U32 length, const F64 *array, Encoding encoding, | |||
2325 | } | 2326 | } |
2326 | 2327 | ||
2327 | // static | 2328 | // static |
2328 | LLString LLXMLNode::escapeXML(const LLString& xml) | 2329 | std::string LLXMLNode::escapeXML(const std::string& xml) |
2329 | { | 2330 | { |
2330 | LLString out; | 2331 | std::string out; |
2331 | for (LLString::size_type i = 0; i < xml.size(); ++i) | 2332 | for (std::string::size_type i = 0; i < xml.size(); ++i) |
2332 | { | 2333 | { |
2333 | char c = xml[i]; | 2334 | char c = xml[i]; |
2334 | switch(c) | 2335 | switch(c) |
@@ -2344,11 +2345,11 @@ LLString LLXMLNode::escapeXML(const LLString& xml) | |||
2344 | return out; | 2345 | return out; |
2345 | } | 2346 | } |
2346 | 2347 | ||
2347 | void LLXMLNode::setStringValue(U32 length, const LLString *array) | 2348 | void LLXMLNode::setStringValue(U32 length, const std::string *array) |
2348 | { | 2349 | { |
2349 | if (length == 0) return; | 2350 | if (length == 0) return; |
2350 | 2351 | ||
2351 | LLString new_value; | 2352 | std::string new_value; |
2352 | for (U32 pos=0; pos<length; ++pos) | 2353 | for (U32 pos=0; pos<length; ++pos) |
2353 | { | 2354 | { |
2354 | new_value.append(escapeXML(array[pos])); | 2355 | new_value.append(escapeXML(array[pos])); |
@@ -2365,7 +2366,7 @@ void LLXMLNode::setUUIDValue(U32 length, const LLUUID *array) | |||
2365 | { | 2366 | { |
2366 | if (length == 0) return; | 2367 | if (length == 0) return; |
2367 | 2368 | ||
2368 | LLString new_value; | 2369 | std::string new_value; |
2369 | for (U32 pos=0; pos<length; ++pos) | 2370 | for (U32 pos=0; pos<length; ++pos) |
2370 | { | 2371 | { |
2371 | new_value.append(array[pos].asString()); | 2372 | new_value.append(array[pos].asString()); |
@@ -2382,7 +2383,7 @@ void LLXMLNode::setNodeRefValue(U32 length, const LLXMLNode **array) | |||
2382 | { | 2383 | { |
2383 | if (length == 0) return; | 2384 | if (length == 0) return; |
2384 | 2385 | ||
2385 | LLString new_value; | 2386 | std::string new_value; |
2386 | for (U32 pos=0; pos<length; ++pos) | 2387 | for (U32 pos=0; pos<length; ++pos) |
2387 | { | 2388 | { |
2388 | if (array[pos]->mID != "") | 2389 | if (array[pos]->mID != "") |
@@ -2402,7 +2403,7 @@ void LLXMLNode::setNodeRefValue(U32 length, const LLXMLNode **array) | |||
2402 | mType = TYPE_NODEREF; | 2403 | mType = TYPE_NODEREF; |
2403 | } | 2404 | } |
2404 | 2405 | ||
2405 | void LLXMLNode::setValue(const LLString& value) | 2406 | void LLXMLNode::setValue(const std::string& value) |
2406 | { | 2407 | { |
2407 | if (TYPE_CONTAINER == mType) | 2408 | if (TYPE_CONTAINER == mType) |
2408 | { | 2409 | { |
@@ -2439,7 +2440,7 @@ void LLXMLNode::findDefault(LLXMLNode *defaults_list) | |||
2439 | mDefault = NULL; | 2440 | mDefault = NULL; |
2440 | } | 2441 | } |
2441 | 2442 | ||
2442 | BOOL LLXMLNode::deleteChildren(const LLString& name) | 2443 | BOOL LLXMLNode::deleteChildren(const std::string& name) |
2443 | { | 2444 | { |
2444 | U32 removed_count = 0; | 2445 | U32 removed_count = 0; |
2445 | LLXMLNodeList node_list; | 2446 | LLXMLNodeList node_list; |
@@ -2491,7 +2492,7 @@ void LLXMLNode::setAttributes(LLXMLNode::ValueType type, U32 precision, LLXMLNod | |||
2491 | mLength = length; | 2492 | mLength = length; |
2492 | } | 2493 | } |
2493 | 2494 | ||
2494 | void LLXMLNode::setName(const LLString& name) | 2495 | void LLXMLNode::setName(const std::string& name) |
2495 | { | 2496 | { |
2496 | setName(gStringTable.addStringEntry(name)); | 2497 | setName(gStringTable.addStringEntry(name)); |
2497 | } | 2498 | } |
@@ -2512,10 +2513,11 @@ void LLXMLNode::setName(LLStringTableEntry* name) | |||
2512 | } | 2513 | } |
2513 | } | 2514 | } |
2514 | 2515 | ||
2515 | void LLXMLNode::appendValue(const LLString& value) | 2516 | // Unused |
2516 | { | 2517 | // void LLXMLNode::appendValue(const std::string& value) |
2517 | mValue.append(value); | 2518 | // { |
2518 | } | 2519 | // mValue.append(value); |
2520 | // } | ||
2519 | 2521 | ||
2520 | U32 LLXMLNode::getChildCount() const | 2522 | U32 LLXMLNode::getChildCount() const |
2521 | { | 2523 | { |
@@ -2565,14 +2567,13 @@ LLXMLNode *get_rand_node(LLXMLNode *node) | |||
2565 | void LLXMLNode::createUnitTest(S32 max_num_children) | 2567 | void LLXMLNode::createUnitTest(S32 max_num_children) |
2566 | { | 2568 | { |
2567 | // Random ID | 2569 | // Random ID |
2568 | char rand_id[20]; /* Flawfinder: ignore */ | 2570 | std::string rand_id; |
2569 | U32 rand_id_len = get_rand(10)+5; | 2571 | U32 rand_id_len = get_rand(10)+5; |
2570 | U32 pos = 0; | 2572 | for (U32 pos = 0; pos<rand_id_len; ++pos) |
2571 | for (; pos<rand_id_len; ++pos) | ||
2572 | { | 2573 | { |
2573 | rand_id[pos] = get_rand(26)+'a'; | 2574 | char c = 'a' + get_rand(26); |
2575 | rand_id.append(1, c); | ||
2574 | } | 2576 | } |
2575 | rand_id[pos] = 0; | ||
2576 | mID = rand_id; | 2577 | mID = rand_id; |
2577 | 2578 | ||
2578 | if (max_num_children < 2) | 2579 | if (max_num_children < 2) |
@@ -2594,26 +2595,24 @@ void LLXMLNode::createUnitTest(S32 max_num_children) | |||
2594 | for (U32 child_num=0; child_num<num_children; ++child_num) | 2595 | for (U32 child_num=0; child_num<num_children; ++child_num) |
2595 | { | 2596 | { |
2596 | // Random Name | 2597 | // Random Name |
2597 | char child_name[20]; /* Flawfinder: ignore */ | 2598 | std::string child_name; |
2598 | U32 child_name_len = get_rand(10)+5; | 2599 | U32 child_name_len = get_rand(10)+5; |
2599 | pos = 0; | 2600 | for (U32 pos = 0; pos<child_name_len; ++pos) |
2600 | for (; pos<child_name_len; ++pos) | ||
2601 | { | 2601 | { |
2602 | child_name[pos] = get_rand(26)+'a'; | 2602 | char c = 'a' + get_rand(26); |
2603 | child_name.append(1, c); | ||
2603 | } | 2604 | } |
2604 | child_name[pos] = 0; | ||
2605 | 2605 | ||
2606 | LLXMLNode *new_child = createChild(child_name, FALSE); | 2606 | LLXMLNode *new_child = createChild(child_name.c_str(), FALSE); |
2607 | 2607 | ||
2608 | // Random ID | 2608 | // Random ID |
2609 | char child_id[20]; /* Flawfinder: ignore */ | 2609 | std::string child_id; |
2610 | U32 child_id_len = get_rand(10)+5; | 2610 | U32 child_id_len = get_rand(10)+5; |
2611 | pos = 0; | 2611 | for (U32 pos=0; pos<child_id_len; ++pos) |
2612 | for (; pos<child_id_len; ++pos) | ||
2613 | { | 2612 | { |
2614 | child_id[pos] = get_rand(26)+'a'; | 2613 | char c = 'a' + get_rand(26); |
2614 | child_id.append(1, c); | ||
2615 | } | 2615 | } |
2616 | child_id[pos] = 0; | ||
2617 | new_child->mID = child_id; | 2616 | new_child->mID = child_id; |
2618 | 2617 | ||
2619 | // Random Length | 2618 | // Random Length |
@@ -2747,7 +2746,7 @@ void LLXMLNode::createUnitTest(S32 max_num_children) | |||
2747 | createChild("float_checksum", TRUE)->setUnsignedValue(1, &float_checksum, LLXMLNode::ENCODING_HEX); | 2746 | createChild("float_checksum", TRUE)->setUnsignedValue(1, &float_checksum, LLXMLNode::ENCODING_HEX); |
2748 | } | 2747 | } |
2749 | 2748 | ||
2750 | BOOL LLXMLNode::performUnitTest(LLString &error_buffer) | 2749 | BOOL LLXMLNode::performUnitTest(std::string &error_buffer) |
2751 | { | 2750 | { |
2752 | if (!mChildren) | 2751 | if (!mChildren) |
2753 | { | 2752 | { |
@@ -3021,10 +3020,10 @@ LLXMLNodePtr LLXMLNode::getNextSibling() | |||
3021 | return ret; | 3020 | return ret; |
3022 | } | 3021 | } |
3023 | 3022 | ||
3024 | LLString LLXMLNode::getTextContents() const | 3023 | std::string LLXMLNode::getTextContents() const |
3025 | { | 3024 | { |
3026 | std::string msg; | 3025 | std::string msg; |
3027 | LLString contents = mValue; | 3026 | std::string contents = mValue; |
3028 | std::string::size_type n = contents.find_first_not_of(" \t\n"); | 3027 | std::string::size_type n = contents.find_first_not_of(" \t\n"); |
3029 | if (n != std::string::npos && contents[n] == '\"') | 3028 | if (n != std::string::npos && contents[n] == '\"') |
3030 | { | 3029 | { |
@@ -3068,10 +3067,10 @@ LLString LLXMLNode::getTextContents() const | |||
3068 | else | 3067 | else |
3069 | { | 3068 | { |
3070 | // Case 2: node has embedded text (beginning and trailing whitespace trimmed) | 3069 | // Case 2: node has embedded text (beginning and trailing whitespace trimmed) |
3071 | LLString::size_type start = mValue.find_first_not_of(" \t\n"); | 3070 | std::string::size_type start = mValue.find_first_not_of(" \t\n"); |
3072 | if (start != mValue.npos) | 3071 | if (start != mValue.npos) |
3073 | { | 3072 | { |
3074 | LLString::size_type end = mValue.find_last_not_of(" \t\n"); | 3073 | std::string::size_type end = mValue.find_last_not_of(" \t\n"); |
3075 | if (end != mValue.npos) | 3074 | if (end != mValue.npos) |
3076 | { | 3075 | { |
3077 | msg = mValue.substr(start, end+1-start); | 3076 | msg = mValue.substr(start, end+1-start); |
diff --git a/linden/indra/llxml/llxmlnode.h b/linden/indra/llxml/llxmlnode.h index 269108c..ed170f6 100644 --- a/linden/indra/llxml/llxmlnode.h +++ b/linden/indra/llxml/llxmlnode.h | |||
@@ -49,6 +49,13 @@ | |||
49 | #include "llstringtable.h" | 49 | #include "llstringtable.h" |
50 | 50 | ||
51 | 51 | ||
52 | class LLVector3; | ||
53 | class LLVector3d; | ||
54 | class LLQuaternion; | ||
55 | class LLUUID; | ||
56 | class LLColor4; | ||
57 | class LLColor4U; | ||
58 | |||
52 | 59 | ||
53 | struct CompareAttributes | 60 | struct CompareAttributes |
54 | { | 61 | { |
@@ -68,10 +75,18 @@ struct CompareAttributes | |||
68 | 75 | ||
69 | class LLXMLNode; | 76 | class LLXMLNode; |
70 | typedef LLPointer<LLXMLNode> LLXMLNodePtr; | 77 | typedef LLPointer<LLXMLNode> LLXMLNodePtr; |
71 | typedef std::multimap<LLString, LLXMLNodePtr > LLXMLNodeList; | 78 | typedef std::multimap<std::string, LLXMLNodePtr > LLXMLNodeList; |
72 | typedef std::multimap<const LLStringTableEntry *, LLXMLNodePtr > LLXMLChildList; | 79 | typedef std::multimap<const LLStringTableEntry *, LLXMLNodePtr > LLXMLChildList; |
73 | typedef std::map<const LLStringTableEntry *, LLXMLNodePtr, CompareAttributes> LLXMLAttribList; | 80 | typedef std::map<const LLStringTableEntry *, LLXMLNodePtr, CompareAttributes> LLXMLAttribList; |
74 | 81 | ||
82 | class LLColor4; | ||
83 | class LLColor4U; | ||
84 | class LLQuaternion; | ||
85 | class LLVector3; | ||
86 | class LLVector3d; | ||
87 | class LLVector4; | ||
88 | class LLVector4U; | ||
89 | |||
75 | struct LLXMLChildren | 90 | struct LLXMLChildren |
76 | { | 91 | { |
77 | LLXMLChildList map; // Map of children names->pointers | 92 | LLXMLChildList map; // Map of children names->pointers |
@@ -107,7 +122,7 @@ protected: | |||
107 | 122 | ||
108 | public: | 123 | public: |
109 | LLXMLNode(); | 124 | LLXMLNode(); |
110 | LLXMLNode(const LLString& name, BOOL is_attribute); | 125 | LLXMLNode(const char* name, BOOL is_attribute); |
111 | LLXMLNode(LLStringTableEntry* name, BOOL is_attribute); | 126 | LLXMLNode(LLStringTableEntry* name, BOOL is_attribute); |
112 | 127 | ||
113 | BOOL isNull(); | 128 | BOOL isNull(); |
@@ -118,7 +133,7 @@ public: | |||
118 | 133 | ||
119 | // Serialization | 134 | // Serialization |
120 | static bool parseFile( | 135 | static bool parseFile( |
121 | LLString filename, | 136 | const std::string& filename, |
122 | LLXMLNodePtr& node, | 137 | LLXMLNodePtr& node, |
123 | LLXMLNode* defaults_tree); | 138 | LLXMLNode* defaults_tree); |
124 | static bool parseBuffer( | 139 | static bool parseBuffer( |
@@ -134,16 +149,16 @@ public: | |||
134 | LLXMLNodePtr& node, | 149 | LLXMLNodePtr& node, |
135 | LLXMLNodePtr& update_node); | 150 | LLXMLNodePtr& update_node); |
136 | static void writeHeaderToFile(LLFILE *fOut); | 151 | static void writeHeaderToFile(LLFILE *fOut); |
137 | void writeToFile(LLFILE *fOut, LLString indent = LLString()); | 152 | void writeToFile(LLFILE *fOut, const std::string& indent = std::string()); |
138 | void writeToOstream(std::ostream& output_stream, const LLString& indent = LLString()); | 153 | void writeToOstream(std::ostream& output_stream, const std::string& indent = std::string()); |
139 | 154 | ||
140 | // Utility | 155 | // Utility |
141 | void findName(const LLString& name, LLXMLNodeList &results); | 156 | void findName(const std::string& name, LLXMLNodeList &results); |
142 | void findName(LLStringTableEntry* name, LLXMLNodeList &results); | 157 | void findName(LLStringTableEntry* name, LLXMLNodeList &results); |
143 | void findID(const LLString& id, LLXMLNodeList &results); | 158 | void findID(const std::string& id, LLXMLNodeList &results); |
144 | 159 | ||
145 | 160 | ||
146 | virtual LLXMLNodePtr createChild(const LLString& name, BOOL is_attribute); | 161 | virtual LLXMLNodePtr createChild(const char* name, BOOL is_attribute); |
147 | virtual LLXMLNodePtr createChild(LLStringTableEntry* name, BOOL is_attribute); | 162 | virtual LLXMLNodePtr createChild(LLStringTableEntry* name, BOOL is_attribute); |
148 | 163 | ||
149 | 164 | ||
@@ -155,49 +170,49 @@ public: | |||
155 | U32 getLongValue(U32 expected_length, U64 *array, Encoding encoding = ENCODING_DEFAULT); | 170 | U32 getLongValue(U32 expected_length, U64 *array, Encoding encoding = ENCODING_DEFAULT); |
156 | U32 getFloatValue(U32 expected_length, F32 *array, Encoding encoding = ENCODING_DEFAULT); | 171 | U32 getFloatValue(U32 expected_length, F32 *array, Encoding encoding = ENCODING_DEFAULT); |
157 | U32 getDoubleValue(U32 expected_length, F64 *array, Encoding encoding = ENCODING_DEFAULT); | 172 | U32 getDoubleValue(U32 expected_length, F64 *array, Encoding encoding = ENCODING_DEFAULT); |
158 | U32 getStringValue(U32 expected_length, LLString *array); | 173 | U32 getStringValue(U32 expected_length, std::string *array); |
159 | U32 getUUIDValue(U32 expected_length, LLUUID *array); | 174 | U32 getUUIDValue(U32 expected_length, LLUUID *array); |
160 | U32 getNodeRefValue(U32 expected_length, LLXMLNode **array); | 175 | U32 getNodeRefValue(U32 expected_length, LLXMLNode **array); |
161 | 176 | ||
162 | BOOL hasAttribute(const LLString& name ); | 177 | BOOL hasAttribute(const char* name ); |
163 | 178 | ||
164 | BOOL getAttributeBOOL(const LLString& name, BOOL& value ); | 179 | BOOL getAttributeBOOL(const char* name, BOOL& value ); |
165 | BOOL getAttributeU8(const LLString& name, U8& value ); | 180 | BOOL getAttributeU8(const char* name, U8& value ); |
166 | BOOL getAttributeS8(const LLString& name, S8& value ); | 181 | BOOL getAttributeS8(const char* name, S8& value ); |
167 | BOOL getAttributeU16(const LLString& name, U16& value ); | 182 | BOOL getAttributeU16(const char* name, U16& value ); |
168 | BOOL getAttributeS16(const LLString& name, S16& value ); | 183 | BOOL getAttributeS16(const char* name, S16& value ); |
169 | BOOL getAttributeU32(const LLString& name, U32& value ); | 184 | BOOL getAttributeU32(const char* name, U32& value ); |
170 | BOOL getAttributeS32(const LLString& name, S32& value ); | 185 | BOOL getAttributeS32(const char* name, S32& value ); |
171 | BOOL getAttributeF32(const LLString& name, F32& value ); | 186 | BOOL getAttributeF32(const char* name, F32& value ); |
172 | BOOL getAttributeF64(const LLString& name, F64& value ); | 187 | BOOL getAttributeF64(const char* name, F64& value ); |
173 | BOOL getAttributeColor(const LLString& name, LLColor4& value ); | 188 | BOOL getAttributeColor(const char* name, LLColor4& value ); |
174 | BOOL getAttributeColor4(const LLString& name, LLColor4& value ); | 189 | BOOL getAttributeColor4(const char* name, LLColor4& value ); |
175 | BOOL getAttributeColor4U(const LLString& name, LLColor4U& value ); | 190 | BOOL getAttributeColor4U(const char* name, LLColor4U& value ); |
176 | BOOL getAttributeVector3(const LLString& name, LLVector3& value ); | 191 | BOOL getAttributeVector3(const char* name, LLVector3& value ); |
177 | BOOL getAttributeVector3d(const LLString& name, LLVector3d& value ); | 192 | BOOL getAttributeVector3d(const char* name, LLVector3d& value ); |
178 | BOOL getAttributeQuat(const LLString& name, LLQuaternion& value ); | 193 | BOOL getAttributeQuat(const char* name, LLQuaternion& value ); |
179 | BOOL getAttributeUUID(const LLString& name, LLUUID& value ); | 194 | BOOL getAttributeUUID(const char* name, LLUUID& value ); |
180 | BOOL getAttributeString(const LLString& name, LLString& value ); | 195 | BOOL getAttributeString(const char* name, std::string& value ); |
181 | 196 | ||
182 | const ValueType& getType() const { return mType; } | 197 | const ValueType& getType() const { return mType; } |
183 | U32 getLength() const { return mLength; } | 198 | U32 getLength() const { return mLength; } |
184 | U32 getPrecision() const { return mPrecision; } | 199 | U32 getPrecision() const { return mPrecision; } |
185 | const LLString& getValue() const { return mValue; } | 200 | const std::string& getValue() const { return mValue; } |
186 | LLString getTextContents() const; | 201 | std::string getTextContents() const; |
187 | const LLStringTableEntry* getName() const { return mName; } | 202 | const LLStringTableEntry* getName() const { return mName; } |
188 | BOOL hasName(const char* name) const { return mName == gStringTable.checkStringEntry(name); } | 203 | BOOL hasName(const char* name) const { return mName == gStringTable.checkStringEntry(name); } |
189 | BOOL hasName(LLString name) const { return mName == gStringTable.checkStringEntry(name.c_str()); } | 204 | BOOL hasName(const std::string& name) const { return mName == gStringTable.checkStringEntry(name.c_str()); } |
190 | const LLString& getID() const { return mID; } | 205 | const std::string& getID() const { return mID; } |
191 | 206 | ||
192 | U32 getChildCount() const; | 207 | U32 getChildCount() const; |
193 | // getChild returns a Null LLXMLNode (not a NULL pointer) if there is no such child. | 208 | // getChild returns a Null LLXMLNode (not a NULL pointer) if there is no such child. |
194 | // This child has no value so any getTYPEValue() calls on it will return 0. | 209 | // This child has no value so any getTYPEValue() calls on it will return 0. |
195 | bool getChild(const LLString& name, LLXMLNodePtr& node, BOOL use_default_if_missing = TRUE); | 210 | bool getChild(const char* name, LLXMLNodePtr& node, BOOL use_default_if_missing = TRUE); |
196 | bool getChild(const LLStringTableEntry* name, LLXMLNodePtr& node, BOOL use_default_if_missing = TRUE); | 211 | bool getChild(const LLStringTableEntry* name, LLXMLNodePtr& node, BOOL use_default_if_missing = TRUE); |
197 | void getChildren(const LLString& name, LLXMLNodeList &children, BOOL use_default_if_missing = TRUE) const; | 212 | void getChildren(const char* name, LLXMLNodeList &children, BOOL use_default_if_missing = TRUE) const; |
198 | void getChildren(const LLStringTableEntry* name, LLXMLNodeList &children, BOOL use_default_if_missing = TRUE) const; | 213 | void getChildren(const LLStringTableEntry* name, LLXMLNodeList &children, BOOL use_default_if_missing = TRUE) const; |
199 | 214 | ||
200 | bool getAttribute(const LLString& name, LLXMLNodePtr& node, BOOL use_default_if_missing = TRUE); | 215 | bool getAttribute(const char* name, LLXMLNodePtr& node, BOOL use_default_if_missing = TRUE); |
201 | bool getAttribute(const LLStringTableEntry* name, LLXMLNodePtr& node, BOOL use_default_if_missing = TRUE); | 216 | bool getAttribute(const LLStringTableEntry* name, LLXMLNodePtr& node, BOOL use_default_if_missing = TRUE); |
202 | 217 | ||
203 | // The following skip over attributes | 218 | // The following skip over attributes |
@@ -208,7 +223,7 @@ public: | |||
208 | 223 | ||
209 | // Setters | 224 | // Setters |
210 | 225 | ||
211 | bool setAttributeString(const LLString& attr, const LLString& value); | 226 | bool setAttributeString(const char* attr, const std::string& value); |
212 | 227 | ||
213 | void setBoolValue(const BOOL value) { setBoolValue(1, &value); } | 228 | void setBoolValue(const BOOL value) { setBoolValue(1, &value); } |
214 | void setByteValue(const U8 value, Encoding encoding = ENCODING_DEFAULT) { setByteValue(1, &value, encoding); } | 229 | void setByteValue(const U8 value, Encoding encoding = ENCODING_DEFAULT) { setByteValue(1, &value, encoding); } |
@@ -217,7 +232,7 @@ public: | |||
217 | void setLongValue(const U64 value, Encoding encoding = ENCODING_DEFAULT) { setLongValue(1, &value, encoding); } | 232 | void setLongValue(const U64 value, Encoding encoding = ENCODING_DEFAULT) { setLongValue(1, &value, encoding); } |
218 | void setFloatValue(const F32 value, Encoding encoding = ENCODING_DEFAULT, U32 precision = 0) { setFloatValue(1, &value, encoding); } | 233 | void setFloatValue(const F32 value, Encoding encoding = ENCODING_DEFAULT, U32 precision = 0) { setFloatValue(1, &value, encoding); } |
219 | void setDoubleValue(const F64 value, Encoding encoding = ENCODING_DEFAULT, U32 precision = 0) { setDoubleValue(1, &value, encoding); } | 234 | void setDoubleValue(const F64 value, Encoding encoding = ENCODING_DEFAULT, U32 precision = 0) { setDoubleValue(1, &value, encoding); } |
220 | void setStringValue(const LLString value) { setStringValue(1, &value); } | 235 | void setStringValue(const std::string& value) { setStringValue(1, &value); } |
221 | void setUUIDValue(const LLUUID value) { setUUIDValue(1, &value); } | 236 | void setUUIDValue(const LLUUID value) { setUUIDValue(1, &value); } |
222 | void setNodeRefValue(const LLXMLNode *value) { setNodeRefValue(1, &value); } | 237 | void setNodeRefValue(const LLXMLNode *value) { setNodeRefValue(1, &value); } |
223 | 238 | ||
@@ -228,16 +243,16 @@ public: | |||
228 | void setLongValue(U32 length, const U64 *array, Encoding encoding = ENCODING_DEFAULT); | 243 | void setLongValue(U32 length, const U64 *array, Encoding encoding = ENCODING_DEFAULT); |
229 | void setFloatValue(U32 length, const F32 *array, Encoding encoding = ENCODING_DEFAULT, U32 precision = 0); | 244 | void setFloatValue(U32 length, const F32 *array, Encoding encoding = ENCODING_DEFAULT, U32 precision = 0); |
230 | void setDoubleValue(U32 length, const F64 *array, Encoding encoding = ENCODING_DEFAULT, U32 precision = 0); | 245 | void setDoubleValue(U32 length, const F64 *array, Encoding encoding = ENCODING_DEFAULT, U32 precision = 0); |
231 | void setStringValue(U32 length, const LLString *array); | 246 | void setStringValue(U32 length, const std::string *array); |
232 | void setUUIDValue(U32 length, const LLUUID *array); | 247 | void setUUIDValue(U32 length, const LLUUID *array); |
233 | void setNodeRefValue(U32 length, const LLXMLNode **array); | 248 | void setNodeRefValue(U32 length, const LLXMLNode **array); |
234 | void setValue(const LLString& value); | 249 | void setValue(const std::string& value); |
235 | void setName(const LLString& name); | 250 | void setName(const std::string& name); |
236 | void setName(LLStringTableEntry* name); | 251 | void setName(LLStringTableEntry* name); |
237 | 252 | ||
238 | // Escapes " (quot) ' (apos) & (amp) < (lt) > (gt) | 253 | // Escapes " (quot) ' (apos) & (amp) < (lt) > (gt) |
239 | // TomY TODO: Make this private | 254 | // TomY TODO: Make this private |
240 | static LLString escapeXML(const LLString& xml); | 255 | static std::string escapeXML(const std::string& xml); |
241 | 256 | ||
242 | // Set the default node corresponding to this default node | 257 | // Set the default node corresponding to this default node |
243 | void setDefault(LLXMLNode *default_node); | 258 | void setDefault(LLXMLNode *default_node); |
@@ -250,20 +265,20 @@ public: | |||
250 | // Delete any child nodes that aren't among the tree's children, recursive | 265 | // Delete any child nodes that aren't among the tree's children, recursive |
251 | void scrubToTree(LLXMLNode *tree); | 266 | void scrubToTree(LLXMLNode *tree); |
252 | 267 | ||
253 | BOOL deleteChildren(const LLString& name); | 268 | BOOL deleteChildren(const std::string& name); |
254 | BOOL deleteChildren(LLStringTableEntry* name); | 269 | BOOL deleteChildren(LLStringTableEntry* name); |
255 | void setAttributes(ValueType type, U32 precision, Encoding encoding, U32 length); | 270 | void setAttributes(ValueType type, U32 precision, Encoding encoding, U32 length); |
256 | void appendValue(const LLString& value); | 271 | // void appendValue(const std::string& value); // Unused |
257 | 272 | ||
258 | // Unit Testing | 273 | // Unit Testing |
259 | void createUnitTest(S32 max_num_children); | 274 | void createUnitTest(S32 max_num_children); |
260 | BOOL performUnitTest(LLString &error_buffer); | 275 | BOOL performUnitTest(std::string &error_buffer); |
261 | 276 | ||
262 | protected: | 277 | protected: |
263 | BOOL removeChild(LLXMLNode* child); | 278 | BOOL removeChild(LLXMLNode* child); |
264 | 279 | ||
265 | public: | 280 | public: |
266 | LLString mID; // The ID attribute of this node | 281 | std::string mID; // The ID attribute of this node |
267 | 282 | ||
268 | XML_Parser *mParser; // Temporary pointer while loading | 283 | XML_Parser *mParser; // Temporary pointer while loading |
269 | 284 | ||
@@ -286,7 +301,7 @@ public: | |||
286 | 301 | ||
287 | protected: | 302 | protected: |
288 | LLStringTableEntry *mName; // The name of this node | 303 | LLStringTableEntry *mName; // The name of this node |
289 | LLString mValue; // The value of this node (use getters/setters only) | 304 | std::string mValue; // The value of this node (use getters/setters only) |
290 | 305 | ||
291 | LLXMLNodePtr mDefault; // Mirror node in the default tree | 306 | LLXMLNodePtr mDefault; // Mirror node in the default tree |
292 | 307 | ||
diff --git a/linden/indra/llxml/llxmlparser.cpp b/linden/indra/llxml/llxmlparser.cpp index 3b4d944..b0a3a05 100644 --- a/linden/indra/llxml/llxmlparser.cpp +++ b/linden/indra/llxml/llxmlparser.cpp | |||
@@ -45,7 +45,7 @@ LLXmlParser::LLXmlParser() | |||
45 | mParser( NULL ), | 45 | mParser( NULL ), |
46 | mDepth( 0 ) | 46 | mDepth( 0 ) |
47 | { | 47 | { |
48 | strcpy( mAuxErrorString, "no error" ); /* Flawfinder: ignore */ | 48 | mAuxErrorString = "no error"; |
49 | 49 | ||
50 | // Override the document's declared encoding. | 50 | // Override the document's declared encoding. |
51 | mParser = XML_ParserCreate(NULL); | 51 | mParser = XML_ParserCreate(NULL); |
@@ -77,10 +77,10 @@ BOOL LLXmlParser::parseFile(const std::string &path) | |||
77 | 77 | ||
78 | BOOL success = TRUE; | 78 | BOOL success = TRUE; |
79 | 79 | ||
80 | LLFILE* file = LLFile::fopen(path.c_str(), "rb"); /* Flawfinder: ignore */ | 80 | LLFILE* file = LLFile::fopen(path, "rb"); /* Flawfinder: ignore */ |
81 | if( !file ) | 81 | if( !file ) |
82 | { | 82 | { |
83 | snprintf( mAuxErrorString, sizeof(mAuxErrorString), "Couldn't open file %s", path.c_str()); /* Flawfinder: ignore */ | 83 | mAuxErrorString = llformat( "Couldn't open file %s", path.c_str()); |
84 | success = FALSE; | 84 | success = FALSE; |
85 | } | 85 | } |
86 | else | 86 | else |
@@ -94,7 +94,7 @@ BOOL LLXmlParser::parseFile(const std::string &path) | |||
94 | void* buffer = XML_GetBuffer(mParser, buffer_size); | 94 | void* buffer = XML_GetBuffer(mParser, buffer_size); |
95 | if( !buffer ) | 95 | if( !buffer ) |
96 | { | 96 | { |
97 | snprintf( mAuxErrorString, sizeof(mAuxErrorString), "Unable to allocate XML buffer while reading file %s", path.c_str() ); /* Flawfinder: ignore */ | 97 | mAuxErrorString = llformat( "Unable to allocate XML buffer while reading file %s", path.c_str() ); |
98 | success = FALSE; | 98 | success = FALSE; |
99 | goto exit_label; | 99 | goto exit_label; |
100 | } | 100 | } |
@@ -102,14 +102,14 @@ BOOL LLXmlParser::parseFile(const std::string &path) | |||
102 | bytes_read = (S32)fread(buffer, 1, buffer_size, file); | 102 | bytes_read = (S32)fread(buffer, 1, buffer_size, file); |
103 | if( bytes_read <= 0 ) | 103 | if( bytes_read <= 0 ) |
104 | { | 104 | { |
105 | snprintf( mAuxErrorString, sizeof(mAuxErrorString), "Error while reading file %s", path.c_str() ); /* Flawfinder: ignore */ | 105 | mAuxErrorString = llformat( "Error while reading file %s", path.c_str() ); |
106 | success = FALSE; | 106 | success = FALSE; |
107 | goto exit_label; | 107 | goto exit_label; |
108 | } | 108 | } |
109 | 109 | ||
110 | if( !XML_ParseBuffer(mParser, bytes_read, TRUE ) ) | 110 | if( !XML_ParseBuffer(mParser, bytes_read, TRUE ) ) |
111 | { | 111 | { |
112 | snprintf( mAuxErrorString, sizeof(mAuxErrorString), "Error while parsing file %s", path.c_str() ); /* Flawfinder: ignore */ | 112 | mAuxErrorString = llformat( "Error while parsing file %s", path.c_str() ); |
113 | success = FALSE; | 113 | success = FALSE; |
114 | } | 114 | } |
115 | 115 | ||
@@ -146,7 +146,7 @@ const char* LLXmlParser::getErrorString() | |||
146 | const char* error_string = XML_ErrorString(XML_GetErrorCode( mParser )); | 146 | const char* error_string = XML_ErrorString(XML_GetErrorCode( mParser )); |
147 | if( !error_string ) | 147 | if( !error_string ) |
148 | { | 148 | { |
149 | error_string = mAuxErrorString; | 149 | error_string = mAuxErrorString.c_str(); |
150 | } | 150 | } |
151 | return error_string; | 151 | return error_string; |
152 | } | 152 | } |
diff --git a/linden/indra/llxml/llxmlparser.h b/linden/indra/llxml/llxmlparser.h index 7ce5524..4717d5d 100644 --- a/linden/indra/llxml/llxmlparser.h +++ b/linden/indra/llxml/llxmlparser.h | |||
@@ -132,7 +132,7 @@ public: | |||
132 | protected: | 132 | protected: |
133 | XML_Parser mParser; | 133 | XML_Parser mParser; |
134 | int mDepth; | 134 | int mDepth; |
135 | char mAuxErrorString[1024]; /*Flawfinder: ignore*/ | 135 | std::string mAuxErrorString; |
136 | }; | 136 | }; |
137 | 137 | ||
138 | #endif // LL_LLXMLPARSER_H | 138 | #endif // LL_LLXMLPARSER_H |
diff --git a/linden/indra/llxml/llxmltree.cpp b/linden/indra/llxml/llxmltree.cpp index 4ac05f9..0c24d9f 100644 --- a/linden/indra/llxml/llxmltree.cpp +++ b/linden/indra/llxml/llxmltree.cpp | |||
@@ -90,11 +90,11 @@ void LLXmlTree::dump() | |||
90 | } | 90 | } |
91 | } | 91 | } |
92 | 92 | ||
93 | void LLXmlTree::dumpNode( LLXmlTreeNode* node, const LLString& prefix ) | 93 | void LLXmlTree::dumpNode( LLXmlTreeNode* node, const std::string& prefix ) |
94 | { | 94 | { |
95 | node->dump( prefix ); | 95 | node->dump( prefix ); |
96 | 96 | ||
97 | LLString new_prefix = prefix + " "; | 97 | std::string new_prefix = prefix + " "; |
98 | for( LLXmlTreeNode* child = node->getFirstChild(); child; child = node->getNextChild() ) | 98 | for( LLXmlTreeNode* child = node->getFirstChild(); child; child = node->getNextChild() ) |
99 | { | 99 | { |
100 | dumpNode( child, new_prefix ); | 100 | dumpNode( child, new_prefix ); |
@@ -121,7 +121,7 @@ LLXmlTreeNode::~LLXmlTreeNode() | |||
121 | delete *child_iter; | 121 | delete *child_iter; |
122 | } | 122 | } |
123 | 123 | ||
124 | void LLXmlTreeNode::dump( const LLString& prefix ) | 124 | void LLXmlTreeNode::dump( const std::string& prefix ) |
125 | { | 125 | { |
126 | llinfos << prefix << mName ; | 126 | llinfos << prefix << mName ; |
127 | if( !mContents.empty() ) | 127 | if( !mContents.empty() ) |
@@ -132,7 +132,7 @@ void LLXmlTreeNode::dump( const LLString& prefix ) | |||
132 | for (iter=mAttributes.begin(); iter != mAttributes.end(); iter++) | 132 | for (iter=mAttributes.begin(); iter != mAttributes.end(); iter++) |
133 | { | 133 | { |
134 | LLStdStringHandle key = iter->first; | 134 | LLStdStringHandle key = iter->first; |
135 | const LLString* value = iter->second; | 135 | const std::string* value = iter->second; |
136 | llcont << prefix << " " << key << "=" << (value->empty() ? "NULL" : *value); | 136 | llcont << prefix << " " << key << "=" << (value->empty() ? "NULL" : *value); |
137 | } | 137 | } |
138 | llcont << llendl; | 138 | llcont << llendl; |
@@ -148,7 +148,7 @@ BOOL LLXmlTreeNode::hasAttribute(const std::string& name) | |||
148 | void LLXmlTreeNode::addAttribute(const std::string& name, const std::string& value) | 148 | void LLXmlTreeNode::addAttribute(const std::string& name, const std::string& value) |
149 | { | 149 | { |
150 | LLStdStringHandle canonical_name = LLXmlTree::sAttributeKeys.addString( name ); | 150 | LLStdStringHandle canonical_name = LLXmlTree::sAttributeKeys.addString( name ); |
151 | const LLString *newstr = new LLString(value); | 151 | const std::string *newstr = new std::string(value); |
152 | mAttributes[canonical_name] = newstr; // insert + copy | 152 | mAttributes[canonical_name] = newstr; // insert + copy |
153 | } | 153 | } |
154 | 154 | ||
@@ -204,103 +204,103 @@ void LLXmlTreeNode::addChild(LLXmlTreeNode* child) | |||
204 | 204 | ||
205 | BOOL LLXmlTreeNode::getFastAttributeBOOL(LLStdStringHandle canonical_name, BOOL& value) | 205 | BOOL LLXmlTreeNode::getFastAttributeBOOL(LLStdStringHandle canonical_name, BOOL& value) |
206 | { | 206 | { |
207 | const LLString *s = getAttribute( canonical_name ); | 207 | const std::string *s = getAttribute( canonical_name ); |
208 | return s && LLString::convertToBOOL( *s, value ); | 208 | return s && LLStringUtil::convertToBOOL( *s, value ); |
209 | } | 209 | } |
210 | 210 | ||
211 | BOOL LLXmlTreeNode::getFastAttributeU8(LLStdStringHandle canonical_name, U8& value) | 211 | BOOL LLXmlTreeNode::getFastAttributeU8(LLStdStringHandle canonical_name, U8& value) |
212 | { | 212 | { |
213 | const LLString *s = getAttribute( canonical_name ); | 213 | const std::string *s = getAttribute( canonical_name ); |
214 | return s && LLString::convertToU8( *s, value ); | 214 | return s && LLStringUtil::convertToU8( *s, value ); |
215 | } | 215 | } |
216 | 216 | ||
217 | BOOL LLXmlTreeNode::getFastAttributeS8(LLStdStringHandle canonical_name, S8& value) | 217 | BOOL LLXmlTreeNode::getFastAttributeS8(LLStdStringHandle canonical_name, S8& value) |
218 | { | 218 | { |
219 | const LLString *s = getAttribute( canonical_name ); | 219 | const std::string *s = getAttribute( canonical_name ); |
220 | return s && LLString::convertToS8( *s, value ); | 220 | return s && LLStringUtil::convertToS8( *s, value ); |
221 | } | 221 | } |
222 | 222 | ||
223 | BOOL LLXmlTreeNode::getFastAttributeS16(LLStdStringHandle canonical_name, S16& value) | 223 | BOOL LLXmlTreeNode::getFastAttributeS16(LLStdStringHandle canonical_name, S16& value) |
224 | { | 224 | { |
225 | const LLString *s = getAttribute( canonical_name ); | 225 | const std::string *s = getAttribute( canonical_name ); |
226 | return s && LLString::convertToS16( *s, value ); | 226 | return s && LLStringUtil::convertToS16( *s, value ); |
227 | } | 227 | } |
228 | 228 | ||
229 | BOOL LLXmlTreeNode::getFastAttributeU16(LLStdStringHandle canonical_name, U16& value) | 229 | BOOL LLXmlTreeNode::getFastAttributeU16(LLStdStringHandle canonical_name, U16& value) |
230 | { | 230 | { |
231 | const LLString *s = getAttribute( canonical_name ); | 231 | const std::string *s = getAttribute( canonical_name ); |
232 | return s && LLString::convertToU16( *s, value ); | 232 | return s && LLStringUtil::convertToU16( *s, value ); |
233 | } | 233 | } |
234 | 234 | ||
235 | BOOL LLXmlTreeNode::getFastAttributeU32(LLStdStringHandle canonical_name, U32& value) | 235 | BOOL LLXmlTreeNode::getFastAttributeU32(LLStdStringHandle canonical_name, U32& value) |
236 | { | 236 | { |
237 | const LLString *s = getAttribute( canonical_name ); | 237 | const std::string *s = getAttribute( canonical_name ); |
238 | return s && LLString::convertToU32( *s, value ); | 238 | return s && LLStringUtil::convertToU32( *s, value ); |
239 | } | 239 | } |
240 | 240 | ||
241 | BOOL LLXmlTreeNode::getFastAttributeS32(LLStdStringHandle canonical_name, S32& value) | 241 | BOOL LLXmlTreeNode::getFastAttributeS32(LLStdStringHandle canonical_name, S32& value) |
242 | { | 242 | { |
243 | const LLString *s = getAttribute( canonical_name ); | 243 | const std::string *s = getAttribute( canonical_name ); |
244 | return s && LLString::convertToS32( *s, value ); | 244 | return s && LLStringUtil::convertToS32( *s, value ); |
245 | } | 245 | } |
246 | 246 | ||
247 | BOOL LLXmlTreeNode::getFastAttributeF32(LLStdStringHandle canonical_name, F32& value) | 247 | BOOL LLXmlTreeNode::getFastAttributeF32(LLStdStringHandle canonical_name, F32& value) |
248 | { | 248 | { |
249 | const LLString *s = getAttribute( canonical_name ); | 249 | const std::string *s = getAttribute( canonical_name ); |
250 | return s && LLString::convertToF32( *s, value ); | 250 | return s && LLStringUtil::convertToF32( *s, value ); |
251 | } | 251 | } |
252 | 252 | ||
253 | BOOL LLXmlTreeNode::getFastAttributeF64(LLStdStringHandle canonical_name, F64& value) | 253 | BOOL LLXmlTreeNode::getFastAttributeF64(LLStdStringHandle canonical_name, F64& value) |
254 | { | 254 | { |
255 | const LLString *s = getAttribute( canonical_name ); | 255 | const std::string *s = getAttribute( canonical_name ); |
256 | return s && LLString::convertToF64( *s, value ); | 256 | return s && LLStringUtil::convertToF64( *s, value ); |
257 | } | 257 | } |
258 | 258 | ||
259 | BOOL LLXmlTreeNode::getFastAttributeColor(LLStdStringHandle canonical_name, LLColor4& value) | 259 | BOOL LLXmlTreeNode::getFastAttributeColor(LLStdStringHandle canonical_name, LLColor4& value) |
260 | { | 260 | { |
261 | const LLString *s = getAttribute( canonical_name ); | 261 | const std::string *s = getAttribute( canonical_name ); |
262 | return s ? LLColor4::parseColor(s->c_str(), &value) : FALSE; | 262 | return s ? LLColor4::parseColor(*s, &value) : FALSE; |
263 | } | 263 | } |
264 | 264 | ||
265 | BOOL LLXmlTreeNode::getFastAttributeColor4(LLStdStringHandle canonical_name, LLColor4& value) | 265 | BOOL LLXmlTreeNode::getFastAttributeColor4(LLStdStringHandle canonical_name, LLColor4& value) |
266 | { | 266 | { |
267 | const LLString *s = getAttribute( canonical_name ); | 267 | const std::string *s = getAttribute( canonical_name ); |
268 | return s ? LLColor4::parseColor4(s->c_str(), &value) : FALSE; | 268 | return s ? LLColor4::parseColor4(*s, &value) : FALSE; |
269 | } | 269 | } |
270 | 270 | ||
271 | BOOL LLXmlTreeNode::getFastAttributeColor4U(LLStdStringHandle canonical_name, LLColor4U& value) | 271 | BOOL LLXmlTreeNode::getFastAttributeColor4U(LLStdStringHandle canonical_name, LLColor4U& value) |
272 | { | 272 | { |
273 | const LLString *s = getAttribute( canonical_name ); | 273 | const std::string *s = getAttribute( canonical_name ); |
274 | return s ? LLColor4U::parseColor4U(s->c_str(), &value ) : FALSE; | 274 | return s ? LLColor4U::parseColor4U(*s, &value ) : FALSE; |
275 | } | 275 | } |
276 | 276 | ||
277 | BOOL LLXmlTreeNode::getFastAttributeVector3(LLStdStringHandle canonical_name, LLVector3& value) | 277 | BOOL LLXmlTreeNode::getFastAttributeVector3(LLStdStringHandle canonical_name, LLVector3& value) |
278 | { | 278 | { |
279 | const LLString *s = getAttribute( canonical_name ); | 279 | const std::string *s = getAttribute( canonical_name ); |
280 | return s ? LLVector3::parseVector3(s->c_str(), &value ) : FALSE; | 280 | return s ? LLVector3::parseVector3(*s, &value ) : FALSE; |
281 | } | 281 | } |
282 | 282 | ||
283 | BOOL LLXmlTreeNode::getFastAttributeVector3d(LLStdStringHandle canonical_name, LLVector3d& value) | 283 | BOOL LLXmlTreeNode::getFastAttributeVector3d(LLStdStringHandle canonical_name, LLVector3d& value) |
284 | { | 284 | { |
285 | const LLString *s = getAttribute( canonical_name ); | 285 | const std::string *s = getAttribute( canonical_name ); |
286 | return s ? LLVector3d::parseVector3d(s->c_str(), &value ) : FALSE; | 286 | return s ? LLVector3d::parseVector3d(*s, &value ) : FALSE; |
287 | } | 287 | } |
288 | 288 | ||
289 | BOOL LLXmlTreeNode::getFastAttributeQuat(LLStdStringHandle canonical_name, LLQuaternion& value) | 289 | BOOL LLXmlTreeNode::getFastAttributeQuat(LLStdStringHandle canonical_name, LLQuaternion& value) |
290 | { | 290 | { |
291 | const LLString *s = getAttribute( canonical_name ); | 291 | const std::string *s = getAttribute( canonical_name ); |
292 | return s ? LLQuaternion::parseQuat(s->c_str(), &value ) : FALSE; | 292 | return s ? LLQuaternion::parseQuat(*s, &value ) : FALSE; |
293 | } | 293 | } |
294 | 294 | ||
295 | BOOL LLXmlTreeNode::getFastAttributeUUID(LLStdStringHandle canonical_name, LLUUID& value) | 295 | BOOL LLXmlTreeNode::getFastAttributeUUID(LLStdStringHandle canonical_name, LLUUID& value) |
296 | { | 296 | { |
297 | const LLString *s = getAttribute( canonical_name ); | 297 | const std::string *s = getAttribute( canonical_name ); |
298 | return s ? LLUUID::parseUUID(s->c_str(), &value ) : FALSE; | 298 | return s ? LLUUID::parseUUID(*s, &value ) : FALSE; |
299 | } | 299 | } |
300 | 300 | ||
301 | BOOL LLXmlTreeNode::getFastAttributeString(LLStdStringHandle canonical_name, LLString& value) | 301 | BOOL LLXmlTreeNode::getFastAttributeString(LLStdStringHandle canonical_name, std::string& value) |
302 | { | 302 | { |
303 | const LLString *s = getAttribute( canonical_name ); | 303 | const std::string *s = getAttribute( canonical_name ); |
304 | if( !s ) | 304 | if( !s ) |
305 | { | 305 | { |
306 | return FALSE; | 306 | return FALSE; |
@@ -409,7 +409,7 @@ BOOL LLXmlTreeNode::getAttributeUUID(const std::string& name, LLUUID& value) | |||
409 | return getFastAttributeUUID(canonical_name, value); | 409 | return getFastAttributeUUID(canonical_name, value); |
410 | } | 410 | } |
411 | 411 | ||
412 | BOOL LLXmlTreeNode::getAttributeString(const std::string& name, LLString& value) | 412 | BOOL LLXmlTreeNode::getAttributeString(const std::string& name, std::string& value) |
413 | { | 413 | { |
414 | LLStdStringHandle canonical_name = LLXmlTree::sAttributeKeys.addString( name ); | 414 | LLStdStringHandle canonical_name = LLXmlTree::sAttributeKeys.addString( name ); |
415 | return getFastAttributeString(canonical_name, value); | 415 | return getFastAttributeString(canonical_name, value); |
@@ -437,7 +437,7 @@ The quick brown fox | |||
437 | 437 | ||
438 | */ | 438 | */ |
439 | 439 | ||
440 | LLString LLXmlTreeNode::getTextContents() | 440 | std::string LLXmlTreeNode::getTextContents() |
441 | { | 441 | { |
442 | std::string msg; | 442 | std::string msg; |
443 | LLXmlTreeNode* p = getChildByName("p"); | 443 | LLXmlTreeNode* p = getChildByName("p"); |
@@ -541,7 +541,7 @@ BOOL LLXmlTreeParser::parseFile(const std::string &path, LLXmlTreeNode** root, B | |||
541 | 541 | ||
542 | const std::string& LLXmlTreeParser::tabs() | 542 | const std::string& LLXmlTreeParser::tabs() |
543 | { | 543 | { |
544 | static LLString s; | 544 | static std::string s; |
545 | s = ""; | 545 | s = ""; |
546 | S32 num_tabs = getDepth() - 1; | 546 | S32 num_tabs = getDepth() - 1; |
547 | for( S32 i = 0; i < num_tabs; i++) | 547 | for( S32 i = 0; i < num_tabs; i++) |
@@ -602,8 +602,8 @@ void LLXmlTreeParser::endElement(const char* name) | |||
602 | 602 | ||
603 | if( !mCurrent->mContents.empty() ) | 603 | if( !mCurrent->mContents.empty() ) |
604 | { | 604 | { |
605 | LLString::trim(mCurrent->mContents); | 605 | LLStringUtil::trim(mCurrent->mContents); |
606 | LLString::removeCRLF(mCurrent->mContents); | 606 | LLStringUtil::removeCRLF(mCurrent->mContents); |
607 | } | 607 | } |
608 | 608 | ||
609 | mCurrent = mCurrent->getParent(); | 609 | mCurrent = mCurrent->getParent(); |
@@ -611,7 +611,8 @@ void LLXmlTreeParser::endElement(const char* name) | |||
611 | 611 | ||
612 | void LLXmlTreeParser::characterData(const char *s, int len) | 612 | void LLXmlTreeParser::characterData(const char *s, int len) |
613 | { | 613 | { |
614 | LLString str(s, len); | 614 | std::string str; |
615 | if (s) str = std::string(s, len); | ||
615 | if( mDump ) | 616 | if( mDump ) |
616 | { | 617 | { |
617 | llinfos << tabs() << "CharacterData " << str << llendl; | 618 | llinfos << tabs() << "CharacterData " << str << llendl; |
@@ -659,7 +660,8 @@ void LLXmlTreeParser::defaultData(const char *s, int len) | |||
659 | { | 660 | { |
660 | if( mDump ) | 661 | if( mDump ) |
661 | { | 662 | { |
662 | LLString str(s, len); | 663 | std::string str; |
664 | if (s) str = std::string(s, len); | ||
663 | llinfos << tabs() << "defaultData " << str << llendl; | 665 | llinfos << tabs() << "defaultData " << str << llendl; |
664 | } | 666 | } |
665 | } | 667 | } |
diff --git a/linden/indra/llxml/llxmltree.h b/linden/indra/llxml/llxmltree.h index 87fe4f5..5d475d0 100644 --- a/linden/indra/llxml/llxmltree.h +++ b/linden/indra/llxml/llxmltree.h | |||
@@ -65,7 +65,7 @@ public: | |||
65 | LLXmlTreeNode* getRoot() { return mRoot; } | 65 | LLXmlTreeNode* getRoot() { return mRoot; } |
66 | 66 | ||
67 | void dump(); | 67 | void dump(); |
68 | void dumpNode( LLXmlTreeNode* node, const LLString &prefix ); | 68 | void dumpNode( LLXmlTreeNode* node, const std::string& prefix ); |
69 | 69 | ||
70 | static LLStdStringHandle addAttributeString( const std::string& name) | 70 | static LLStdStringHandle addAttributeString( const std::string& name) |
71 | { | 71 | { |
@@ -126,7 +126,7 @@ public: | |||
126 | BOOL getFastAttributeVector3d( LLStdStringHandle cannonical_name, LLVector3d& value ); | 126 | BOOL getFastAttributeVector3d( LLStdStringHandle cannonical_name, LLVector3d& value ); |
127 | BOOL getFastAttributeQuat( LLStdStringHandle cannonical_name, LLQuaternion& value ); | 127 | BOOL getFastAttributeQuat( LLStdStringHandle cannonical_name, LLQuaternion& value ); |
128 | BOOL getFastAttributeUUID( LLStdStringHandle cannonical_name, LLUUID& value ); | 128 | BOOL getFastAttributeUUID( LLStdStringHandle cannonical_name, LLUUID& value ); |
129 | BOOL getFastAttributeString( LLStdStringHandle cannonical_name, LLString& value ); | 129 | BOOL getFastAttributeString( LLStdStringHandle cannonical_name, std::string& value ); |
130 | 130 | ||
131 | // Normal versions find 'name' in LLXmlTree::sAttributeKeys then call fast versions | 131 | // Normal versions find 'name' in LLXmlTree::sAttributeKeys then call fast versions |
132 | virtual BOOL getAttributeBOOL( const std::string& name, BOOL& value ); | 132 | virtual BOOL getAttributeBOOL( const std::string& name, BOOL& value ); |
@@ -145,13 +145,13 @@ public: | |||
145 | virtual BOOL getAttributeVector3d( const std::string& name, LLVector3d& value ); | 145 | virtual BOOL getAttributeVector3d( const std::string& name, LLVector3d& value ); |
146 | virtual BOOL getAttributeQuat( const std::string& name, LLQuaternion& value ); | 146 | virtual BOOL getAttributeQuat( const std::string& name, LLQuaternion& value ); |
147 | virtual BOOL getAttributeUUID( const std::string& name, LLUUID& value ); | 147 | virtual BOOL getAttributeUUID( const std::string& name, LLUUID& value ); |
148 | virtual BOOL getAttributeString( const std::string& name, LLString& value ); | 148 | virtual BOOL getAttributeString( const std::string& name, std::string& value ); |
149 | 149 | ||
150 | const LLString& getContents() | 150 | const std::string& getContents() |
151 | { | 151 | { |
152 | return mContents; | 152 | return mContents; |
153 | } | 153 | } |
154 | LLString getTextContents(); | 154 | std::string getTextContents(); |
155 | 155 | ||
156 | LLXmlTreeNode* getParent() { return mParent; } | 156 | LLXmlTreeNode* getParent() { return mParent; } |
157 | LLXmlTreeNode* getFirstChild(); | 157 | LLXmlTreeNode* getFirstChild(); |
@@ -161,7 +161,7 @@ public: | |||
161 | LLXmlTreeNode* getNextNamedChild(); // returns next child with name, NULL if none | 161 | LLXmlTreeNode* getNextNamedChild(); // returns next child with name, NULL if none |
162 | 162 | ||
163 | protected: | 163 | protected: |
164 | const LLString* getAttribute( LLStdStringHandle name) | 164 | const std::string* getAttribute( LLStdStringHandle name) |
165 | { | 165 | { |
166 | attribute_map_t::iterator iter = mAttributes.find(name); | 166 | attribute_map_t::iterator iter = mAttributes.find(name); |
167 | return (iter == mAttributes.end()) ? 0 : iter->second; | 167 | return (iter == mAttributes.end()) ? 0 : iter->second; |
@@ -172,15 +172,15 @@ private: | |||
172 | void appendContents( const std::string& str ); | 172 | void appendContents( const std::string& str ); |
173 | void addChild( LLXmlTreeNode* child ); | 173 | void addChild( LLXmlTreeNode* child ); |
174 | 174 | ||
175 | void dump( const LLString& prefix ); | 175 | void dump( const std::string& prefix ); |
176 | 176 | ||
177 | protected: | 177 | protected: |
178 | typedef std::map<LLStdStringHandle, const LLString*> attribute_map_t; | 178 | typedef std::map<LLStdStringHandle, const std::string*> attribute_map_t; |
179 | attribute_map_t mAttributes; | 179 | attribute_map_t mAttributes; |
180 | 180 | ||
181 | private: | 181 | private: |
182 | LLString mName; | 182 | std::string mName; |
183 | LLString mContents; | 183 | std::string mContents; |
184 | 184 | ||
185 | typedef std::list<class LLXmlTreeNode *> child_list_t; | 185 | typedef std::list<class LLXmlTreeNode *> child_list_t; |
186 | child_list_t mChildList; | 186 | child_list_t mChildList; |