From: Matthias Clasen Date: Thu, 18 Feb 2021 20:33:01 +0000 (-0500) Subject: imwayland: Be careful about cursor positions X-Git-Tag: archive/raspbian/4.4.1+ds1-2+rpi1~1^2~83^2^2~387^2~2 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=3ee5354e0f8a127e284e2d96b379b9f675f20cf7;p=gtk4.git imwayland: Be careful about cursor positions We don't want to hand out cursor positions based on the original preedit text and then tweak the text to be different. --- diff --git a/gtk/gtkimcontextwayland.c b/gtk/gtkimcontextwayland.c index 397909064d..0bee5162d9 100644 --- a/gtk/gtkimcontextwayland.c +++ b/gtk/gtkimcontextwayland.c @@ -609,7 +609,7 @@ gtk_im_context_wayland_get_preedit_string (GtkIMContext *context, int *cursor_pos) { GtkIMContextWayland *context_wayland = GTK_IM_CONTEXT_WAYLAND (context); - const char *preedit_str; + char *preedit_str; if (attrs) *attrs = NULL; @@ -628,10 +628,8 @@ gtk_im_context_wayland_get_preedit_string (GtkIMContext *context, } preedit_str = - context_wayland->current_preedit.text ? context_wayland->current_preedit.text : ""; + tweak_preedit (context_wayland->current_preedit.text ? context_wayland->current_preedit.text : ""); - if (str) - *str = tweak_preedit (preedit_str); if (cursor_pos) *cursor_pos = g_utf8_strlen (preedit_str, context_wayland->current_preedit.cursor_begin); @@ -665,6 +663,10 @@ gtk_im_context_wayland_get_preedit_string (GtkIMContext *context, pango_attr_list_insert (*attrs, cursor); } } + if (str) + *str = preedit_str; + else + g_free (preedit_str); } static gboolean