emacs-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

master 2e60ca3713: Correctly translate GDK virtual modifiers when using


From: Po Lu
Subject: master 2e60ca3713: Correctly translate GDK virtual modifiers when using native input
Date: Sat, 8 Jan 2022 07:45:10 -0500 (EST)

branch: master
commit 2e60ca3713af49cd8b3bfe5cda9ad51f6be6046a
Author: Po Lu <luangruo@yahoo.com>
Commit: Po Lu <luangruo@yahoo.com>

    Correctly translate GDK virtual modifiers when using native input
    
    * src/gtkutil.c (xg_virtual_mods_to_x): New function.
    (xg_widget_key_press_event_cb): Translate modifiers to X first.
---
 src/gtkutil.c | 29 +++++++++++++++++++++++++++--
 1 file changed, 27 insertions(+), 2 deletions(-)

diff --git a/src/gtkutil.c b/src/gtkutil.c
index f236227514..aaa2933f86 100644
--- a/src/gtkutil.c
+++ b/src/gtkutil.c
@@ -6024,6 +6024,27 @@ xg_add_virtual_mods (struct x_display_info *dpyinfo, 
GdkEventKey *key)
     key->state |= GDK_HYPER_MASK;
 }
 
+static unsigned int
+xg_virtual_mods_to_x (struct x_display_info *dpyinfo, guint virtual)
+{
+  unsigned int modifiers = virtual & ~(GDK_SUPER_MASK
+                                      | GDK_META_MASK
+                                      | GDK_HYPER_MASK
+                                      | GDK_MOD2_MASK
+                                      | GDK_MOD3_MASK
+                                      | GDK_MOD4_MASK
+                                      | GDK_MOD5_MASK);
+
+  if (virtual & GDK_META_MASK)
+    modifiers |= dpyinfo->meta_mod_mask;
+  if (virtual & GDK_SUPER_MASK)
+    modifiers |= dpyinfo->super_mod_mask;
+  if (virtual & GDK_HYPER_MASK)
+    modifiers |= dpyinfo->hyper_mod_mask;
+
+  return modifiers;
+}
+
 static void
 xg_im_context_commit (GtkIMContext *imc, gchar *str,
                      gpointer user_data)
@@ -6093,6 +6114,7 @@ xg_widget_key_press_event_cb (GtkWidget *widget, GdkEvent 
*event,
   struct frame *f = NULL;
   union buffered_input_event inev;
   guint keysym = event->key.keyval;
+  unsigned int xstate;
   gunichar *cb;
   ptrdiff_t i;
   glong len;
@@ -6117,8 +6139,11 @@ xg_widget_key_press_event_cb (GtkWidget *widget, 
GdkEvent *event,
   EVENT_INIT (inev.ie);
   XSETFRAME (inev.ie.frame_or_window, f);
 
-  inev.ie.modifiers |= x_x_to_emacs_modifiers (FRAME_DISPLAY_INFO (f),
-                                              event->key.state);
+  xstate = xg_virtual_mods_to_x (FRAME_DISPLAY_INFO (f),
+                                event->key.state);
+
+  inev.ie.modifiers
+    |= x_x_to_emacs_modifiers (FRAME_DISPLAY_INFO (f), xstate);
 
   /* First deal with keysyms which have defined
      translations to characters.  */



reply via email to

[Prev in Thread] Current Thread [Next in Thread]