diff options
author | Bram Moolenaar <Bram@vim.org> | 2022-06-25 13:48:25 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2022-06-25 13:48:25 +0100 |
commit | 7bb6d56cfc8ac82dea323f6799a773d7fa3286a8 (patch) | |
tree | ee4ab62a83c542dd361b5cd5db9bd0673d5e63d4 /src/gui_w32.c | |
parent | 61e3784819d3776ec6fb40d97a12a1bb659e8143 (diff) | |
download | vim-git-7bb6d56cfc8ac82dea323f6799a773d7fa3286a8.tar.gz |
patch 8.2.5159: fix for CTRL-key combinations causes problemsv8.2.5159
Problem: Fix for CTRL-key combinations causes more problems than it solves.
Solution: Roll back the change.
Diffstat (limited to 'src/gui_w32.c')
-rw-r--r-- | src/gui_w32.c | 28 |
1 files changed, 9 insertions, 19 deletions
diff --git a/src/gui_w32.c b/src/gui_w32.c index ae419053b..7bdbf418d 100644 --- a/src/gui_w32.c +++ b/src/gui_w32.c @@ -2055,21 +2055,21 @@ process_message(void) int i; UINT scan_code; - // Construct the keyboard state table, the modifiers can and will - // affect the character translation performed by ToUnicode. - // Eg. With a Russian keyboard layout pressing 'n' produces 'т' but - // Ctrl+p produces 'p', this is essential for the keybindings to - // work. + // Construct the state table with only a few modifiers, we don't + // really care about the presence of Ctrl/Alt as those modifiers are + // handled by Vim separately. memset(keyboard_state, 0, 256); - if (GetKeyState(VK_CONTROL) & 0x8000) - keyboard_state[VK_CONTROL] = 0x80; if (GetKeyState(VK_SHIFT) & 0x8000) keyboard_state[VK_SHIFT] = 0x80; if (GetKeyState(VK_CAPITAL) & 0x0001) keyboard_state[VK_CAPITAL] = 0x01; - // Alt-Gr is synthesized as (Right)Alt + Ctrl. - if ((GetKeyState(VK_RMENU) & 0x8000) && keyboard_state[VK_CONTROL]) + // Alt-Gr is synthesized as Alt + Ctrl. + if ((GetKeyState(VK_RMENU) & 0x8000) + && (GetKeyState(VK_CONTROL) & 0x8000)) + { keyboard_state[VK_MENU] = 0x80; + keyboard_state[VK_CONTROL] = 0x80; + } // Translate the virtual key according to the current keyboard // layout. @@ -2079,16 +2079,6 @@ process_message(void) // If this is a dead key ToUnicode returns a negative value. len = ToUnicode(vk, scan_code, keyboard_state, ch, ARRAY_LENGTH(ch), 0); - if (len == 0 && keyboard_state[VK_CONTROL]) - { - // Handle one more special case: pressing Ctrl+key may - // generate an unprintable ASCII character, try again without - // the modifier to get the pressed key value. - keyboard_state[VK_CONTROL] = 0; - len = ToUnicode(vk, scan_code, keyboard_state, ch, - ARRAY_LENGTH(ch), 0); - keyboard_state[VK_CONTROL] = 0x80; - } dead_key = len < 0; if (len <= 0) |