diff options
Diffstat (limited to 'indra/llwindow')
| -rw-r--r-- | indra/llwindow/llkeyboard.cpp | 16 | ||||
| -rw-r--r-- | indra/llwindow/llkeyboard.h | 3 | ||||
| -rw-r--r-- | indra/llwindow/llopenglview-objc.mm | 6 | ||||
| -rw-r--r-- | indra/llwindow/llwindowmacosx-objc.mm | 4 | ||||
| -rw-r--r-- | indra/llwindow/llwindowmacosx.cpp | 2 | 
5 files changed, 24 insertions, 7 deletions
| diff --git a/indra/llwindow/llkeyboard.cpp b/indra/llwindow/llkeyboard.cpp index 5404ac50e5..e65cc7563e 100644 --- a/indra/llwindow/llkeyboard.cpp +++ b/indra/llwindow/llkeyboard.cpp @@ -148,6 +148,22 @@ void LLKeyboard::addKeyName(KEY key, const std::string& name)  	sNamesToKeys[nameuc] = key;  } +void LLKeyboard::resetKeyDownAndHandle() +{ +    MASK mask = currentMask(FALSE); +    for (S32 i = 0; i < KEY_COUNT; i++) +    { +        if (mKeyLevel[i]) +        { +            mKeyDown[i] = FALSE; +            mKeyLevel[i] = FALSE; +            mKeyUp[i] = TRUE; +            mCurTranslatedKey = (KEY)i; +            mCallbacks->handleTranslatedKeyUp(i, mask); +        } +    } +} +  // BUG this has to be called when an OS dialog is shown, otherwise modifier key state  // is wrong because the keyup event is never received by the main window. JC  void LLKeyboard::resetKeys() diff --git a/indra/llwindow/llkeyboard.h b/indra/llwindow/llkeyboard.h index 36bd8bcbed..fb1ae10f50 100644 --- a/indra/llwindow/llkeyboard.h +++ b/indra/llwindow/llkeyboard.h @@ -58,7 +58,8 @@ public:  	LLKeyboard();  	virtual ~LLKeyboard(); -	void			resetKeys(); +    void			resetKeyDownAndHandle(); +    void			resetKeys();  	F32				getCurKeyElapsedTime()	{ return getKeyDown(mCurScanKey) ? getKeyElapsedTime( mCurScanKey ) : 0.f; } diff --git a/indra/llwindow/llopenglview-objc.mm b/indra/llwindow/llopenglview-objc.mm index f9b387b00b..27d36a803b 100644 --- a/indra/llwindow/llopenglview-objc.mm +++ b/indra/llwindow/llopenglview-objc.mm @@ -494,14 +494,14 @@ attributedStringInfo getSegments(NSAttributedString *str)      // e.g. OS Window for upload something or Input Window...      // mModifiers instance variable is for insertText: or insertText:replacementRange:  (by Pell Smit)  	mModifiers = [theEvent modifierFlags]; +    unichar ch = [[theEvent charactersIgnoringModifiers] characterAtIndex:0]; +    bool acceptsText = mHasMarkedText ? false : callKeyDown(&eventData, keycode, mModifiers, ch); -    bool acceptsText = mHasMarkedText ? false : callKeyDown(&eventData, keycode, mModifiers, [[theEvent characters] characterAtIndex:0]); -    unichar ch;      if (acceptsText &&          !mMarkedTextAllowed &&          !(mModifiers & (NSControlKeyMask | NSCommandKeyMask)) &&  // commands don't invoke InputWindow          ![(LLAppDelegate*)[NSApp delegate] romanScript] && -        (ch = [[theEvent charactersIgnoringModifiers] characterAtIndex:0]) > ' ' && +        ch > ' ' &&          ch != NSDeleteCharacter &&          (ch < 0xF700 || ch > 0xF8FF))  // 0xF700-0xF8FF: reserved for function keys on the keyboard(from NSEvent.h)      { diff --git a/indra/llwindow/llwindowmacosx-objc.mm b/indra/llwindow/llwindowmacosx-objc.mm index f895c17643..5ec9b017cf 100644 --- a/indra/llwindow/llwindowmacosx-objc.mm +++ b/indra/llwindow/llwindowmacosx-objc.mm @@ -100,13 +100,13 @@ const unsigned short *copyFromPBoard()  CursorRef createImageCursor(const char *fullpath, int hotspotX, int hotspotY)  {  	NSAutoreleasePool *pool = [[NSAutoreleasePool alloc] init]; -	 +  	// extra retain on the NSCursor since we want it to live for the lifetime of the app.  	NSCursor *cursor =  	[[[NSCursor alloc]  	  initWithImage:  	  [[[NSImage alloc] initWithContentsOfFile: -		[NSString stringWithFormat:@"%s", fullpath] +		[NSString stringWithUTF8String:fullpath]  		]autorelease]  	  hotSpot:NSMakePoint(hotspotX, hotspotY)  	  ]retain]; diff --git a/indra/llwindow/llwindowmacosx.cpp b/indra/llwindow/llwindowmacosx.cpp index 24ce5131d5..c6d1bb3fec 100644 --- a/indra/llwindow/llwindowmacosx.cpp +++ b/indra/llwindow/llwindowmacosx.cpp @@ -1676,7 +1676,7 @@ void LLWindowMacOSX::hideCursor()  void LLWindowMacOSX::showCursor()  { -	if(mCursorHidden) +	if(mCursorHidden || !isCGCursorVisible())  	{  		//		LL_INFOS() << "showCursor: showing" << LL_ENDL;  		mCursorHidden = FALSE; | 
