summaryrefslogtreecommitdiff
path: root/indra/newview/lltool.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'indra/newview/lltool.cpp')
-rw-r--r--indra/newview/lltool.cpp151
1 files changed, 151 insertions, 0 deletions
diff --git a/indra/newview/lltool.cpp b/indra/newview/lltool.cpp
new file mode 100644
index 0000000000..f9ff070289
--- /dev/null
+++ b/indra/newview/lltool.cpp
@@ -0,0 +1,151 @@
+/**
+ * @file lltool.cpp
+ * @brief LLTool class implementation
+ *
+ * Copyright (c) 2001-$CurrentYear$, Linden Research, Inc.
+ * $License$
+ */
+
+#include "llviewerprecompiledheaders.h"
+
+#include "lltool.h"
+
+#include "indra_constants.h"
+#include "llerror.h"
+#include "llview.h"
+
+#include "llviewerwindow.h"
+#include "lltoolcomp.h"
+#include "llfocusmgr.h"
+#include "llagent.h"
+#include "llviewborder.h"
+
+extern BOOL gDebugClicks;
+
+//static
+const LLString LLTool::sNameNull("null");
+
+LLTool::LLTool( const LLString& name, LLToolComposite* composite ) :
+ mComposite( composite ),
+ mName(name)
+{
+}
+
+LLTool::~LLTool()
+{
+ if( gFocusMgr.getMouseCapture() == this )
+ {
+ llwarns << "Tool deleted holding mouse capture. Mouse capture removed." << llendl;
+ gFocusMgr.removeMouseCaptureWithoutCallback( this );
+ }
+}
+
+
+BOOL LLTool::handleMouseDown(S32 x, S32 y, MASK mask)
+{
+ if (gDebugClicks)
+ {
+ llinfos << "LLTool left mouse down" << llendl;
+ }
+ // by default, didn't handle it
+ // llinfos << "LLTool::handleMouseDown" << llendl;
+ gAgent.setControlFlags(AGENT_CONTROL_LBUTTON_DOWN);
+ return TRUE;
+}
+
+BOOL LLTool::handleMouseUp(S32 x, S32 y, MASK mask)
+{
+ if (gDebugClicks)
+ {
+ llinfos << "LLTool left mouse up" << llendl;
+ }
+ // by default, didn't handle it
+ // llinfos << "LLTool::handleMouseUp" << llendl;
+ gAgent.setControlFlags(AGENT_CONTROL_LBUTTON_UP);
+ return TRUE;
+}
+
+BOOL LLTool::handleHover(S32 x, S32 y, MASK mask)
+{
+ gViewerWindow->getWindow()->setCursor(UI_CURSOR_ARROW);
+ lldebugst(LLERR_USER_INPUT) << "hover handled by a tool" << llendl;
+ // 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
+ // llinfos << "LLTool::handleScrollWheel" << llendl;
+ return FALSE;
+}
+
+BOOL LLTool::handleDoubleClick(S32 x,S32 y,MASK mask)
+{
+ // llinfos << "LLTool::handleDoubleClick" << llendl;
+ // 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
+ // llinfos << "LLTool::handleRightMouseDown" << llendl;
+ return FALSE;
+}
+
+BOOL LLTool::handleRightMouseUp(S32 x, S32 y, MASK mask)
+{
+ // by default, didn't handle it
+ // llinfos << "LLTool::handleRightMouseDown" << llendl;
+ return FALSE;
+}
+
+BOOL LLTool::handleToolTip(S32 x, S32 y, LLString& msg, LLRect* sticky_rect_screen)
+{
+ // by default, didn't handle it
+ // llinfos << "LLTool::handleToolTip" << llendl;
+ return FALSE;
+}
+
+void LLTool::setMouseCapture( BOOL b )
+{
+ if( b )
+ {
+ gViewerWindow->setMouseCapture(mComposite ? mComposite : this, &LLTool::onMouseCaptureLost );
+ }
+ else
+ if( hasMouseCapture() )
+ {
+ gViewerWindow->setMouseCapture( NULL, NULL );
+ }
+}
+
+// virtual
+void LLTool::draw()
+{ }
+
+BOOL LLTool::hasMouseCapture()
+{
+ return gViewerWindow->hasMouseCapture(mComposite ? mComposite : this);
+}
+
+BOOL LLTool::handleKey(KEY key, MASK mask)
+{
+ return FALSE;
+}
+
+
+// static
+void LLTool::onMouseCaptureLost( LLMouseHandler* old_captor )
+{
+ LLTool* self = (LLTool*) old_captor;
+ if( self->mComposite )
+ {
+ self->mComposite->onMouseCaptureLost();
+ }
+ else
+ {
+ self->onMouseCaptureLost();
+ }
+}