[PATCH 3/4] user32: Adjust ToUnicodeEx control code translation.
Rémi Bernon
rbernon at codeweavers.com
Tue May 4 03:32:06 CDT 2021
To match VkKeyScanW and pass corresponding tests.
Signed-off-by: Rémi Bernon <rbernon at codeweavers.com>
---
dlls/user32/input.c | 6 +++++-
1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/dlls/user32/input.c b/dlls/user32/input.c
index 0304b7fb49d..743e8fe8483 100644
--- a/dlls/user32/input.c
+++ b/dlls/user32/input.c
@@ -1300,8 +1300,11 @@ INT WINAPI ToUnicodeEx( UINT virt, UINT scan, const BYTE *state,
case VK_OEM_4: buffer[0] = 0x1b; break;
case VK_OEM_5: buffer[0] = 0x1c; break;
case VK_OEM_6: buffer[0] = 0x1d; break;
- case VK_SUBTRACT: buffer[0] = 0x1e; break;
+ case '6': buffer[0] = shift ? 0x1e : 0; break;
+ case VK_OEM_MINUS: buffer[0] = shift ? 0x1f : 0; break;
+ case VK_BACK: buffer[0] = 0x7f; break;
case VK_RETURN: buffer[0] = shift ? 0 : '\n'; break;
+ case '2': buffer[0] = shift ? 0xffff : 0xf000; break;
case VK_SPACE: buffer[0] = ' '; break;
default:
if (virt >= 'A' && virt <= 'Z') buffer[0] = virt - 'A' + 1;
@@ -1312,6 +1315,7 @@ INT WINAPI ToUnicodeEx( UINT virt, UINT scan, const BYTE *state,
else buffer[0] = 0;
buffer[1] = 0;
len = wcslen( buffer );
+ if (buffer[0] == 0xffff) buffer[0] = 0;
lstrcpynW( str, buffer, size );
TRACE_(keyboard)( "ret %d, str %s.\n", len, debugstr_w(str) );
--
2.31.0
More information about the wine-devel
mailing list