From e4d48f3a3b67026825f54e2c8df18550f7220acf Mon Sep 17 00:00:00 2001 From: michi_cc Date: Mon, 5 Aug 2013 20:37:33 +0000 Subject: (svn r25686) -Codechange: [OSX] Abandon IME input if the edit box lost the focus. --- src/video/cocoa/cocoa_v.h | 5 +++++ src/video/cocoa/cocoa_v.mm | 14 ++++++++++++++ 2 files changed, 19 insertions(+) (limited to 'src/video') diff --git a/src/video/cocoa/cocoa_v.h b/src/video/cocoa/cocoa_v.h index 06bbbfdb2..e350f0a06 100644 --- a/src/video/cocoa/cocoa_v.h +++ b/src/video/cocoa/cocoa_v.h @@ -50,6 +50,11 @@ public: */ /* virtual */ bool AfterBlitterChange(); + /** + * An edit box lost the input focus. Abort character compositing if necessary. + */ + /* virtual */ void EditBoxLostFocus(); + /** Return driver name * @return driver name */ diff --git a/src/video/cocoa/cocoa_v.mm b/src/video/cocoa/cocoa_v.mm index 8e7b7824e..11ba8ab84 100644 --- a/src/video/cocoa/cocoa_v.mm +++ b/src/video/cocoa/cocoa_v.mm @@ -494,6 +494,20 @@ bool VideoDriver_Cocoa::AfterBlitterChange() return this->ChangeResolution(_screen.width, _screen.height); } +/** + * An edit box lost the input focus. Abort character compositing if necessary. + */ +void VideoDriver_Cocoa::EditBoxLostFocus() +{ + if (_cocoa_subdriver != NULL) { + if ([ _cocoa_subdriver->cocoaview respondsToSelector:@selector(inputContext) ]) { + [ [ _cocoa_subdriver->cocoaview performSelector:@selector(inputContext) ] performSelector:@selector(discardMarkedText) ]; + } else { + [ [ NSInputManager currentInputManager ] markedTextAbandoned:_cocoa_subdriver->cocoaview ]; + } + } +} + /** * Catch asserts prior to initialization of the videodriver. * -- cgit v1.2.3-70-g09d2