aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/newview/lltoolcomp.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/newview/lltoolcomp.cpp')
-rw-r--r--linden/indra/newview/lltoolcomp.cpp57
1 files changed, 47 insertions, 10 deletions
diff --git a/linden/indra/newview/lltoolcomp.cpp b/linden/indra/newview/lltoolcomp.cpp
index 0ef710d..8898dcb 100644
--- a/linden/indra/newview/lltoolcomp.cpp
+++ b/linden/indra/newview/lltoolcomp.cpp
@@ -167,7 +167,7 @@ void LLToolCompInspect::pickCallback(S32 x, S32 y, MASK mask)
167 167
168 if( hit_obj ) 168 if( hit_obj )
169 { 169 {
170 if (gSelectMgr->getObjectCount()) 170 if (gSelectMgr->getSelection()->getObjectCount())
171 { 171 {
172 gEditMenuHandler = gSelectMgr; 172 gEditMenuHandler = gSelectMgr;
173 } 173 }
@@ -223,7 +223,7 @@ BOOL LLToolCompTranslate::handleHover(S32 x, S32 y, MASK mask)
223BOOL LLToolCompTranslate::handleMouseDown(S32 x, S32 y, MASK mask) 223BOOL LLToolCompTranslate::handleMouseDown(S32 x, S32 y, MASK mask)
224{ 224{
225 mMouseDown = TRUE; 225 mMouseDown = TRUE;
226 gViewerWindow->hitObjectOrLandGlobalAsync(x, y, mask, pickCallback); 226 gViewerWindow->hitObjectOrLandGlobalAsync(x, y, mask, pickCallback, TRUE);
227 return TRUE; 227 return TRUE;
228} 228}
229 229
@@ -241,7 +241,7 @@ void LLToolCompTranslate::pickCallback(S32 x, S32 y, MASK mask)
241 241
242 if( hit_obj || gToolTranslate->mManip->getHighlightedPart() != LLManip::LL_NO_PART ) 242 if( hit_obj || gToolTranslate->mManip->getHighlightedPart() != LLManip::LL_NO_PART )
243 { 243 {
244 if (gSelectMgr->getObjectCount()) 244 if (gToolTranslate->mManip->getSelection()->getObjectCount())
245 { 245 {
246 gEditMenuHandler = gSelectMgr; 246 gEditMenuHandler = gSelectMgr;
247 } 247 }
@@ -272,9 +272,22 @@ BOOL LLToolCompTranslate::handleMouseUp(S32 x, S32 y, MASK mask)
272 return LLToolComposite::handleMouseUp(x, y, mask); 272 return LLToolComposite::handleMouseUp(x, y, mask);
273} 273}
274 274
275LLTool* LLToolCompTranslate::getOverrideTool(MASK mask)
276{
277 if (mask == MASK_CONTROL)
278 {
279 return gToolRotate;
280 }
281 else if (mask == (MASK_CONTROL | MASK_SHIFT))
282 {
283 return gToolStretch;
284 }
285 return LLToolComposite::getOverrideTool(mask);
286}
287
275BOOL LLToolCompTranslate::handleDoubleClick(S32 x, S32 y, MASK mask) 288BOOL LLToolCompTranslate::handleDoubleClick(S32 x, S32 y, MASK mask)
276{ 289{
277 if (!gSelectMgr->isEmpty() && mManip->getHighlightedPart() == LLManip::LL_NO_PART) 290 if (mManip->getSelection()->isEmpty() && mManip->getHighlightedPart() == LLManip::LL_NO_PART)
278 { 291 {
279 // You should already have an object selected from the mousedown. 292 // You should already have an object selected from the mousedown.
280 // If so, show its properties 293 // If so, show its properties
@@ -350,7 +363,7 @@ void LLToolCompScale::pickCallback(S32 x, S32 y, MASK mask)
350 363
351 if( hit_obj || gToolStretch->mManip->getHighlightedPart() != LLManip::LL_NO_PART) 364 if( hit_obj || gToolStretch->mManip->getHighlightedPart() != LLManip::LL_NO_PART)
352 { 365 {
353 if (gSelectMgr->getObjectCount()) 366 if (gToolStretch->mManip->getSelection()->getObjectCount())
354 { 367 {
355 gEditMenuHandler = gSelectMgr; 368 gEditMenuHandler = gSelectMgr;
356 } 369 }
@@ -378,9 +391,20 @@ BOOL LLToolCompScale::handleMouseUp(S32 x, S32 y, MASK mask)
378 return LLToolComposite::handleMouseUp(x, y, mask); 391 return LLToolComposite::handleMouseUp(x, y, mask);
379} 392}
380 393
394LLTool* LLToolCompScale::getOverrideTool(MASK mask)
395{
396 if (mask == MASK_CONTROL)
397 {
398 return gToolRotate;
399 }
400
401 return LLToolComposite::getOverrideTool(mask);
402}
403
404
381BOOL LLToolCompScale::handleDoubleClick(S32 x, S32 y, MASK mask) 405BOOL LLToolCompScale::handleDoubleClick(S32 x, S32 y, MASK mask)
382{ 406{
383 if (!gSelectMgr->isEmpty() && mManip->getHighlightedPart() == LLManip::LL_NO_PART) 407 if (!mManip->getSelection()->isEmpty() && mManip->getHighlightedPart() == LLManip::LL_NO_PART)
384 { 408 {
385 // You should already have an object selected from the mousedown. 409 // You should already have an object selected from the mousedown.
386 // If so, show its properties 410 // If so, show its properties
@@ -480,6 +504,11 @@ BOOL LLToolCompCreate::handleMouseUp(S32 x, S32 y, MASK mask)
480 mObjectPlacedOnMouseDown = FALSE; 504 mObjectPlacedOnMouseDown = FALSE;
481 mMouseDown = FALSE; 505 mMouseDown = FALSE;
482 506
507 if (!handled)
508 {
509 handled = LLToolComposite::handleMouseUp(x, y, mask);
510 }
511
483 return handled; 512 return handled;
484} 513}
485 514
@@ -534,7 +563,7 @@ void LLToolCompRotate::pickCallback(S32 x, S32 y, MASK mask)
534 563
535 if( hit_obj || gToolRotate->mManip->getHighlightedPart() != LLManip::LL_NO_PART) 564 if( hit_obj || gToolRotate->mManip->getHighlightedPart() != LLManip::LL_NO_PART)
536 { 565 {
537 if (gSelectMgr->getObjectCount()) 566 if (gToolRotate->mManip->getSelection()->getObjectCount())
538 { 567 {
539 gEditMenuHandler = gSelectMgr; 568 gEditMenuHandler = gSelectMgr;
540 } 569 }
@@ -562,10 +591,18 @@ BOOL LLToolCompRotate::handleMouseUp(S32 x, S32 y, MASK mask)
562 return LLToolComposite::handleMouseUp(x, y, mask); 591 return LLToolComposite::handleMouseUp(x, y, mask);
563} 592}
564 593
594LLTool* LLToolCompRotate::getOverrideTool(MASK mask)
595{
596 if (mask == (MASK_CONTROL | MASK_SHIFT))
597 {
598 return gToolStretch;
599 }
600 return LLToolComposite::getOverrideTool(mask);
601}
565 602
566BOOL LLToolCompRotate::handleDoubleClick(S32 x, S32 y, MASK mask) 603BOOL LLToolCompRotate::handleDoubleClick(S32 x, S32 y, MASK mask)
567{ 604{
568 if (!gSelectMgr->isEmpty() && mManip->getHighlightedPart() == LLManip::LL_NO_PART) 605 if (!mManip->getSelection()->isEmpty() && mManip->getHighlightedPart() == LLManip::LL_NO_PART)
569 { 606 {
570 // You should already have an object selected from the mousedown. 607 // You should already have an object selected from the mousedown.
571 // If so, show its properties 608 // If so, show its properties
@@ -668,7 +705,7 @@ BOOL LLToolCompGun::handleMouseDown(S32 x, S32 y, MASK mask)
668 705
669 // On mousedown, start grabbing 706 // On mousedown, start grabbing
670 gGrabTransientTool = this; 707 gGrabTransientTool = this;
671 gCurrentToolset->selectTool( (LLTool*) mGrab ); 708 gToolMgr->getCurrentToolset()->selectTool( (LLTool*) mGrab );
672 709
673 return gToolGrab->handleMouseDown(x, y, mask); 710 return gToolGrab->handleMouseDown(x, y, mask);
674} 711}
@@ -685,7 +722,7 @@ BOOL LLToolCompGun::handleDoubleClick(S32 x, S32 y, MASK mask)
685 722
686 // On mousedown, start grabbing 723 // On mousedown, start grabbing
687 gGrabTransientTool = this; 724 gGrabTransientTool = this;
688 gCurrentToolset->selectTool( (LLTool*) mGrab ); 725 gToolMgr->getCurrentToolset()->selectTool( (LLTool*) mGrab );
689 726
690 return gToolGrab->handleDoubleClick(x, y, mask); 727 return gToolGrab->handleDoubleClick(x, y, mask);
691} 728}