diff options
author | Ek Kato <ek.kato@gmail.com> | 2013-08-16 09:54:34 -0700 |
---|---|---|
committer | John Ralls <jralls@ceridwen.us> | 2013-08-16 11:18:29 -0700 |
commit | 08042ea830da88aa192e3e8d99aa7af8863aeb16 (patch) | |
tree | 278758c9b1835066795d47ce40e71083a6741562 /modules/input | |
parent | 77059dbaba04dfaf234032d7ea9ca53c137096ca (diff) | |
download | gtk+-08042ea830da88aa192e3e8d99aa7af8863aeb16.tar.gz |
Bug 705750 Quartz input method doesn't work correctly for Chinese characters
Modified from original for Gtk3.
Diffstat (limited to 'modules/input')
-rw-r--r-- | modules/input/imquartz.c | 103 |
1 files changed, 66 insertions, 37 deletions
diff --git a/modules/input/imquartz.c b/modules/input/imquartz.c index 06ebc6837b..febf41bc69 100644 --- a/modules/input/imquartz.c +++ b/modules/input/imquartz.c @@ -126,48 +126,13 @@ quartz_get_preedit_string (GtkIMContext *context, } static gboolean -quartz_filter_keypress (GtkIMContext *context, - GdkEventKey *event) +output_result (GtkIMContext *context, + GdkWindow *win) { GtkIMContextQuartz *qc = GTK_IM_CONTEXT_QUARTZ (context); gboolean retval = FALSE; - NSView *nsview; - GdkWindow *win; gchar *fixed_str, *marked_str; - GTK_NOTE (MISC, g_print ("quartz_filter_keypress\n")); - - if (!qc->client_window) - return FALSE; - - nsview = gdk_quartz_window_get_nsview (qc->client_window); - if (GDK_IS_WINDOW (nsview)) - /* it gets GDK_WINDOW in some cases */ - return gtk_im_context_filter_keypress (qc->slave, event); - else - win = (GdkWindow *)[ (GdkQuartzView *)nsview gdkWindow]; - GTK_NOTE (MISC, g_print ("client_window: %p, win: %p, nsview: %p\n", - qc->client_window, win, nsview)); - - NSEvent *nsevent = gdk_quartz_event_get_nsevent ((GdkEvent *)event); - if (!nsevent) - return gtk_im_context_filter_keypress (qc->slave, event); - - if (event->type == GDK_KEY_RELEASE) - return FALSE; - - if (event->hardware_keycode == 55) /* Command */ - return FALSE; - - NSEventType etype = [nsevent type]; - if (etype == NSKeyDown) - [nsview keyDown: nsevent]; - /* JIS_Eisu || JIS_Kana */ - if (event->hardware_keycode == 102 || event->hardware_keycode == 104) - return FALSE; - - GTK_NOTE (MISC, - g_print ("quartz_filter_keypress: getting tic-insert-text\n")); fixed_str = g_object_get_data (G_OBJECT (win), TIC_INSERT_TEXT); marked_str = g_object_get_data (G_OBJECT (win), TIC_MARKED_TEXT); if (fixed_str) @@ -203,10 +168,74 @@ quartz_filter_keypress (GtkIMContext *context, g_signal_emit_by_name (context, "preedit_changed"); retval = TRUE; } + if (!fixed_str && !marked_str) + { + if (qc->preedit_str && strlen (qc->preedit_str) > 0) + retval = TRUE; + } + g_free (fixed_str); g_free (marked_str); + return retval; +} + +static gboolean +quartz_filter_keypress (GtkIMContext *context, + GdkEventKey *event) +{ + GtkIMContextQuartz *qc = GTK_IM_CONTEXT_QUARTZ (context); + gboolean retval; + NSView *nsview; + GdkWindow *win; + + GTK_NOTE (MISC, g_print ("quartz_filter_keypress\n")); + + if (!qc->client_window) + return FALSE; + + nsview = gdk_quartz_window_get_nsview (qc->client_window); + if (GDK_IS_WINDOW (nsview)) + /* it gets GDK_WINDOW in some cases */ + return gtk_im_context_filter_keypress (qc->slave, event); + else + win = (GdkWindow *)[ (GdkQuartzView *)nsview gdkWindow]; + GTK_NOTE (MISC, g_print ("client_window: %p, win: %p, nsview: %p\n", + qc->client_window, win, nsview)); + + NSEvent *nsevent = gdk_quartz_event_get_nsevent ((GdkEvent *)event); + + if (!nsevent) + { + if (event->hardware_keycode == 0 && event->keyval == 0xffffff) + /* update text input changes by mouse events */ + output_result(context, win); + else + return gtk_im_context_filter_keypress (qc->slave, event); + } + + if (event->type == GDK_KEY_RELEASE) + return FALSE; + + if (event->hardware_keycode == 55) /* Command */ + return FALSE; + + NSEventType etype = [nsevent type]; + if (etype == NSKeyDown) + { + g_object_set_data (G_OBJECT (win), TIC_IN_KEY_DOWN, + GUINT_TO_POINTER (TRUE)); + [nsview keyDown: nsevent]; + } + /* JIS_Eisu || JIS_Kana */ + if (event->hardware_keycode == 102 || event->hardware_keycode == 104) + return FALSE; + + retval = output_result(context, win); + g_object_set_data (G_OBJECT (win), TIC_IN_KEY_DOWN, + GUINT_TO_POINTER (FALSE)); GTK_NOTE (MISC, g_print ("quartz_filter_keypress done\n")); + return retval; } |