From 0ef7d0788084ad8054418300eaa76fd1861dfe51 Mon Sep 17 00:00:00 2001 From: Benjamin Otte Date: Tue, 8 Jan 2019 00:36:58 +0100 Subject: [PATCH] immodule: Check if module matches display When loading IM modules from environment variables or GtkSettings, we would accept "xim" on Wayland. That is a bad idea. --- gtk/gtkimmodule.c | 21 +++++++++++++-------- 1 file changed, 13 insertions(+), 8 deletions(-) diff --git a/gtk/gtkimmodule.c b/gtk/gtkimmodule.c index de88af8ba1..d626a7ebc6 100644 --- a/gtk/gtkimmodule.c +++ b/gtk/gtkimmodule.c @@ -161,13 +161,19 @@ match_backend (GdkDisplay *display, } static const gchar * -lookup_immodule (gchar **immodules_list) +lookup_immodule (GdkDisplay *display, + gchar **immodules_list) { - while (immodules_list && *immodules_list) + guint i; + + for (i = 0; immodules_list[i]; i++) { - if (g_strcmp0 (*immodules_list, SIMPLE_ID) == 0) + if (!match_backend (display, immodules_list[i])) + continue; + + if (g_strcmp0 (immodules_list[i], SIMPLE_ID) == 0) return SIMPLE_ID; - else if (g_strcmp0 (*immodules_list, NONE_ID) == 0) + else if (g_strcmp0 (immodules_list[i], NONE_ID) == 0) return NONE_ID; else { @@ -175,11 +181,10 @@ lookup_immodule (gchar **immodules_list) GIOExtension *ext; ep = g_io_extension_point_lookup (GTK_IM_MODULE_EXTENSION_POINT_NAME); - ext = g_io_extension_point_get_extension_by_name (ep, *immodules_list); + ext = g_io_extension_point_get_extension_by_name (ep, immodules_list[i]); if (ext) return g_io_extension_get_name (ext); } - immodules_list++; } return NULL; @@ -207,7 +212,7 @@ _gtk_im_module_get_default_context_id (GdkDisplay *display) { char **immodules; immodules = g_strsplit (envvar, ":", 0); - context_id = lookup_immodule (immodules); + context_id = lookup_immodule (display, immodules); g_strfreev (immodules); if (context_id) @@ -222,7 +227,7 @@ _gtk_im_module_get_default_context_id (GdkDisplay *display) char **immodules; immodules = g_strsplit (tmp, ":", 0); - context_id = lookup_immodule (immodules); + context_id = lookup_immodule (display, immodules); g_strfreev (immodules); g_free (tmp);