summaryrefslogtreecommitdiff
path: root/indra/newview/lltool.cpp
diff options
context:
space:
mode:
authorAnsariel <ansariel.hiller@phoenixviewer.com>2024-05-22 19:04:52 +0200
committerAnsariel <ansariel.hiller@phoenixviewer.com>2024-05-22 19:04:52 +0200
commit1b67dd855c41f5a0cda7ec2a68d98071986ca703 (patch)
treeab243607f74f78200787bba5b9b88f07ef1b966f /indra/newview/lltool.cpp
parent6d6eabca44d08d5b97bfe3e941d2b9687c2246ea (diff)
parente1623bb276f83a43ce7a197e388720c05bdefe61 (diff)
Merge remote-tracking branch 'origin/main' into DRTVWR-600-maint-A
# Conflicts: # autobuild.xml # indra/cmake/CMakeLists.txt # indra/cmake/GoogleMock.cmake # indra/llaudio/llaudioengine_fmodstudio.cpp # indra/llaudio/llaudioengine_fmodstudio.h # indra/llaudio/lllistener_fmodstudio.cpp # indra/llaudio/lllistener_fmodstudio.h # indra/llaudio/llstreamingaudio_fmodstudio.cpp # indra/llaudio/llstreamingaudio_fmodstudio.h # indra/llcharacter/llmultigesture.cpp # indra/llcharacter/llmultigesture.h # indra/llimage/llimage.cpp # indra/llimage/llimagepng.cpp # indra/llimage/llimageworker.cpp # indra/llimage/tests/llimageworker_test.cpp # indra/llmessage/tests/llmockhttpclient.h # indra/llprimitive/llgltfmaterial.h # indra/llrender/llfontfreetype.cpp # indra/llui/llcombobox.cpp # indra/llui/llfolderview.cpp # indra/llui/llfolderviewmodel.h # indra/llui/lllineeditor.cpp # indra/llui/lllineeditor.h # indra/llui/lltextbase.cpp # indra/llui/lltextbase.h # indra/llui/lltexteditor.cpp # indra/llui/lltextvalidate.cpp # indra/llui/lltextvalidate.h # indra/llui/lluictrl.h # indra/llui/llview.cpp # indra/llwindow/llwindowmacosx.cpp # indra/newview/app_settings/settings.xml # indra/newview/llappearancemgr.cpp # indra/newview/llappearancemgr.h # indra/newview/llavatarpropertiesprocessor.cpp # indra/newview/llavatarpropertiesprocessor.h # indra/newview/llbreadcrumbview.cpp # indra/newview/llbreadcrumbview.h # indra/newview/llbreastmotion.cpp # indra/newview/llbreastmotion.h # indra/newview/llconversationmodel.h # indra/newview/lldensityctrl.cpp # indra/newview/lldensityctrl.h # indra/newview/llface.inl # indra/newview/llfloatereditsky.cpp # indra/newview/llfloatereditwater.cpp # indra/newview/llfloateremojipicker.h # indra/newview/llfloaterimsessiontab.cpp # indra/newview/llfloaterprofiletexture.cpp # indra/newview/llfloaterprofiletexture.h # indra/newview/llgesturemgr.cpp # indra/newview/llgesturemgr.h # indra/newview/llimpanel.cpp # indra/newview/llimpanel.h # indra/newview/llinventorybridge.cpp # indra/newview/llinventorybridge.h # indra/newview/llinventoryclipboard.cpp # indra/newview/llinventoryclipboard.h # indra/newview/llinventoryfunctions.cpp # indra/newview/llinventoryfunctions.h # indra/newview/llinventorygallery.cpp # indra/newview/lllistbrowser.cpp # indra/newview/lllistbrowser.h # indra/newview/llpanelobjectinventory.cpp # indra/newview/llpanelprofile.cpp # indra/newview/llpanelprofile.h # indra/newview/llpreviewgesture.cpp # indra/newview/llsavedsettingsglue.cpp # indra/newview/llsavedsettingsglue.h # indra/newview/lltooldraganddrop.cpp # indra/newview/llurllineeditorctrl.cpp # indra/newview/llvectorperfoptions.cpp # indra/newview/llvectorperfoptions.h # indra/newview/llviewerparceloverlay.cpp # indra/newview/llviewertexlayer.cpp # indra/newview/llviewertexturelist.cpp # indra/newview/macmain.h # indra/test/test.cpp
Diffstat (limited to 'indra/newview/lltool.cpp')
-rw-r--r--indra/newview/lltool.cpp420
1 files changed, 210 insertions, 210 deletions
diff --git a/indra/newview/lltool.cpp b/indra/newview/lltool.cpp
index 18dd695ec1..5618e64dd4 100644
--- a/indra/newview/lltool.cpp
+++ b/indra/newview/lltool.cpp
@@ -1,210 +1,210 @@
-/**
- * @file lltool.cpp
- * @brief LLTool class implementation
- *
- * $LicenseInfo:firstyear=2001&license=viewerlgpl$
- * Second Life Viewer Source Code
- * Copyright (C) 2010, Linden Research, Inc.
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public
- * License as published by the Free Software Foundation;
- * version 2.1 of the License only.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public
- * License along with this library; if not, write to the Free Software
- * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
- *
- * Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA
- * $/LicenseInfo$
- */
-
-#include "llviewerprecompiledheaders.h"
-
-#include "lltool.h"
-
-#include "indra_constants.h"
-#include "llerror.h"
-#include "llview.h"
-
-#include "llviewerwindow.h"
-#include "llviewercontrol.h"
-#include "lltoolcomp.h"
-#include "lltoolfocus.h"
-#include "llfocusmgr.h"
-#include "llagent.h"
-#include "llviewerjoystick.h"
-
-extern bool gDebugClicks;
-
-//static
-const std::string LLTool::sNameNull("null");
-
-LLTool::LLTool( const std::string& name, LLToolComposite* composite ) :
- mComposite( composite ),
- mName(name)
-{
-}
-
-LLTool::~LLTool()
-{
- if( hasMouseCapture() )
- {
- LL_WARNS() << "Tool deleted holding mouse capture. Mouse capture removed." << LL_ENDL;
- gFocusMgr.removeMouseCaptureWithoutCallback( this );
- }
-}
-
-bool LLTool::handleAnyMouseClick(S32 x, S32 y, MASK mask, EMouseClickType clicktype, bool down)
-{
- bool result = LLMouseHandler::handleAnyMouseClick(x, y, mask, clicktype, down);
-
- // This behavior was moved here from LLViewerWindow::handleAnyMouseClick, so it can be selectively overridden by LLTool subclasses.
- if(down && result)
- {
- // This is necessary to force clicks in the world to cause edit
- // boxes that might have keyboard focus to relinquish it, and hence
- // cause a commit to update their value. JC
- gFocusMgr.setKeyboardFocus(NULL);
- }
-
- return result;
-}
-
-bool LLTool::handleMouseDown(S32 x, S32 y, MASK mask)
-{
- if (gDebugClicks)
- {
- LL_INFOS() << "LLTool left mouse down" << LL_ENDL;
- }
- // by default, didn't handle it
- // AGENT_CONTROL_LBUTTON_DOWN is handled by scanMouse() and scanKey()
- // LL_INFOS() << "LLTool::handleMouseDown" << LL_ENDL;
- return false;
-}
-
-bool LLTool::handleMouseUp(S32 x, S32 y, MASK mask)
-{
- if (gDebugClicks)
- {
- LL_INFOS() << "LLTool left mouse up" << LL_ENDL;
- }
- // by default, didn't handle it
- // AGENT_CONTROL_LBUTTON_UP is handled by scanMouse() and scanKey()
- // LL_INFOS() << "LLTool::handleMouseUp" << LL_ENDL;
- return true;
-}
-
-bool LLTool::handleHover(S32 x, S32 y, MASK mask)
-{
- gViewerWindow->setCursor(UI_CURSOR_ARROW);
- LL_DEBUGS("UserInput") << "hover handled by a tool" << LL_ENDL;
- // by default, do nothing, say we handled it
- return true;
-}
-
-bool LLTool::handleScrollWheel(S32 x, S32 y, S32 clicks)
-{
- // by default, didn't handle it
- // LL_INFOS() << "LLTool::handleScrollWheel" << LL_ENDL;
- return false;
-}
-
-bool LLTool::handleScrollHWheel(S32 x, S32 y, S32 clicks)
-{
- // by default, didn't handle it
- return false;
-}
-
-bool LLTool::handleDoubleClick(S32 x,S32 y,MASK mask)
-{
- // LL_INFOS() << "LLTool::handleDoubleClick" << LL_ENDL;
- // by default, pretend it's a left click
- return false;
-}
-
-bool LLTool::handleRightMouseDown(S32 x,S32 y,MASK mask)
-{
- // by default, didn't handle it
- // LL_INFOS() << "LLTool::handleRightMouseDown" << LL_ENDL;
- return false;
-}
-
-bool LLTool::handleRightMouseUp(S32 x, S32 y, MASK mask)
-{
- // by default, didn't handle it
- // LL_INFOS() << "LLTool::handleRightMouseDown" << LL_ENDL;
- return false;
-}
-
-bool LLTool::handleMiddleMouseDown(S32 x,S32 y,MASK mask)
-{
- // by default, didn't handle it
- // LL_INFOS() << "LLTool::handleMiddleMouseDown" << LL_ENDL;
- return false;
-}
-
-bool LLTool::handleMiddleMouseUp(S32 x, S32 y, MASK mask)
-{
- // by default, didn't handle it
- // LL_INFOS() << "LLTool::handleMiddleMouseUp" << LL_ENDL;
- return false;
-}
-
-bool LLTool::handleToolTip(S32 x, S32 y, MASK mask)
-{
- // by default, didn't handle it
- // LL_INFOS() << "LLTool::handleToolTip" << LL_ENDL;
- return false;
-}
-
-void LLTool::setMouseCapture( bool b )
-{
- if( b )
- {
- gFocusMgr.setMouseCapture(mComposite ? mComposite : this );
- }
- else
- if( hasMouseCapture() )
- {
- gFocusMgr.setMouseCapture( NULL );
- }
-}
-
-// virtual
-void LLTool::draw()
-{ }
-
-bool LLTool::hasMouseCapture()
-{
- return gFocusMgr.getMouseCapture() == (mComposite ? mComposite : this);
-}
-
-bool LLTool::handleKey(KEY key, MASK mask)
-{
- return false;
-}
-
-LLTool* LLTool::getOverrideTool(MASK mask)
-{
- // NOTE: if in flycam mode, ALT-ZOOM camera should be disabled
- if (LLViewerJoystick::getInstance()->getOverrideCamera())
- {
- return NULL;
- }
-
- static LLCachedControl<bool> alt_zoom(gSavedSettings, "EnableAltZoom", true);
- if (alt_zoom)
- {
- if (mask & MASK_ALT)
- {
- return LLToolCamera::getInstance();
- }
- }
- return NULL;
-}
+/**
+ * @file lltool.cpp
+ * @brief LLTool class implementation
+ *
+ * $LicenseInfo:firstyear=2001&license=viewerlgpl$
+ * Second Life Viewer Source Code
+ * Copyright (C) 2010, Linden Research, Inc.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation;
+ * version 2.1 of the License only.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
+ *
+ * Linden Research, Inc., 945 Battery Street, San Francisco, CA 94111 USA
+ * $/LicenseInfo$
+ */
+
+#include "llviewerprecompiledheaders.h"
+
+#include "lltool.h"
+
+#include "indra_constants.h"
+#include "llerror.h"
+#include "llview.h"
+
+#include "llviewerwindow.h"
+#include "llviewercontrol.h"
+#include "lltoolcomp.h"
+#include "lltoolfocus.h"
+#include "llfocusmgr.h"
+#include "llagent.h"
+#include "llviewerjoystick.h"
+
+extern bool gDebugClicks;
+
+//static
+const std::string LLTool::sNameNull("null");
+
+LLTool::LLTool( const std::string& name, LLToolComposite* composite ) :
+ mComposite( composite ),
+ mName(name)
+{
+}
+
+LLTool::~LLTool()
+{
+ if( hasMouseCapture() )
+ {
+ LL_WARNS() << "Tool deleted holding mouse capture. Mouse capture removed." << LL_ENDL;
+ gFocusMgr.removeMouseCaptureWithoutCallback( this );
+ }
+}
+
+bool LLTool::handleAnyMouseClick(S32 x, S32 y, MASK mask, EMouseClickType clicktype, bool down)
+{
+ bool result = LLMouseHandler::handleAnyMouseClick(x, y, mask, clicktype, down);
+
+ // This behavior was moved here from LLViewerWindow::handleAnyMouseClick, so it can be selectively overridden by LLTool subclasses.
+ if(down && result)
+ {
+ // This is necessary to force clicks in the world to cause edit
+ // boxes that might have keyboard focus to relinquish it, and hence
+ // cause a commit to update their value. JC
+ gFocusMgr.setKeyboardFocus(NULL);
+ }
+
+ return result;
+}
+
+bool LLTool::handleMouseDown(S32 x, S32 y, MASK mask)
+{
+ if (gDebugClicks)
+ {
+ LL_INFOS() << "LLTool left mouse down" << LL_ENDL;
+ }
+ // by default, didn't handle it
+ // AGENT_CONTROL_LBUTTON_DOWN is handled by scanMouse() and scanKey()
+ // LL_INFOS() << "LLTool::handleMouseDown" << LL_ENDL;
+ return false;
+}
+
+bool LLTool::handleMouseUp(S32 x, S32 y, MASK mask)
+{
+ if (gDebugClicks)
+ {
+ LL_INFOS() << "LLTool left mouse up" << LL_ENDL;
+ }
+ // by default, didn't handle it
+ // AGENT_CONTROL_LBUTTON_UP is handled by scanMouse() and scanKey()
+ // LL_INFOS() << "LLTool::handleMouseUp" << LL_ENDL;
+ return true;
+}
+
+bool LLTool::handleHover(S32 x, S32 y, MASK mask)
+{
+ gViewerWindow->setCursor(UI_CURSOR_ARROW);
+ LL_DEBUGS("UserInput") << "hover handled by a tool" << LL_ENDL;
+ // by default, do nothing, say we handled it
+ return true;
+}
+
+bool LLTool::handleScrollWheel(S32 x, S32 y, S32 clicks)
+{
+ // by default, didn't handle it
+ // LL_INFOS() << "LLTool::handleScrollWheel" << LL_ENDL;
+ return false;
+}
+
+bool LLTool::handleScrollHWheel(S32 x, S32 y, S32 clicks)
+{
+ // by default, didn't handle it
+ return false;
+}
+
+bool LLTool::handleDoubleClick(S32 x,S32 y,MASK mask)
+{
+ // LL_INFOS() << "LLTool::handleDoubleClick" << LL_ENDL;
+ // by default, pretend it's a left click
+ return false;
+}
+
+bool LLTool::handleRightMouseDown(S32 x,S32 y,MASK mask)
+{
+ // by default, didn't handle it
+ // LL_INFOS() << "LLTool::handleRightMouseDown" << LL_ENDL;
+ return false;
+}
+
+bool LLTool::handleRightMouseUp(S32 x, S32 y, MASK mask)
+{
+ // by default, didn't handle it
+ // LL_INFOS() << "LLTool::handleRightMouseDown" << LL_ENDL;
+ return false;
+}
+
+bool LLTool::handleMiddleMouseDown(S32 x,S32 y,MASK mask)
+{
+ // by default, didn't handle it
+ // LL_INFOS() << "LLTool::handleMiddleMouseDown" << LL_ENDL;
+ return false;
+}
+
+bool LLTool::handleMiddleMouseUp(S32 x, S32 y, MASK mask)
+{
+ // by default, didn't handle it
+ // LL_INFOS() << "LLTool::handleMiddleMouseUp" << LL_ENDL;
+ return false;
+}
+
+bool LLTool::handleToolTip(S32 x, S32 y, MASK mask)
+{
+ // by default, didn't handle it
+ // LL_INFOS() << "LLTool::handleToolTip" << LL_ENDL;
+ return false;
+}
+
+void LLTool::setMouseCapture( bool b )
+{
+ if( b )
+ {
+ gFocusMgr.setMouseCapture(mComposite ? mComposite : this );
+ }
+ else
+ if( hasMouseCapture() )
+ {
+ gFocusMgr.setMouseCapture( NULL );
+ }
+}
+
+// virtual
+void LLTool::draw()
+{ }
+
+bool LLTool::hasMouseCapture()
+{
+ return gFocusMgr.getMouseCapture() == (mComposite ? mComposite : this);
+}
+
+bool LLTool::handleKey(KEY key, MASK mask)
+{
+ return false;
+}
+
+LLTool* LLTool::getOverrideTool(MASK mask)
+{
+ // NOTE: if in flycam mode, ALT-ZOOM camera should be disabled
+ if (LLViewerJoystick::getInstance()->getOverrideCamera())
+ {
+ return NULL;
+ }
+
+ static LLCachedControl<bool> alt_zoom(gSavedSettings, "EnableAltZoom", true);
+ if (alt_zoom)
+ {
+ if (mask & MASK_ALT)
+ {
+ return LLToolCamera::getInstance();
+ }
+ }
+ return NULL;
+}