summaryrefslogtreecommitdiff
path: root/clutter/clutter
diff options
context:
space:
mode:
authorCarlos Garnacho <carlosg@gnome.org>2018-03-13 15:44:19 +0100
committerJonas Ã…dahl <jadahl@gmail.com>2018-04-03 15:00:01 +0000
commitde7d7bbf3da5e7f4feb016623c012cba8ccd1e33 (patch)
treee7d36d1b247d7d36266b384990dff4cccedeb935 /clutter/clutter
parent7ac551cd054465db174593cd6e8287d2f4a2bd94 (diff)
downloadmutter-de7d7bbf3da5e7f4feb016623c012cba8ccd1e33.tar.gz
clutter: Apply input hints/purpose on ClutterTextInputFocus focus in
And make the ClutterText-level properties independent from the input focus, as those properties can be set anytime, not just when the ClutterText actor is focused. https://gitlab.gnome.org/GNOME/mutter/issues/66 Closes: #66 (cherry picked from commit 3684f6b0ac6157f2f85e0ae473d834fa474fd72d)
Diffstat (limited to 'clutter/clutter')
-rw-r--r--clutter/clutter/clutter-text.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/clutter/clutter/clutter-text.c b/clutter/clutter/clutter-text.c
index 4a6a74a0c..744d8a323 100644
--- a/clutter/clutter/clutter-text.c
+++ b/clutter/clutter/clutter-text.c
@@ -2830,6 +2830,10 @@ clutter_text_key_focus_in (ClutterActor *actor)
if (method && priv->editable)
{
clutter_input_method_focus_in (method, priv->input_focus);
+ clutter_input_focus_set_content_purpose (priv->input_focus,
+ priv->input_purpose);
+ clutter_input_focus_set_content_hints (priv->input_focus,
+ priv->input_hints);
update_cursor_location (CLUTTER_TEXT (actor));
}
@@ -6523,7 +6527,9 @@ clutter_text_set_input_hints (ClutterText *self,
g_return_if_fail (CLUTTER_IS_TEXT (self));
self->priv->input_hints = hints;
- clutter_input_focus_set_content_hints (self->priv->input_focus, hints);
+
+ if (clutter_input_focus_is_focused (self->priv->input_focus))
+ clutter_input_focus_set_content_hints (self->priv->input_focus, hints);
g_object_notify_by_pspec (G_OBJECT (self), obj_props[PROP_INPUT_HINTS]);
}
@@ -6542,7 +6548,9 @@ clutter_text_set_input_purpose (ClutterText *self,
g_return_if_fail (CLUTTER_IS_TEXT (self));
self->priv->input_purpose = purpose;
- clutter_input_focus_set_content_purpose (self->priv->input_focus, purpose);
+
+ if (clutter_input_focus_is_focused (self->priv->input_focus))
+ clutter_input_focus_set_content_purpose (self->priv->input_focus, purpose);
g_object_notify_by_pspec (G_OBJECT (self), obj_props[PROP_INPUT_PURPOSE]);
}