summaryrefslogtreecommitdiff
path: root/clutter
diff options
context:
space:
mode:
authorCarlos Garnacho <carlosg@gnome.org>2018-02-11 21:56:30 +0100
committerCarlos Garnacho <carlosg@gnome.org>2018-02-12 14:44:30 +0100
commit37aab9280af442935ef23ad27eeba8c4fb1ecca7 (patch)
tree47417aebe9e70a360f32c115ebaba1894c5ec4d3 /clutter
parent49e8bc8a52ac279b81da93bf481168a3cf2f570e (diff)
downloadmutter-37aab9280af442935ef23ad27eeba8c4fb1ecca7.tar.gz
clutter/text: Be more pervasive at updating input method state
More concretely, ensure preedit text goes away after commit/focus_out, and update cursor position right after focus_in.
Diffstat (limited to 'clutter')
-rw-r--r--clutter/clutter/clutter-text.c11
1 files changed, 9 insertions, 2 deletions
diff --git a/clutter/clutter/clutter-text.c b/clutter/clutter/clutter-text.c
index 854b413b7..48904a47d 100644
--- a/clutter/clutter/clutter-text.c
+++ b/clutter/clutter/clutter-text.c
@@ -336,6 +336,7 @@ clutter_text_input_focus_commit_text (ClutterInputFocus *focus,
clutter_text_delete_selection (clutter_text);
clutter_text_insert_text (clutter_text, text,
clutter_text_get_cursor_position (clutter_text));
+ clutter_text_set_preedit_string (clutter_text, NULL, NULL, 0);
}
}
@@ -2824,7 +2825,10 @@ clutter_text_key_focus_in (ClutterActor *actor)
ClutterInputMethod *method = clutter_backend_get_input_method (backend);
if (method && priv->editable)
- clutter_input_method_focus_in (method, priv->input_focus);
+ {
+ clutter_input_method_focus_in (method, priv->input_focus);
+ update_cursor_location (CLUTTER_TEXT (actor));
+ }
priv->has_focus = TRUE;
@@ -2841,7 +2845,10 @@ clutter_text_key_focus_out (ClutterActor *actor)
priv->has_focus = FALSE;
if (priv->editable && clutter_input_focus_is_focused (priv->input_focus))
- clutter_input_method_focus_out (method);
+ {
+ clutter_text_set_preedit_string (CLUTTER_TEXT (actor), NULL, NULL, 0);
+ clutter_input_method_focus_out (method);
+ }
clutter_text_queue_redraw (actor);
}