[PATCH 1/6] user32: Add a default ActivateKeyboardLayout implementation.
Rémi Bernon
rbernon at codeweavers.com
Mon May 3 04:37:56 CDT 2021
Signed-off-by: Rémi Bernon <rbernon at codeweavers.com>
---
dlls/user32/driver.c | 2 +-
dlls/user32/input.c | 11 ++++++++---
2 files changed, 9 insertions(+), 4 deletions(-)
diff --git a/dlls/user32/driver.c b/dlls/user32/driver.c
index c075a49a350..f683cf25b7e 100644
--- a/dlls/user32/driver.c
+++ b/dlls/user32/driver.c
@@ -189,7 +189,7 @@ void USER_unload_driver(void)
static HKL CDECL nulldrv_ActivateKeyboardLayout( HKL layout, UINT flags )
{
- return 0;
+ return (HKL)~0; /* use default implementation */
}
static void CDECL nulldrv_Beep(void)
diff --git a/dlls/user32/input.c b/dlls/user32/input.c
index 97be83369d9..ff90bc6f343 100644
--- a/dlls/user32/input.c
+++ b/dlls/user32/input.c
@@ -1310,11 +1310,16 @@ INT WINAPI ToAsciiEx( UINT virtKey, UINT scanCode, const BYTE *lpKeyState,
/**********************************************************************
* ActivateKeyboardLayout (USER32.@)
*/
-HKL WINAPI ActivateKeyboardLayout(HKL hLayout, UINT flags)
+HKL WINAPI ActivateKeyboardLayout( HKL layout, UINT flags )
{
- TRACE_(keyboard)("(%p, %d)\n", hLayout, flags);
+ HKL old_layout;
- return USER_Driver->pActivateKeyboardLayout(hLayout, flags);
+ TRACE_(keyboard)( "layout %p, flags %x\n", layout, flags );
+
+ if ((old_layout = USER_Driver->pActivateKeyboardLayout( layout, flags )) != (HKL)~0)
+ return old_layout;
+
+ return get_locale_kbd_layout();
}
/**********************************************************************
--
2.31.0
More information about the wine-devel
mailing list