aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/llwearable.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/llwearable.cpp')
-rw-r--r--linden/indra/newview/llwearable.cpp125
1 files changed, 49 insertions, 76 deletions
diff --git a/linden/indra/newview/llwearable.cpp b/linden/indra/newview/llwearable.cpp
index 0cadd5c..9365eeb 100644
--- a/linden/indra/newview/llwearable.cpp
+++ b/linden/indra/newview/llwearable.cpp
@@ -132,8 +132,6 @@ LLWearable::LLWearable(const LLAssetID& asset_id) :
132 132
133LLWearable::~LLWearable() 133LLWearable::~LLWearable()
134{ 134{
135 mVisualParamMap.deleteAllData();
136 mTEMap.deleteAllData();
137} 135}
138 136
139 137
@@ -227,35 +225,37 @@ BOOL LLWearable::exportFile( FILE* file )
227 } 225 }
228 226
229 // parameters 227 // parameters
230 S32 num_parameters = mVisualParamMap.getLength(); 228 S32 num_parameters = mVisualParamMap.size();
231 if( fprintf( file, "parameters %d\n", num_parameters ) < 0 ) 229 if( fprintf( file, "parameters %d\n", num_parameters ) < 0 )
232 { 230 {
233 return FALSE; 231 return FALSE;
234 } 232 }
235 233
236 char s[ MAX_STRING ]; /* Flawfinder: ignore */ 234 char s[ MAX_STRING ]; /* Flawfinder: ignore */
237 for( F32* param_weightp = mVisualParamMap.getFirstData(); param_weightp; param_weightp = mVisualParamMap.getNextData() ) 235 for (param_map_t::iterator iter = mVisualParamMap.begin();
236 iter != mVisualParamMap.end(); ++iter)
238 { 237 {
239 S32 param_id = mVisualParamMap.getCurrentKeyWithoutIncrement(); 238 S32 param_id = iter->first;
240 if( fprintf( file, "%d %s\n", param_id, terse_F32_to_string( *param_weightp, s ) ) < 0 ) 239 F32 param_weight = iter->second;
240 if( fprintf( file, "%d %s\n", param_id, terse_F32_to_string( param_weight, s ) ) < 0 )
241 { 241 {
242 return FALSE; 242 return FALSE;
243 } 243 }
244 } 244 }
245 245
246 // texture entries 246 // texture entries
247 S32 num_textures = mTEMap.getLength(); 247 S32 num_textures = mTEMap.size();
248 if( fprintf( file, "textures %d\n", num_textures ) < 0 ) 248 if( fprintf( file, "textures %d\n", num_textures ) < 0 )
249 { 249 {
250 return FALSE; 250 return FALSE;
251 } 251 }
252 252
253 for( LLUUID* image_id = mTEMap.getFirstData(); image_id; image_id = mTEMap.getNextData() ) 253 for (te_map_t::iterator iter = mTEMap.begin();
254 iter != mTEMap.end(); ++iter)
254 { 255 {
255 S32 te = mTEMap.getCurrentKeyWithoutIncrement(); 256 S32 te = iter->first;
256 char image_id_string[UUID_STR_LENGTH]; /* Flawfinder: ignore */ 257 LLUUID& image_id = iter->second;
257 image_id->toString( image_id_string ); 258 if( fprintf( file, "%d %s\n", te, image_id.asString().c_str()) < 0 )
258 if( fprintf( file, "%d %s\n", te, image_id_string) < 0 )
259 { 259 {
260 return FALSE; 260 return FALSE;
261 } 261 }
@@ -418,7 +418,7 @@ BOOL LLWearable::importFile( FILE* file )
418 llwarns << "Bad Wearable asset: bad parameter, #" << i << llendl; 418 llwarns << "Bad Wearable asset: bad parameter, #" << i << llendl;
419 return FALSE; 419 return FALSE;
420 } 420 }
421 mVisualParamMap.addData( param_id, new F32(param_weight) ); 421 mVisualParamMap[param_id] = param_weight;
422 } 422 }
423 423
424 // textures header 424 // textures header
@@ -450,7 +450,7 @@ BOOL LLWearable::importFile( FILE* file )
450 return FALSE; 450 return FALSE;
451 } 451 }
452 452
453 mTEMap.addData( te, new LLUUID( text_buffer ) ); 453 mTEMap[te] = LLUUID(text_buffer );
454 } 454 }
455 455
456 return TRUE; 456 return TRUE;
@@ -488,13 +488,13 @@ BOOL LLWearable::isOldVersion()
488 if( (param->getWearableType() == mType) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) ) 488 if( (param->getWearableType() == mType) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) )
489 { 489 {
490 param_count++; 490 param_count++;
491 if( !mVisualParamMap.checkKey( param->getID() ) ) 491 if( !is_in_map(mVisualParamMap, param->getID() ) )
492 { 492 {
493 return TRUE; 493 return TRUE;
494 } 494 }
495 } 495 }
496 } 496 }
497 if( param_count != mVisualParamMap.getLength() ) 497 if( param_count != mVisualParamMap.size() )
498 { 498 {
499 return TRUE; 499 return TRUE;
500 } 500 }
@@ -506,13 +506,13 @@ BOOL LLWearable::isOldVersion()
506 if( LLVOAvatar::getTEWearableType( te ) == mType ) 506 if( LLVOAvatar::getTEWearableType( te ) == mType )
507 { 507 {
508 te_count++; 508 te_count++;
509 if( !mTEMap.checkKey( te ) ) 509 if( !is_in_map(mTEMap, te ) )
510 { 510 {
511 return TRUE; 511 return TRUE;
512 } 512 }
513 } 513 }
514 } 514 }
515 if( te_count != mTEMap.getLength() ) 515 if( te_count != mTEMap.size() )
516 { 516 {
517 return TRUE; 517 return TRUE;
518 } 518 }
@@ -543,16 +543,8 @@ BOOL LLWearable::isDirty()
543 { 543 {
544 if( (param->getWearableType() == mType) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) ) 544 if( (param->getWearableType() == mType) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) )
545 { 545 {
546 F32* weightp = mVisualParamMap.getIfThere( param->getID() ); 546 F32 weight = get_if_there(mVisualParamMap, param->getID(), param->getDefaultWeight());
547 F32 weight; 547 weight = llclamp( weight, param->getMinWeight(), param->getMaxWeight() );
548 if( weightp )
549 {
550 weight = llclamp( *weightp, param->getMinWeight(), param->getMaxWeight() );
551 }
552 else
553 {
554 weight = param->getDefaultWeight();
555 }
556 548
557 U8 a = F32_to_U8( param->getWeight(), param->getMinWeight(), param->getMaxWeight() ); 549 U8 a = F32_to_U8( param->getWeight(), param->getMinWeight(), param->getMaxWeight() );
558 U8 b = F32_to_U8( weight, param->getMinWeight(), param->getMaxWeight() ); 550 U8 b = F32_to_U8( weight, param->getMinWeight(), param->getMaxWeight() );
@@ -573,8 +565,7 @@ BOOL LLWearable::isDirty()
573 llassert( 0 ); 565 llassert( 0 );
574 continue; 566 continue;
575 } 567 }
576 LLUUID* mapped_image_id = mTEMap.getIfThere( te ); 568 const LLUUID& image_id = get_if_there(mTEMap, te, LLVOAvatar::getDefaultTEImageID( te ) );
577 const LLUUID& image_id = mapped_image_id ? *mapped_image_id : LLVOAvatar::getDefaultTEImageID( te );
578 if( avatar_image->getID() != image_id ) 569 if( avatar_image->getID() != image_id )
579 { 570 {
580 return TRUE; 571 return TRUE;
@@ -603,24 +594,24 @@ void LLWearable::setParamsToDefaults()
603 return; 594 return;
604 } 595 }
605 596
606 mVisualParamMap.deleteAllData(); 597 mVisualParamMap.clear();
607 for( LLVisualParam* param = avatar->getFirstVisualParam(); param; param = avatar->getNextVisualParam() ) 598 for( LLVisualParam* param = avatar->getFirstVisualParam(); param; param = avatar->getNextVisualParam() )
608 { 599 {
609 if( (((LLViewerVisualParam*)param)->getWearableType() == mType ) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) ) 600 if( (((LLViewerVisualParam*)param)->getWearableType() == mType ) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) )
610 { 601 {
611 mVisualParamMap.addData( param->getID(), new F32( param->getDefaultWeight() ) ); 602 mVisualParamMap[param->getID()] = param->getDefaultWeight();
612 } 603 }
613 } 604 }
614} 605}
615 606
616void LLWearable::setTexturesToDefaults() 607void LLWearable::setTexturesToDefaults()
617{ 608{
618 mTEMap.deleteAllData(); 609 mTEMap.clear();
619 for( S32 te = 0; te < LLVOAvatar::TEX_NUM_ENTRIES; te++ ) 610 for( S32 te = 0; te < LLVOAvatar::TEX_NUM_ENTRIES; te++ )
620 { 611 {
621 if( LLVOAvatar::getTEWearableType( te ) == mType ) 612 if( LLVOAvatar::getTEWearableType( te ) == mType )
622 { 613 {
623 mTEMap.addData( te, new LLUUID( LLVOAvatar::getDefaultTEImageID( te ) ) ); 614 mTEMap[te] = LLVOAvatar::getDefaultTEImageID( te );
624 } 615 }
625 } 616 }
626} 617}
@@ -643,30 +634,15 @@ void LLWearable::writeToAvatar( BOOL set_by_user )
643 if( (((LLViewerVisualParam*)param)->getWearableType() == mType) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) ) 634 if( (((LLViewerVisualParam*)param)->getWearableType() == mType) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) )
644 { 635 {
645 S32 param_id = param->getID(); 636 S32 param_id = param->getID();
646 F32* weight = mVisualParamMap.getIfThere( param_id ); 637 F32 weight = get_if_there(mVisualParamMap, param_id, param->getDefaultWeight());
647 if( weight ) 638 // only animate with user-originated changes
639 if (set_by_user)
648 { 640 {
649 // only animate with user-originated changes 641 param->setAnimationTarget(weight, set_by_user);
650 if (set_by_user)
651 {
652 param->setAnimationTarget(*weight, set_by_user);
653 }
654 else
655 {
656 avatar->setVisualParamWeight( param_id, *weight, set_by_user );
657 }
658 } 642 }
659 else 643 else
660 { 644 {
661 // only animate with user-originated changes 645 avatar->setVisualParamWeight( param_id, weight, set_by_user );
662 if (set_by_user)
663 {
664 param->setAnimationTarget(param->getDefaultWeight(), set_by_user);
665 }
666 else
667 {
668 avatar->setVisualParamWeight( param_id, param->getDefaultWeight(), set_by_user );
669 }
670 } 646 }
671 } 647 }
672 } 648 }
@@ -682,8 +658,7 @@ void LLWearable::writeToAvatar( BOOL set_by_user )
682 { 658 {
683 if( LLVOAvatar::getTEWearableType( te ) == mType ) 659 if( LLVOAvatar::getTEWearableType( te ) == mType )
684 { 660 {
685 LLUUID* mapped_image_id = mTEMap.getIfThere( te ); 661 const LLUUID& image_id = get_if_there(mTEMap, te, LLVOAvatar::getDefaultTEImageID( te ) );
686 const LLUUID& image_id = mapped_image_id ? *mapped_image_id : LLVOAvatar::getDefaultTEImageID( te );
687 LLViewerImage* image = gImageList.getImage( image_id ); 662 LLViewerImage* image = gImageList.getImage( image_id );
688 avatar->setLocTexTE( te, image, set_by_user ); 663 avatar->setLocTexTE( te, image, set_by_user );
689 } 664 }
@@ -792,16 +767,16 @@ void LLWearable::readFromAvatar()
792 767
793 mDefinitionVersion = LLWearable::sCurrentDefinitionVersion; 768 mDefinitionVersion = LLWearable::sCurrentDefinitionVersion;
794 769
795 mVisualParamMap.deleteAllData(); 770 mVisualParamMap.clear();
796 for( LLVisualParam* param = avatar->getFirstVisualParam(); param; param = avatar->getNextVisualParam() ) 771 for( LLVisualParam* param = avatar->getFirstVisualParam(); param; param = avatar->getNextVisualParam() )
797 { 772 {
798 if( (((LLViewerVisualParam*)param)->getWearableType() == mType) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) ) 773 if( (((LLViewerVisualParam*)param)->getWearableType() == mType) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) )
799 { 774 {
800 mVisualParamMap.addData( param->getID(), new F32( param->getWeight() ) ); 775 mVisualParamMap[param->getID()] = param->getWeight();
801 } 776 }
802 } 777 }
803 778
804 mTEMap.deleteAllData(); 779 mTEMap.clear();
805 for( S32 te = 0; te < LLVOAvatar::TEX_NUM_ENTRIES; te++ ) 780 for( S32 te = 0; te < LLVOAvatar::TEX_NUM_ENTRIES; te++ )
806 { 781 {
807 if( LLVOAvatar::getTEWearableType( te ) == mType ) 782 if( LLVOAvatar::getTEWearableType( te ) == mType )
@@ -809,7 +784,7 @@ void LLWearable::readFromAvatar()
809 LLViewerImage* image = avatar->getTEImage( te ); 784 LLViewerImage* image = avatar->getTEImage( te );
810 if( image ) 785 if( image )
811 { 786 {
812 mTEMap.addData( te, new LLUUID( image->getID() ) ); 787 mTEMap[te] = image->getID();
813 } 788 }
814 } 789 }
815 } 790 }
@@ -847,9 +822,8 @@ void LLWearable::copyDataFrom( LLWearable* src )
847 if( (param->getWearableType() == mType) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) ) 822 if( (param->getWearableType() == mType) && (param->getGroup() == VISUAL_PARAM_GROUP_TWEAKABLE ) )
848 { 823 {
849 S32 id = param->getID(); 824 S32 id = param->getID();
850 F32* weightp = src->mVisualParamMap.getIfThere( id ); 825 F32 weight = get_if_there(src->mVisualParamMap, id, param->getDefaultWeight() );
851 F32 weight = weightp ? *weightp : param->getDefaultWeight(); 826 mVisualParamMap[id] = weight;
852 mVisualParamMap.addData( id, new F32( weight ) );
853 } 827 }
854 } 828 }
855 829
@@ -858,9 +832,8 @@ void LLWearable::copyDataFrom( LLWearable* src )
858 { 832 {
859 if( LLVOAvatar::getTEWearableType( te ) == mType ) 833 if( LLVOAvatar::getTEWearableType( te ) == mType )
860 { 834 {
861 LLUUID* mapped_image_id = src->mTEMap.getIfThere( te ); 835 const LLUUID& image_id = get_if_there(src->mTEMap, te, LLVOAvatar::getDefaultTEImageID( te ) );
862 const LLUUID& image_id = mapped_image_id ? *mapped_image_id : LLVOAvatar::getDefaultTEImageID( te ); 836 mTEMap[te] = image_id;
863 mTEMap.addData( te, new LLUUID( image_id ) );
864 } 837 }
865 } 838 }
866} 839}
@@ -985,21 +958,21 @@ void LLWearable::dump()
985 //mSaleInfo 958 //mSaleInfo
986 959
987 llinfos << " Params:" << llendl; 960 llinfos << " Params:" << llendl;
988 for( F32* param_weightp = mVisualParamMap.getFirstData(); 961 for (param_map_t::iterator iter = mVisualParamMap.begin();
989 param_weightp; 962 iter != mVisualParamMap.end(); ++iter)
990 param_weightp = mVisualParamMap.getNextData() )
991 { 963 {
992 S32 param_id = mVisualParamMap.getCurrentKeyWithoutIncrement(); 964 S32 param_id = iter->first;
993 llinfos << " " << param_id << " " << *param_weightp << llendl; 965 F32 param_weight = iter->second;
966 llinfos << " " << param_id << " " << param_weight << llendl;
994 } 967 }
995 968
996 llinfos << " Textures:" << llendl; 969 llinfos << " Textures:" << llendl;
997 for( LLUUID* image_id = mTEMap.getFirstData(); 970 for (te_map_t::iterator iter = mTEMap.begin();
998 image_id; 971 iter != mTEMap.end(); ++iter)
999 image_id = mTEMap.getNextData() )
1000 { 972 {
1001 S32 te = mTEMap.getCurrentKeyWithoutIncrement(); 973 S32 te = iter->first;
1002 llinfos << " " << te << " " << *image_id << llendl; 974 LLUUID& image_id = iter->second;
975 llinfos << " " << te << " " << image_id << llendl;
1003 } 976 }
1004} 977}
1005 978