aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/linden/indra/llui/lllineeditor.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'linden/indra/llui/lllineeditor.cpp')
-rw-r--r--linden/indra/llui/lllineeditor.cpp35
1 files changed, 13 insertions, 22 deletions
diff --git a/linden/indra/llui/lllineeditor.cpp b/linden/indra/llui/lllineeditor.cpp
index 1ca17fe..ec156ba 100644
--- a/linden/indra/llui/lllineeditor.cpp
+++ b/linden/indra/llui/lllineeditor.cpp
@@ -4,6 +4,7 @@
4 * 4 *
5 * Copyright (c) 2001-2007, Linden Research, Inc. 5 * Copyright (c) 2001-2007, Linden Research, Inc.
6 * 6 *
7 * Second Life Viewer Source Code
7 * The source code in this file ("Source Code") is provided by Linden Lab 8 * The source code in this file ("Source Code") is provided by Linden Lab
8 * to you under the terms of the GNU General Public License, version 2.0 9 * to you under the terms of the GNU General Public License, version 2.0
9 * ("GPL"), unless you have obtained a separate licensing agreement 10 * ("GPL"), unless you have obtained a separate licensing agreement
@@ -115,7 +116,7 @@ LLLineEditor::LLLineEditor(const LLString& name, const LLRect& rect,
115 S32 max_length_bytes, 116 S32 max_length_bytes,
116 void (*commit_callback)(LLUICtrl* caller, void* user_data ), 117 void (*commit_callback)(LLUICtrl* caller, void* user_data ),
117 void (*keystroke_callback)(LLLineEditor* caller, void* user_data ), 118 void (*keystroke_callback)(LLLineEditor* caller, void* user_data ),
118 void (*focus_lost_callback)(LLLineEditor* caller, void* user_data ), 119 void (*focus_lost_callback)(LLUICtrl* caller, void* user_data ),
119 void* userdata, 120 void* userdata,
120 LLLinePrevalidateFunc prevalidate_func, 121 LLLinePrevalidateFunc prevalidate_func,
121 LLViewBorder::EBevel border_bevel, 122 LLViewBorder::EBevel border_bevel,
@@ -132,7 +133,6 @@ LLLineEditor::LLLineEditor(const LLString& name, const LLRect& rect,
132 mCommitOnFocusLost( TRUE ), 133 mCommitOnFocusLost( TRUE ),
133 mRevertOnEsc( TRUE ), 134 mRevertOnEsc( TRUE ),
134 mKeystrokeCallback( keystroke_callback ), 135 mKeystrokeCallback( keystroke_callback ),
135 mFocusLostCallback( focus_lost_callback ),
136 mIsSelecting( FALSE ), 136 mIsSelecting( FALSE ),
137 mSelectionStart( 0 ), 137 mSelectionStart( 0 ),
138 mSelectionEnd( 0 ), 138 mSelectionEnd( 0 ),
@@ -166,6 +166,8 @@ LLLineEditor::LLLineEditor(const LLString& name, const LLRect& rect,
166 mGLFont = LLFontGL::sSansSerifSmall; 166 mGLFont = LLFontGL::sSansSerifSmall;
167 } 167 }
168 168
169 setFocusLostCallback(focus_lost_callback);
170
169 mMinHPixels = mBorderThickness + UI_LINEEDITOR_H_PAD + mBorderLeft; 171 mMinHPixels = mBorderThickness + UI_LINEEDITOR_H_PAD + mBorderLeft;
170 mMaxHPixels = mRect.getWidth() - mMinHPixels - mBorderThickness - mBorderRight; 172 mMaxHPixels = mRect.getWidth() - mMinHPixels - mBorderThickness - mBorderRight;
171 173
@@ -186,7 +188,6 @@ LLLineEditor::LLLineEditor(const LLString& name, const LLRect& rect,
186 188
187LLLineEditor::~LLLineEditor() 189LLLineEditor::~LLLineEditor()
188{ 190{
189 mFocusLostCallback = NULL;
190 mCommitOnFocusLost = FALSE; 191 mCommitOnFocusLost = FALSE;
191 192
192 gFocusMgr.releaseFocusIfNeeded( this ); 193 gFocusMgr.releaseFocusIfNeeded( this );
@@ -211,11 +212,8 @@ LLString LLLineEditor::getWidgetTag() const
211 212
212void LLLineEditor::onFocusLost() 213void LLLineEditor::onFocusLost()
213{ 214{
214 if( mFocusLostCallback ) 215 LLUICtrl::onFocusLost();
215 { 216
216 mFocusLostCallback( this, mCallbackUserData );
217 }
218
219 if( mCommitOnFocusLost && mText.getString() != mPrevText) 217 if( mCommitOnFocusLost && mText.getString() != mPrevText)
220 { 218 {
221 onCommit(); 219 onCommit();
@@ -502,7 +500,7 @@ BOOL LLLineEditor::handleMouseDown(S32 x, S32 y, MASK mask)
502 startSelection(); 500 startSelection();
503 } 501 }
504 502
505 gFocusMgr.setMouseCapture( this, &LLLineEditor::onMouseCaptureLost ); 503 gFocusMgr.setMouseCapture( this );
506 } 504 }
507 505
508 // delay cursor flashing 506 // delay cursor flashing
@@ -515,14 +513,14 @@ BOOL LLLineEditor::handleMouseDown(S32 x, S32 y, MASK mask)
515BOOL LLLineEditor::handleHover(S32 x, S32 y, MASK mask) 513BOOL LLLineEditor::handleHover(S32 x, S32 y, MASK mask)
516{ 514{
517 BOOL handled = FALSE; 515 BOOL handled = FALSE;
518 if (gFocusMgr.getMouseCapture() != this && (x < mBorderLeft || x > (mRect.getWidth() - mBorderRight))) 516 if (!hasMouseCapture() && (x < mBorderLeft || x > (mRect.getWidth() - mBorderRight)))
519 { 517 {
520 return LLUICtrl::handleHover(x, y, mask); 518 return LLUICtrl::handleHover(x, y, mask);
521 } 519 }
522 520
523 if( getVisible() ) 521 if( getVisible() )
524 { 522 {
525 if( (gFocusMgr.getMouseCapture() == this) && mIsSelecting ) 523 if( (hasMouseCapture()) && mIsSelecting )
526 { 524 {
527 if (x != mLastSelectionX || y != mLastSelectionY) 525 if (x != mLastSelectionX || y != mLastSelectionY)
528 { 526 {
@@ -580,9 +578,9 @@ BOOL LLLineEditor::handleMouseUp(S32 x, S32 y, MASK mask)
580{ 578{
581 BOOL handled = FALSE; 579 BOOL handled = FALSE;
582 580
583 if( gFocusMgr.getMouseCapture() == this ) 581 if( hasMouseCapture() )
584 { 582 {
585 gFocusMgr.setMouseCapture( NULL, NULL ); 583 gFocusMgr.setMouseCapture( NULL );
586 handled = TRUE; 584 handled = TRUE;
587 } 585 }
588 586
@@ -1916,11 +1914,9 @@ BOOL LLLineEditor::prevalidateASCII(const LLWString &str)
1916 return rv; 1914 return rv;
1917} 1915}
1918 1916
1919//static 1917void LLLineEditor::onMouseCaptureLost()
1920void LLLineEditor::onMouseCaptureLost( LLMouseHandler* old_captor )
1921{ 1918{
1922 LLLineEditor* self = (LLLineEditor*) old_captor; 1919 endSelection();
1923 self->endSelection();
1924} 1920}
1925 1921
1926 1922
@@ -1935,11 +1931,6 @@ void LLLineEditor::setKeystrokeCallback(void (*keystroke_callback)(LLLineEditor*
1935 mKeystrokeCallback = keystroke_callback; 1931 mKeystrokeCallback = keystroke_callback;
1936} 1932}
1937 1933
1938void LLLineEditor::setFocusLostCallback(void (*keystroke_callback)(LLLineEditor* caller, void* user_data))
1939{
1940 mFocusLostCallback = keystroke_callback;
1941}
1942
1943// virtual 1934// virtual
1944LLXMLNodePtr LLLineEditor::getXML(bool save_children) const 1935LLXMLNodePtr LLLineEditor::getXML(bool save_children) const
1945{ 1936{