]> git.eshelyaron.com Git - emacs.git/commitdiff
A (hopefully) better fix for bug #1280.
authorEli Zaretskii <eliz@gnu.org>
Wed, 7 Nov 2012 21:12:25 +0000 (23:12 +0200)
committerEli Zaretskii <eliz@gnu.org>
Wed, 7 Nov 2012 21:12:25 +0000 (23:12 +0200)
 src/w32fns.c (modifier_set): Don't report modifiers from toggle key,
 such as Scroll Lock, if the respective keys are treated as
 function keys, not as modifiers.  This avoids destroying non-ASCII
 keyboard input when Scroll Lock is toggled ON.

src/ChangeLog
src/w32fns.c

index c1b42e276c59efcb5ae1a07b8b7f98d759ab8a77..04b66ba7cc7ad99ef629b03e53d11dd9e44937d1 100644 (file)
@@ -1,10 +1,9 @@
 2012-11-07  Eli Zaretskii  <eliz@gnu.org>
 
-       * w32fns.c (w32_wnd_proc): Don't directly handle key chords
-       including modifiers from toggle key, such as Scroll Lock, if the
-       respective keys are treated as function keys, not as modifiers.
-       This avoids destroying non-ASCII keyboard input when Scroll Lock
-       is toggled ON.  (Bug#1280)
+       * w32fns.c (modifier_set): Don't report modifiers from toggle key,
+       such as Scroll Lock, if the respective keys are treated as
+       function keys, not as modifiers.  This avoids destroying non-ASCII
+       keyboard input when Scroll Lock is toggled ON.  (Bug#1280)
        (modifier_set): Do not omit checking the Num Lock key.
 
 2012-11-07  Dmitry Antipov  <dmantipov@yandex.ru>
index dc395551a4a72277bea85b76d81f73326b982da5..b5e717f8980f1eaad1ce4eb7b2c14a1435e15574 100644 (file)
@@ -2085,8 +2085,28 @@ sync_modifiers (void)
 static int
 modifier_set (int vkey)
 {
-  if (vkey == VK_CAPITAL || vkey == VK_SCROLL || vkey == VK_NUMLOCK)
-    return (GetKeyState (vkey) & 0x1);
+  if (vkey == VK_CAPITAL)
+    {
+      if (NILP (Vw32_enable_caps_lock))
+       return 0;
+      else
+       return (GetKeyState (vkey) & 0x1);
+    }
+  if (vkey == VK_SCROLL)
+    {
+      if (NILP (Vw32_scroll_lock_modifier))
+       return 0;
+      else
+       return (GetKeyState (vkey) & 0x1);
+    }
+  if (vkey == VK_NUMLOCK)
+    {
+      if (NILP (Vw32_enable_num_lock))
+       return 0;
+      else
+       return (GetKeyState (vkey) & 0x1);
+    }
+
   if (!modifiers_recorded)
     return (GetKeyState (vkey) & 0x8000);
 
@@ -2974,21 +2994,12 @@ w32_wnd_proc (HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam)
            {
              DWORD modifiers = construct_console_modifiers ();
 
-             /* Always let TranslateMessage handle AltGr key chords;
-                for some reason, ToAscii doesn't always process AltGr
-                chords correctly.  */
-             if ((!NILP (Vw32_recognize_altgr)
-                  && modifier_set (VK_LCONTROL) && modifier_set (VK_RMENU))
-                 /* If a toggle key is used as a function key, let
-                    TranslateMessage handle keys pressed while the
-                    toggled key is ON.  This avoids munging non-ASCII
-                    keys, like interpreting them as ASCII keys below,
-                    when, e.g., Scroll Lock is toggled ON.  */
-                 || (NILP (Vw32_scroll_lock_modifier)
-                     && modifier_set (VK_SCROLL))
-                 || (NILP (Vw32_enable_num_lock) && modifier_set (VK_NUMLOCK))
-                 || (NILP (Vw32_enable_caps_lock) && modifier_set (VK_CAPITAL)))
+             if (!NILP (Vw32_recognize_altgr)
+                 && modifier_set (VK_LCONTROL) && modifier_set (VK_RMENU))
                {
+                 /* Always let TranslateMessage handle AltGr key chords;
+                    for some reason, ToAscii doesn't always process AltGr
+                    chords correctly.  */
                  windows_translate = 1;
                }
              else if ((modifiers & (~SHIFT_PRESSED & ~CAPSLOCK_ON)) != 0)