From 7830e24b1e974f802e494928a76798a108b14899 Mon Sep 17 00:00:00 2001 From: "Richard M. Stallman" Date: Mon, 10 Jun 1996 17:35:37 +0000 Subject: [PATCH] (sync_modifiers): New function. (w32_wnd_proc): Synchronize modifiers on each key down. --- src/w32fns.c | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/src/w32fns.c b/src/w32fns.c index a2f1ed77d74..e3ad7a8f757 100644 --- a/src/w32fns.c +++ b/src/w32fns.c @@ -2779,6 +2779,23 @@ reset_modifiers () keyboard focus. */ } +/* Synchronize modifier state with what is reported with the current + keystroke. Even if we cannot distinguish between left and right + modifier keys, we know that, if no modifiers are set, then neither + the left or right modifier should be set. */ +static void +sync_modifiers () +{ + if (!modifiers_recorded) + return; + + if (!(GetKeyState (VK_CONTROL) & 0x8000)) + modifiers[EMACS_RCONTROL] = modifiers[EMACS_LCONTROL] = 0; + + if (!(GetKeyState (VK_MENU) & 0x8000)) + modifiers[EMACS_RMENU] = modifiers[EMACS_LMENU] = 0; +} + static int modifier_set (int vkey) { @@ -2948,6 +2965,9 @@ win32_wnd_proc (hwnd, msg, wParam, lParam) case WM_KEYDOWN: case WM_SYSKEYDOWN: + /* Synchronize modifiers with current keystroke. */ + sync_modifiers (); + record_keydown (wParam, lParam); wParam = map_keypad_keys (wParam, lParam); -- 2.39.2