diff options
Diffstat (limited to 'xorg-server/hw/xwin/winkeybd.c')
| -rw-r--r-- | xorg-server/hw/xwin/winkeybd.c | 37 | 
1 files changed, 25 insertions, 12 deletions
| diff --git a/xorg-server/hw/xwin/winkeybd.c b/xorg-server/hw/xwin/winkeybd.c index 611ea5d55..aa5b9a53a 100644 --- a/xorg-server/hw/xwin/winkeybd.c +++ b/xorg-server/hw/xwin/winkeybd.c @@ -75,6 +75,20 @@ winTranslateKey (WPARAM wParam, LPARAM lParam, int *piScanCode)    int		iKeyFixupEx = g_iKeyMap[wParam * WIN_KEYMAP_COLS + 2];    int		iParamScanCode = LOBYTE (HIWORD (lParam)); +/* WM_ key messages faked by Vista speech recognition (WSR) don't have a + * scan code. + * + * Vocola 3 (Rick Mohr's supplement to WSR) uses + * System.Windows.Forms.SendKeys.SendWait(), which appears always to give a + * scan code of 1 + */ +  if (iParamScanCode <= 1) +    { +      iParamScanCode = MapVirtualKeyEx(wParam, +				       /*MAPVK_VK_TO_VSC*/0, +				       GetKeyboardLayout(0)); +    } +    /* Branch on special extended, special non-extended, or normal key */    if ((HIWORD (lParam) & KF_EXTENDED) && iKeyFixupEx)      *piScanCode = iKeyFixupEx; @@ -223,13 +237,13 @@ winKeybdProc (DeviceIntPtr pDeviceInt, int iState)        /* FIXME: Maybe we should use winGetKbdLeds () here? */        defaultKeyboardControl.leds = g_winInfo.keyboard.leds; -      winErrorFVerb(2, "Rules = \"%s\" Model = \"%s\" Layout = \"%s\"" -                    " Variant = \"%s\" Options = \"%s\"\n", -                    g_winInfo.xkb.rules ? g_winInfo.xkb.rules : "none", -                    g_winInfo.xkb.model ? g_winInfo.xkb.model : "none", -                    g_winInfo.xkb.layout ? g_winInfo.xkb.layout : "none", -                    g_winInfo.xkb.variant ? g_winInfo.xkb.variant : "none", -                    g_winInfo.xkb.options ? g_winInfo.xkb.options : "none"); +      winDebug("Rules = \"%s\" Model = \"%s\" Layout = \"%s\"" +               " Variant = \"%s\" Options = \"%s\"\n", +               g_winInfo.xkb.rules ? g_winInfo.xkb.rules : "none", +               g_winInfo.xkb.model ? g_winInfo.xkb.model : "none", +               g_winInfo.xkb.layout ? g_winInfo.xkb.layout : "none", +               g_winInfo.xkb.variant ? g_winInfo.xkb.variant : "none", +               g_winInfo.xkb.options ? g_winInfo.xkb.options : "none");        InitKeyboardDeviceStruct (pDeviceInt,                                  &g_winInfo.xkb, @@ -245,9 +259,10 @@ winKeybdProc (DeviceIntPtr pDeviceInt, int iState)          }        else          { -          winErrorFVerb (1, "winKeybdProc - Error initializing keyboard AutoRepeat\n"); +          winDebug ("winKeybdProc - Error initializing keyboard AutoRepeat\n");          } +	  XkbSetExtension(pDeviceInt, ProcessKeyboardEvent);        break;      case DEVICE_ON:  @@ -547,12 +562,10 @@ winSendKeyEvent (DWORD dwKey, Bool fDown)    nevents = GetKeyboardEvents(events, g_pwinKeyboard, fDown ? KeyPress : KeyRelease, dwKey + MIN_KEYCODE);    for (i = 0; i < nevents; i++) -    mieqEnqueue(g_pwinKeyboard, events[i].event); +    mieqEnqueue(g_pwinKeyboard, (InternalEvent*)(events + i)->event); -#if CYGDEBUG -  ErrorF("winSendKeyEvent: dwKey: %d, fDown: %d, nEvents %d\n", +  winDebug("winSendKeyEvent: dwKey: %d, fDown: %d, nEvents %d\n",            dwKey, fDown, nevents); -#endif  }  BOOL winCheckKeyPressed(WPARAM wParam, LPARAM lParam) | 
