diff options
Diffstat (limited to '')
-rw-r--r-- | linden/indra/newview/llgesturemgr.cpp | 68 |
1 files changed, 54 insertions, 14 deletions
diff --git a/linden/indra/newview/llgesturemgr.cpp b/linden/indra/newview/llgesturemgr.cpp index c94e9e2..bf3c057 100644 --- a/linden/indra/newview/llgesturemgr.cpp +++ b/linden/indra/newview/llgesturemgr.cpp | |||
@@ -103,7 +103,7 @@ void LLGestureManager::activateGesture(const LLUUID& item_id) | |||
103 | mDeactivateSimilarNames.clear(); | 103 | mDeactivateSimilarNames.clear(); |
104 | 104 | ||
105 | const BOOL inform_server = TRUE; | 105 | const BOOL inform_server = TRUE; |
106 | const BOOL deactivate_similar = TRUE; | 106 | const BOOL deactivate_similar = FALSE; |
107 | activateGestureWithAsset(item_id, asset_id, inform_server, deactivate_similar); | 107 | activateGestureWithAsset(item_id, asset_id, inform_server, deactivate_similar); |
108 | } | 108 | } |
109 | 109 | ||
@@ -206,6 +206,11 @@ void LLGestureManager::activateGestureWithAsset(const LLUUID& item_id, | |||
206 | BOOL inform_server, | 206 | BOOL inform_server, |
207 | BOOL deactivate_similar) | 207 | BOOL deactivate_similar) |
208 | { | 208 | { |
209 | if( !gAssetStorage ) | ||
210 | { | ||
211 | llwarns << "LLGestureManager::activateGestureWithAsset without valid gAssetStorage" << llendl; | ||
212 | return; | ||
213 | } | ||
209 | // If gesture is already active, nothing to do. | 214 | // If gesture is already active, nothing to do. |
210 | if (isGestureActive(item_id)) | 215 | if (isGestureActive(item_id)) |
211 | { | 216 | { |
@@ -418,7 +423,7 @@ void LLGestureManager::replaceGesture(const LLUUID& item_id, LLMultiGesture* new | |||
418 | LLLoadInfo* info = new LLLoadInfo; | 423 | LLLoadInfo* info = new LLLoadInfo; |
419 | info->mItemID = item_id; | 424 | info->mItemID = item_id; |
420 | info->mInformServer = TRUE; | 425 | info->mInformServer = TRUE; |
421 | info->mDeactivateSimilar = TRUE; | 426 | info->mDeactivateSimilar = FALSE; |
422 | 427 | ||
423 | const BOOL high_priority = TRUE; | 428 | const BOOL high_priority = TRUE; |
424 | gAssetStorage->getAssetData(asset_id, | 429 | gAssetStorage->getAssetData(asset_id, |
@@ -489,6 +494,8 @@ BOOL LLGestureManager::triggerAndReviseString(const std::string &utf8str, std::s | |||
489 | LLString cur_token_lower = cur_token; | 494 | LLString cur_token_lower = cur_token; |
490 | LLString::toLower(cur_token_lower); | 495 | LLString::toLower(cur_token_lower); |
491 | 496 | ||
497 | // collect gestures that match | ||
498 | std::vector <LLMultiGesture *> matching; | ||
492 | item_map_t::iterator it; | 499 | item_map_t::iterator it; |
493 | for (it = mActive.begin(); it != mActive.end(); ++it) | 500 | for (it = mActive.begin(); it != mActive.end(); ++it) |
494 | { | 501 | { |
@@ -496,16 +503,32 @@ BOOL LLGestureManager::triggerAndReviseString(const std::string &utf8str, std::s | |||
496 | 503 | ||
497 | // Gesture asset data might not have arrived yet | 504 | // Gesture asset data might not have arrived yet |
498 | if (!gesture) continue; | 505 | if (!gesture) continue; |
499 | 506 | ||
500 | if (!stricmp(gesture->mTrigger.c_str(), cur_token_lower.c_str())) | 507 | if (!stricmp(gesture->mTrigger.c_str(), cur_token_lower.c_str())) |
501 | { | 508 | { |
509 | matching.push_back(gesture); | ||
510 | } | ||
511 | |||
512 | gesture = NULL; | ||
513 | } | ||
514 | |||
515 | |||
516 | if (matching.size() > 0) | ||
517 | { | ||
518 | // choose one at random | ||
519 | { | ||
520 | S32 random = ll_rand(matching.size()); | ||
521 | |||
522 | gesture = matching[random]; | ||
523 | |||
502 | playGesture(gesture); | 524 | playGesture(gesture); |
503 | 525 | ||
504 | if (!gesture->mReplaceText.empty()) | 526 | if (!gesture->mReplaceText.empty()) |
505 | { | 527 | { |
506 | if( !first_token ) | 528 | if( !first_token ) |
507 | { | 529 | { |
508 | revised_string->append( " " ); | 530 | if (revised_string) |
531 | revised_string->append( " " ); | ||
509 | } | 532 | } |
510 | 533 | ||
511 | // Don't muck with the user's capitalization if we don't have to. | 534 | // Don't muck with the user's capitalization if we don't have to. |
@@ -514,30 +537,34 @@ BOOL LLGestureManager::triggerAndReviseString(const std::string &utf8str, std::s | |||
514 | LLString::toLower(output_lower); | 537 | LLString::toLower(output_lower); |
515 | if( cur_token_lower == output_lower ) | 538 | if( cur_token_lower == output_lower ) |
516 | { | 539 | { |
517 | revised_string->append( cur_token ); | 540 | if (revised_string) |
541 | revised_string->append( cur_token ); | ||
518 | } | 542 | } |
519 | else | 543 | else |
520 | { | 544 | { |
521 | revised_string->append( output ); | 545 | if (revised_string) |
546 | revised_string->append( output ); | ||
522 | } | 547 | } |
523 | } | 548 | } |
524 | found_gestures = TRUE; | 549 | found_gestures = TRUE; |
525 | break; | ||
526 | } | 550 | } |
527 | gesture = NULL; | ||
528 | } | 551 | } |
529 | } | 552 | } |
530 | 553 | ||
531 | if( !gesture ) | 554 | if(!gesture) |
532 | { | 555 | { |
556 | // This token doesn't match a gesture. Pass it through to the output. | ||
533 | if( !first_token ) | 557 | if( !first_token ) |
534 | { | 558 | { |
535 | revised_string->append( " " ); | 559 | if (revised_string) |
560 | revised_string->append( " " ); | ||
536 | } | 561 | } |
537 | revised_string->append( cur_token ); | 562 | if (revised_string) |
563 | revised_string->append( cur_token ); | ||
538 | } | 564 | } |
539 | 565 | ||
540 | first_token = FALSE; | 566 | first_token = FALSE; |
567 | gesture = NULL; | ||
541 | } | 568 | } |
542 | return found_gestures; | 569 | return found_gestures; |
543 | } | 570 | } |
@@ -545,7 +572,10 @@ BOOL LLGestureManager::triggerAndReviseString(const std::string &utf8str, std::s | |||
545 | 572 | ||
546 | BOOL LLGestureManager::triggerGesture(KEY key, MASK mask) | 573 | BOOL LLGestureManager::triggerGesture(KEY key, MASK mask) |
547 | { | 574 | { |
575 | std::vector <LLMultiGesture *> matching; | ||
548 | item_map_t::iterator it; | 576 | item_map_t::iterator it; |
577 | |||
578 | // collect matching gestures | ||
549 | for (it = mActive.begin(); it != mActive.end(); ++it) | 579 | for (it = mActive.begin(); it != mActive.end(); ++it) |
550 | { | 580 | { |
551 | LLMultiGesture* gesture = (*it).second; | 581 | LLMultiGesture* gesture = (*it).second; |
@@ -556,10 +586,20 @@ BOOL LLGestureManager::triggerGesture(KEY key, MASK mask) | |||
556 | if (gesture->mKey == key | 586 | if (gesture->mKey == key |
557 | && gesture->mMask == mask) | 587 | && gesture->mMask == mask) |
558 | { | 588 | { |
559 | playGesture(gesture); | 589 | matching.push_back(gesture); |
560 | return TRUE; | ||
561 | } | 590 | } |
562 | } | 591 | } |
592 | |||
593 | // choose one and play it | ||
594 | if (matching.size() > 0) | ||
595 | { | ||
596 | U32 random = ll_rand(matching.size()); | ||
597 | |||
598 | LLMultiGesture* gesture = matching[random]; | ||
599 | |||
600 | playGesture(gesture); | ||
601 | return TRUE; | ||
602 | } | ||
563 | return FALSE; | 603 | return FALSE; |
564 | } | 604 | } |
565 | 605 | ||