reposting this here, looking for someone to fix a long standing wine bug.
text [edited] again: well, this is just this: http://bugs.winehq.org/show_bug.cgi?id=2400 and should apply to today's cvs. i AM NOT the author!
it IS kinda urgent, since a lot of european keyboards are affected...
like hungarian, croatian, slovenian... all have "delete" key producing "<delete>,"
instead of "<delete>". this patch is just a "works here" workaround, see url for more details.
i got response from some people, so i fixed comments, but what needs to be tuned, according to mr. Dmitry Timoshkov, is that it should use symbolic key(sym) names instead of hardcoded numbers. seems like a trivial task for a programmer (which i am not)
so, anybody up to it?
Changelog:
* dlls/x11drv/keyboard.c
Arpad Biro <[EMAIL PROTECTED]>
(modified to current cvs by Marin Glibic <[EMAIL PROTECTED]>)
This fixes the problem is that when NumLock is active, both Del keys perform a "delete" action _and_ insert a comma (the decimal character).
--- dlls/x11drv/keyboard.c.orig 2005-05-05 23:33:23.000000000 +0200
+++ dlls/x11drv/keyboard.c 2005-05-05 23:38:44.000000000 +0200
@@ -1067,11 +1067,14 @@
else
XLookupString(e, NULL, 0, &keysym, NULL);
- if ((keysym >= 0xFFAE) && (keysym <= 0xFFB9) && (keysym != 0xFFAF)
- && (e->state & NumLockMask))
- /* Only the Keypad keys 0-9 and . send different keysyms
- * depending on the NumLock state */
- return nonchar_key_vkey[keysym & 0xFF];
+ if (e->state & NumLockMask) /* NumLock is active */
+ { if (keysym == 0xFFAC) /* Numeric Del pressed */
+ return keyc2vkey[0x3B]; /* comma */
+ if ((keysym >= 0xFFAE) && (keysym <= 0xFFB9) && (keysym != 0xFFAF))
+ /* Only the Keypad keys 0-9 and . send different keysyms
+ * depending on the NumLock state */
+ return nonchar_key_vkey[keysym & 0xFF];
+ }
TRACE_(key)("e->keycode = %x\n", e->keycode);
