|
|
@ -38,12 +38,6 @@ keyboard and mouse stuff
|
|
|
|
|
|
|
|
|
|
|
|
#include "rdp.h"
|
|
|
|
#include "rdp.h"
|
|
|
|
|
|
|
|
|
|
|
|
#if 1
|
|
|
|
|
|
|
|
#define DEBUG_OUT_INPUT(arg)
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
#define DEBUG_OUT_INPUT(arg) ErrorF arg
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define LOG_LEVEL 1
|
|
|
|
#define LOG_LEVEL 1
|
|
|
|
#define LLOG(_level, _args) \
|
|
|
|
#define LLOG(_level, _args) \
|
|
|
|
do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0)
|
|
|
|
do { if (_level < LOG_LEVEL) { ErrorF _args ; } } while (0)
|
|
|
@ -76,22 +70,79 @@ static int g_delay_motion = 1; /* turn on or off */
|
|
|
|
#define MAX_KEY_CODE 255
|
|
|
|
#define MAX_KEY_CODE 255
|
|
|
|
#define NO_OF_KEYS ((MAX_KEY_CODE - MIN_KEY_CODE) + 1)
|
|
|
|
#define NO_OF_KEYS ((MAX_KEY_CODE - MIN_KEY_CODE) + 1)
|
|
|
|
#define GLYPHS_PER_KEY 2
|
|
|
|
#define GLYPHS_PER_KEY 2
|
|
|
|
/* control */
|
|
|
|
|
|
|
|
#define CONTROL_L_KEY_CODE 37
|
|
|
|
#define RDPSCAN_Tab 15
|
|
|
|
#define CONTROL_R_KEY_CODE 109
|
|
|
|
#define RDPSCAN_Return 28 /* ext is used to know KP or not */
|
|
|
|
/* shift */
|
|
|
|
#define RDPSCAN_Control 29 /* ext is used to know L or R */
|
|
|
|
#define SHIFT_L_KEY_CODE 50
|
|
|
|
#define RDPSCAN_Shift_L 42
|
|
|
|
#define SHIFT_R_KEY_CODE 62
|
|
|
|
#define RDPSCAN_Slash 53
|
|
|
|
/* win keys */
|
|
|
|
#define RDPSCAN_Shift_R 54
|
|
|
|
#define SUPER_L_KEY_CODE 115
|
|
|
|
#define RDPSCAN_KP_Multiply 55
|
|
|
|
#define SUPER_R_KEY_CODE 116
|
|
|
|
#define RDPSCAN_Alt 56 /* ext is used to know L or R */
|
|
|
|
/* alt */
|
|
|
|
#define RDPSCAN_Caps_Lock 58
|
|
|
|
#define ALT_L_KEY_CODE 64
|
|
|
|
#define RDPSCAN_Pause 69
|
|
|
|
#define ALT_R_KEY_CODE 113
|
|
|
|
#define RDPSCAN_Scroll_Lock 70
|
|
|
|
/* caps lock */
|
|
|
|
#define RDPSCAN_KP_7 71 /* KP7 or home */
|
|
|
|
#define CAPS_LOCK_KEY_CODE 66
|
|
|
|
#define RDPSCAN_KP_8 72 /* KP8 or up */
|
|
|
|
/* num lock */
|
|
|
|
#define RDPSCAN_KP_9 73 /* KP9 or page up */
|
|
|
|
#define NUM_LOCK_KEY_CODE 77
|
|
|
|
#define RDPSCAN_KP_4 75 /* KP4 or left */
|
|
|
|
|
|
|
|
#define RDPSCAN_KP_6 77 /* KP6 or right */
|
|
|
|
|
|
|
|
#define RDPSCAN_KP_1 79 /* KP1 or home */
|
|
|
|
|
|
|
|
#define RDPSCAN_KP_2 80 /* KP2 or up */
|
|
|
|
|
|
|
|
#define RDPSCAN_KP_3 81 /* KP3 or page down */
|
|
|
|
|
|
|
|
#define RDPSCAN_KP_0 82 /* KP0 or insert */
|
|
|
|
|
|
|
|
#define RDPSCAN_KP_Decimal 83 /* KP. or delete */
|
|
|
|
|
|
|
|
#define RDPSCAN_89 89
|
|
|
|
|
|
|
|
#define RDPSCAN_90 90
|
|
|
|
|
|
|
|
#define RDPSCAN_LWin 91
|
|
|
|
|
|
|
|
#define RDPSCAN_RWin 92
|
|
|
|
|
|
|
|
#define RDPSCAN_Menu 93
|
|
|
|
|
|
|
|
#define RDPSCAN_115 115
|
|
|
|
|
|
|
|
#define RDPSCAN_126 126
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
#define XSCAN_Tab 23
|
|
|
|
|
|
|
|
#define XSCAN_Return 36 /* above right shift */
|
|
|
|
|
|
|
|
#define XSCAN_Control_L 37
|
|
|
|
|
|
|
|
#define XSCAN_Shift_L 50
|
|
|
|
|
|
|
|
#define XSCAN_slash 61
|
|
|
|
|
|
|
|
#define XSCAN_Shift_R 62
|
|
|
|
|
|
|
|
#define XSCAN_KP_Multiply 63
|
|
|
|
|
|
|
|
#define XSCAN_Alt_L 64
|
|
|
|
|
|
|
|
#define XSCAN_Caps_Lock 66 /* caps lock */
|
|
|
|
|
|
|
|
#define XSCAN_Num_Lock 77 /* num lock */
|
|
|
|
|
|
|
|
#define XSCAN_KP_7 79
|
|
|
|
|
|
|
|
#define XSCAN_KP_8 80
|
|
|
|
|
|
|
|
#define XSCAN_KP_9 81
|
|
|
|
|
|
|
|
#define XSCAN_KP_4 83
|
|
|
|
|
|
|
|
#define XSCAN_KP_6 85
|
|
|
|
|
|
|
|
#define XSCAN_KP_1 87
|
|
|
|
|
|
|
|
#define XSCAN_KP_2 88
|
|
|
|
|
|
|
|
#define XSCAN_KP_3 89
|
|
|
|
|
|
|
|
#define XSCAN_KP_0 90
|
|
|
|
|
|
|
|
#define XSCAN_KP_Decimal 91
|
|
|
|
|
|
|
|
#define XSCAN_97 97
|
|
|
|
|
|
|
|
#define XSCAN_Enter 104 /* on keypad */
|
|
|
|
|
|
|
|
#define XSCAN_Control_R 105
|
|
|
|
|
|
|
|
#define XSCAN_KP_Divide 106
|
|
|
|
|
|
|
|
#define XSCAN_Print 107
|
|
|
|
|
|
|
|
#define XSCAN_Alt_R 108
|
|
|
|
|
|
|
|
#define XSCAN_Home 110
|
|
|
|
|
|
|
|
#define XSCAN_Up 111
|
|
|
|
|
|
|
|
#define XSCAN_Prior 112
|
|
|
|
|
|
|
|
#define XSCAN_Left 113
|
|
|
|
|
|
|
|
#define XSCAN_Right 114
|
|
|
|
|
|
|
|
#define XSCAN_End 115
|
|
|
|
|
|
|
|
#define XSCAN_Down 116
|
|
|
|
|
|
|
|
#define XSCAN_Next 117
|
|
|
|
|
|
|
|
#define XSCAN_Insert 118
|
|
|
|
|
|
|
|
#define XSCAN_Delete 119
|
|
|
|
|
|
|
|
#define XSCAN_Pause 127
|
|
|
|
|
|
|
|
#define XSCAN_129 129
|
|
|
|
|
|
|
|
#define XSCAN_LWin 133
|
|
|
|
|
|
|
|
#define XSCAN_RWin 134
|
|
|
|
|
|
|
|
#define XSCAN_Menu 135
|
|
|
|
|
|
|
|
#define XSCAN_LMeta 156
|
|
|
|
|
|
|
|
#define XSCAN_RMeta 156
|
|
|
|
|
|
|
|
|
|
|
|
#define N_PREDEFINED_KEYS \
|
|
|
|
#define N_PREDEFINED_KEYS \
|
|
|
|
(sizeof(g_kbdMap) / (sizeof(KeySym) * GLYPHS_PER_KEY))
|
|
|
|
(sizeof(g_kbdMap) / (sizeof(KeySym) * GLYPHS_PER_KEY))
|
|
|
@ -176,7 +227,7 @@ static KeySym g_kbdMap[] =
|
|
|
|
XK_L, NoSymbol,
|
|
|
|
XK_L, NoSymbol,
|
|
|
|
XK_semicolon, XK_colon,
|
|
|
|
XK_semicolon, XK_colon,
|
|
|
|
XK_apostrophe, XK_quotedbl,
|
|
|
|
XK_apostrophe, XK_quotedbl,
|
|
|
|
XK_grave, XK_asciitilde,
|
|
|
|
XK_grave, XK_asciitilde,
|
|
|
|
XK_Shift_L, NoSymbol, /* 50 */
|
|
|
|
XK_Shift_L, NoSymbol, /* 50 */
|
|
|
|
XK_backslash, XK_bar,
|
|
|
|
XK_backslash, XK_bar,
|
|
|
|
XK_Z, NoSymbol,
|
|
|
|
XK_Z, NoSymbol,
|
|
|
@ -224,31 +275,45 @@ static KeySym g_kbdMap[] =
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
XK_F11, NoSymbol,
|
|
|
|
XK_F11, NoSymbol,
|
|
|
|
XK_F12, NoSymbol,
|
|
|
|
XK_F12, NoSymbol,
|
|
|
|
XK_Home, NoSymbol,
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol, /* 100 */
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
XK_KP_Enter, NoSymbol,
|
|
|
|
|
|
|
|
XK_Control_R, NoSymbol,
|
|
|
|
|
|
|
|
XK_KP_Divide, NoSymbol,
|
|
|
|
|
|
|
|
XK_Print, NoSymbol,
|
|
|
|
|
|
|
|
XK_Alt_R, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
XK_Home, NoSymbol, /* 110 */
|
|
|
|
XK_Up, NoSymbol,
|
|
|
|
XK_Up, NoSymbol,
|
|
|
|
XK_Prior, NoSymbol,
|
|
|
|
XK_Prior, NoSymbol,
|
|
|
|
XK_Left, NoSymbol, /* 100 */
|
|
|
|
XK_Left, NoSymbol,
|
|
|
|
XK_Print, NoSymbol,
|
|
|
|
|
|
|
|
XK_Right, NoSymbol,
|
|
|
|
XK_Right, NoSymbol,
|
|
|
|
XK_End, NoSymbol,
|
|
|
|
XK_End, NoSymbol,
|
|
|
|
XK_Down, NoSymbol,
|
|
|
|
XK_Down, NoSymbol,
|
|
|
|
XK_Next, NoSymbol,
|
|
|
|
XK_Next, NoSymbol,
|
|
|
|
XK_Insert, NoSymbol,
|
|
|
|
XK_Insert, NoSymbol,
|
|
|
|
XK_Delete, NoSymbol,
|
|
|
|
XK_Delete, NoSymbol,
|
|
|
|
XK_KP_Enter, NoSymbol,
|
|
|
|
NoSymbol, NoSymbol, /* 120 */
|
|
|
|
XK_Control_R, NoSymbol,
|
|
|
|
|
|
|
|
XK_Pause, NoSymbol, /* 110 */
|
|
|
|
|
|
|
|
XK_Print, NoSymbol,
|
|
|
|
|
|
|
|
XK_KP_Divide, NoSymbol,
|
|
|
|
|
|
|
|
XK_Alt_R, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
XK_Super_L, NoSymbol,
|
|
|
|
|
|
|
|
XK_Super_R, NoSymbol,
|
|
|
|
|
|
|
|
XK_Menu, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
NoSymbol, NoSymbol, /* 120 */
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
NoSymbol, NoSymbol
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
XK_Pause, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol, /* 130 */
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
NoSymbol, NoSymbol,
|
|
|
|
|
|
|
|
XK_Super_L, NoSymbol,
|
|
|
|
|
|
|
|
XK_Super_R, NoSymbol,
|
|
|
|
|
|
|
|
XK_Menu, NoSymbol
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
#if 0
|
|
|
@ -256,7 +321,7 @@ static KeySym g_kbdMap[] =
|
|
|
|
static void
|
|
|
|
static void
|
|
|
|
rdpSendBell(void)
|
|
|
|
rdpSendBell(void)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("rdpSendBell\n"));
|
|
|
|
LLOGLN(10, ("rdpSendBell:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
@ -266,23 +331,23 @@ KbdDeviceInit(DeviceIntPtr pDevice, KeySymsPtr pKeySyms, CARD8 *pModMap)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
|
|
|
|
DEBUG_OUT_INPUT(("KbdDeviceInit\n"));
|
|
|
|
LLOGLN(10, ("KbdDeviceInit:"));
|
|
|
|
|
|
|
|
|
|
|
|
for (i = 0; i < MAP_LENGTH; i++)
|
|
|
|
for (i = 0; i < MAP_LENGTH; i++)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
pModMap[i] = NoSymbol;
|
|
|
|
pModMap[i] = NoSymbol;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pModMap[SHIFT_L_KEY_CODE] = ShiftMask;
|
|
|
|
pModMap[XSCAN_Shift_L] = ShiftMask;
|
|
|
|
pModMap[SHIFT_R_KEY_CODE] = ShiftMask;
|
|
|
|
pModMap[XSCAN_Shift_R] = ShiftMask;
|
|
|
|
pModMap[CAPS_LOCK_KEY_CODE] = LockMask;
|
|
|
|
pModMap[XSCAN_Caps_Lock] = LockMask;
|
|
|
|
pModMap[CONTROL_L_KEY_CODE] = ControlMask;
|
|
|
|
pModMap[XSCAN_Control_L] = ControlMask;
|
|
|
|
pModMap[CONTROL_R_KEY_CODE] = ControlMask;
|
|
|
|
pModMap[XSCAN_Control_R] = ControlMask;
|
|
|
|
pModMap[ALT_L_KEY_CODE] = Mod1Mask;
|
|
|
|
pModMap[XSCAN_Alt_L] = Mod1Mask;
|
|
|
|
pModMap[ALT_R_KEY_CODE] = Mod1Mask;
|
|
|
|
pModMap[XSCAN_Alt_R] = Mod1Mask;
|
|
|
|
pModMap[NUM_LOCK_KEY_CODE] = Mod2Mask;
|
|
|
|
pModMap[XSCAN_Num_Lock] = Mod2Mask;
|
|
|
|
pModMap[SUPER_L_KEY_CODE] = Mod4Mask;
|
|
|
|
pModMap[XSCAN_LWin] = Mod4Mask;
|
|
|
|
pModMap[SUPER_R_KEY_CODE] = Mod4Mask;
|
|
|
|
pModMap[XSCAN_RWin] = Mod4Mask;
|
|
|
|
pKeySyms->minKeyCode = MIN_KEY_CODE;
|
|
|
|
pKeySyms->minKeyCode = MIN_KEY_CODE;
|
|
|
|
pKeySyms->maxKeyCode = MAX_KEY_CODE;
|
|
|
|
pKeySyms->maxKeyCode = MAX_KEY_CODE;
|
|
|
|
pKeySyms->mapWidth = GLYPHS_PER_KEY;
|
|
|
|
pKeySyms->mapWidth = GLYPHS_PER_KEY;
|
|
|
@ -310,28 +375,28 @@ KbdDeviceInit(DeviceIntPtr pDevice, KeySymsPtr pKeySyms, CARD8 *pModMap)
|
|
|
|
void
|
|
|
|
void
|
|
|
|
KbdDeviceOn(void)
|
|
|
|
KbdDeviceOn(void)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("KbdDeviceOn\n"));
|
|
|
|
LLOGLN(10, ("KbdDeviceOn:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
void
|
|
|
|
KbdDeviceOff(void)
|
|
|
|
KbdDeviceOff(void)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("KbdDeviceOff\n"));
|
|
|
|
LLOGLN(10, ("KbdDeviceOff:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
void
|
|
|
|
rdpBell(int volume, DeviceIntPtr pDev, pointer ctrl, int cls)
|
|
|
|
rdpBell(int volume, DeviceIntPtr pDev, pointer ctrl, int cls)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ErrorF("rdpBell:\n");
|
|
|
|
LLOGLN(0, ("rdpBell:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
static CARD32
|
|
|
|
static CARD32
|
|
|
|
rdpInDeferredUpdateCallback(OsTimerPtr timer, CARD32 now, pointer arg)
|
|
|
|
rdpInDeferredUpdateCallback(OsTimerPtr timer, CARD32 now, pointer arg)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
//ErrorF("rdpInDeferredUpdateCallback:\n");
|
|
|
|
LLOGLN(10, ("rdpInDeferredUpdateCallback:"));
|
|
|
|
|
|
|
|
|
|
|
|
/* our keyboard device */
|
|
|
|
/* our keyboard device */
|
|
|
|
XkbSetRepeatKeys(g_keyboard, -1, AutoRepeatModeOff);
|
|
|
|
XkbSetRepeatKeys(g_keyboard, -1, AutoRepeatModeOff);
|
|
|
@ -347,7 +412,7 @@ rdpChangeKeyboardControl(DeviceIntPtr pDev, KeybdCtrl *ctrl)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
XkbControlsPtr ctrls;
|
|
|
|
XkbControlsPtr ctrls;
|
|
|
|
|
|
|
|
|
|
|
|
ErrorF("rdpChangeKeyboardControl:\n");
|
|
|
|
LLOGLN(0, ("rdpChangeKeyboardControl:"));
|
|
|
|
ctrls = 0;
|
|
|
|
ctrls = 0;
|
|
|
|
if (pDev != 0)
|
|
|
|
if (pDev != 0)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -369,14 +434,14 @@ rdpChangeKeyboardControl(DeviceIntPtr pDev, KeybdCtrl *ctrl)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (ctrls->enabled_ctrls & XkbRepeatKeysMask)
|
|
|
|
if (ctrls->enabled_ctrls & XkbRepeatKeysMask)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
//ErrorF("rdpChangeKeyboardControl: autoRepeat on\n");
|
|
|
|
LLOGLN(10, ("rdpChangeKeyboardControl: autoRepeat on"));
|
|
|
|
/* schedual to turn off the autorepeat after 100 ms so any app
|
|
|
|
/* schedual to turn off the autorepeat after 100 ms so any app
|
|
|
|
* polling it will be happy it's on */
|
|
|
|
* polling it will be happy it's on */
|
|
|
|
g_kbtimer = TimerSet(g_kbtimer, 0, 100, rdpInDeferredUpdateCallback, 0);\
|
|
|
|
g_kbtimer = TimerSet(g_kbtimer, 0, 100, rdpInDeferredUpdateCallback, 0);\
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
//ErrorF("rdpChangeKeyboardControl: autoRepeat off\n");
|
|
|
|
LLOGLN(10, ("rdpChangeKeyboardControl: autoRepeat off"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -390,7 +455,7 @@ rdpKeybdProc(DeviceIntPtr pDevice, int onoff)
|
|
|
|
DevicePtr pDev;
|
|
|
|
DevicePtr pDev;
|
|
|
|
XkbRMLVOSet set;
|
|
|
|
XkbRMLVOSet set;
|
|
|
|
|
|
|
|
|
|
|
|
DEBUG_OUT_INPUT(("rdpKeybdProc\n"));
|
|
|
|
LLOGLN(10, ("rdpKeybdProc:"));
|
|
|
|
pDev = (DevicePtr)pDevice;
|
|
|
|
pDev = (DevicePtr)pDevice;
|
|
|
|
|
|
|
|
|
|
|
|
switch (onoff)
|
|
|
|
switch (onoff)
|
|
|
@ -398,7 +463,7 @@ rdpKeybdProc(DeviceIntPtr pDevice, int onoff)
|
|
|
|
case DEVICE_INIT:
|
|
|
|
case DEVICE_INIT:
|
|
|
|
KbdDeviceInit(pDevice, &keySyms, modMap);
|
|
|
|
KbdDeviceInit(pDevice, &keySyms, modMap);
|
|
|
|
memset(&set, 0, sizeof(set));
|
|
|
|
memset(&set, 0, sizeof(set));
|
|
|
|
set.rules = "base";
|
|
|
|
set.rules = "evdev"; /* was "base" */
|
|
|
|
set.model = "pc104";
|
|
|
|
set.model = "pc104";
|
|
|
|
set.layout = "us";
|
|
|
|
set.layout = "us";
|
|
|
|
set.variant = "";
|
|
|
|
set.variant = "";
|
|
|
@ -432,35 +497,35 @@ rdpKeybdProc(DeviceIntPtr pDevice, int onoff)
|
|
|
|
void
|
|
|
|
void
|
|
|
|
PtrDeviceControl(DeviceIntPtr dev, PtrCtrl *ctrl)
|
|
|
|
PtrDeviceControl(DeviceIntPtr dev, PtrCtrl *ctrl)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("PtrDeviceControl\n"));
|
|
|
|
LLOGLN(10, ("PtrDeviceControl:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
void
|
|
|
|
PtrDeviceInit(void)
|
|
|
|
PtrDeviceInit(void)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("PtrDeviceInit\n"));
|
|
|
|
LLOGLN(10, ("PtrDeviceInit:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
void
|
|
|
|
PtrDeviceOn(DeviceIntPtr pDev)
|
|
|
|
PtrDeviceOn(DeviceIntPtr pDev)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("PtrDeviceOn\n"));
|
|
|
|
LLOGLN(10, ("PtrDeviceOn:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
void
|
|
|
|
PtrDeviceOff(void)
|
|
|
|
PtrDeviceOff(void)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("PtrDeviceOff\n"));
|
|
|
|
LLOGLN(10, ("PtrDeviceOff:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
static void
|
|
|
|
static void
|
|
|
|
rdpMouseCtrl(DeviceIntPtr pDevice, PtrCtrl *pCtrl)
|
|
|
|
rdpMouseCtrl(DeviceIntPtr pDevice, PtrCtrl *pCtrl)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ErrorF("rdpMouseCtrl:\n");
|
|
|
|
LLOGLN(0, ("rdpMouseCtrl:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
@ -472,7 +537,7 @@ rdpMouseProc(DeviceIntPtr pDevice, int onoff)
|
|
|
|
Atom btn_labels[8];
|
|
|
|
Atom btn_labels[8];
|
|
|
|
Atom axes_labels[2];
|
|
|
|
Atom axes_labels[2];
|
|
|
|
|
|
|
|
|
|
|
|
DEBUG_OUT_INPUT(("rdpMouseProc\n"));
|
|
|
|
LLOGLN(10, ("rdpMouseProc:"));
|
|
|
|
pDev = (DevicePtr)pDevice;
|
|
|
|
pDev = (DevicePtr)pDevice;
|
|
|
|
|
|
|
|
|
|
|
|
switch (onoff)
|
|
|
|
switch (onoff)
|
|
|
@ -528,7 +593,7 @@ rdpMouseProc(DeviceIntPtr pDevice, int onoff)
|
|
|
|
Bool
|
|
|
|
Bool
|
|
|
|
rdpCursorOffScreen(ScreenPtr *ppScreen, int *x, int *y)
|
|
|
|
rdpCursorOffScreen(ScreenPtr *ppScreen, int *x, int *y)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("rdpCursorOffScreen\n"));
|
|
|
|
LLOGLN(10, ("rdpCursorOffScreen:"));
|
|
|
|
return 0;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -536,14 +601,14 @@ rdpCursorOffScreen(ScreenPtr *ppScreen, int *x, int *y)
|
|
|
|
void
|
|
|
|
void
|
|
|
|
rdpCrossScreen(ScreenPtr pScreen, Bool entering)
|
|
|
|
rdpCrossScreen(ScreenPtr pScreen, Bool entering)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("rdpCrossScreen\n"));
|
|
|
|
LLOGLN(10, ("rdpCrossScreen:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
void
|
|
|
|
rdpPointerWarpCursor(DeviceIntPtr pDev, ScreenPtr pScr, int x, int y)
|
|
|
|
rdpPointerWarpCursor(DeviceIntPtr pDev, ScreenPtr pScr, int x, int y)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ErrorF("rdpPointerWarpCursor:\n");
|
|
|
|
LLOGLN(0, ("rdpPointerWarpCursor:"));
|
|
|
|
miPointerWarpCursor(pDev, pScr, x, y);
|
|
|
|
miPointerWarpCursor(pDev, pScr, x, y);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -551,21 +616,21 @@ rdpPointerWarpCursor(DeviceIntPtr pDev, ScreenPtr pScr, int x, int y)
|
|
|
|
void
|
|
|
|
void
|
|
|
|
rdpPointerEnqueueEvent(DeviceIntPtr pDev, InternalEvent *event)
|
|
|
|
rdpPointerEnqueueEvent(DeviceIntPtr pDev, InternalEvent *event)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ErrorF("rdpPointerEnqueueEvent:\n");
|
|
|
|
LLOGLN(0, ("rdpPointerEnqueueEvent:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
void
|
|
|
|
void
|
|
|
|
rdpPointerNewEventScreen(DeviceIntPtr pDev, ScreenPtr pScr, Bool fromDIX)
|
|
|
|
rdpPointerNewEventScreen(DeviceIntPtr pDev, ScreenPtr pScr, Bool fromDIX)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ErrorF("rdpPointerNewEventScreen:\n");
|
|
|
|
LLOGLN(0, ("rdpPointerNewEventScreen:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
Bool
|
|
|
|
Bool
|
|
|
|
rdpSpriteRealizeCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs)
|
|
|
|
rdpSpriteRealizeCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("rdpSpriteRealizeCursor\n"));
|
|
|
|
LLOGLN(10, ("rdpSpriteRealizeCursor:"));
|
|
|
|
return 1;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -573,7 +638,7 @@ rdpSpriteRealizeCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs)
|
|
|
|
Bool
|
|
|
|
Bool
|
|
|
|
rdpSpriteUnrealizeCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs)
|
|
|
|
rdpSpriteUnrealizeCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("hi rdpSpriteUnrealizeCursor\n"));
|
|
|
|
LLOGLN(10, ("rdpSpriteUnrealizeCursor:"));
|
|
|
|
return 1;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -780,14 +845,14 @@ rdpSpriteSetCursor(DeviceIntPtr pDev, ScreenPtr pScr, CursorPtr pCurs,
|
|
|
|
void
|
|
|
|
void
|
|
|
|
rdpSpriteMoveCursor(DeviceIntPtr pDev, ScreenPtr pScr, int x, int y)
|
|
|
|
rdpSpriteMoveCursor(DeviceIntPtr pDev, ScreenPtr pScr, int x, int y)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
DEBUG_OUT_INPUT(("hi rdpSpriteMoveCursor\n"));
|
|
|
|
LLOGLN(10, ("rdpSpriteMoveCursor:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
|
Bool
|
|
|
|
Bool
|
|
|
|
rdpSpriteDeviceCursorInitialize(DeviceIntPtr pDev, ScreenPtr pScr)
|
|
|
|
rdpSpriteDeviceCursorInitialize(DeviceIntPtr pDev, ScreenPtr pScr)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ErrorF("rdpSpriteDeviceCursorInitialize:\n");
|
|
|
|
LLOGLN(0, ("rdpSpriteDeviceCursorInitialize:"));
|
|
|
|
return 1;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -795,7 +860,7 @@ rdpSpriteDeviceCursorInitialize(DeviceIntPtr pDev, ScreenPtr pScr)
|
|
|
|
void
|
|
|
|
void
|
|
|
|
rdpSpriteDeviceCursorCleanup(DeviceIntPtr pDev, ScreenPtr pScr)
|
|
|
|
rdpSpriteDeviceCursorCleanup(DeviceIntPtr pDev, ScreenPtr pScr)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ErrorF("rdpSpriteDeviceCursorCleanup:\n");
|
|
|
|
LLOGLN(0, ("rdpSpriteDeviceCursorCleanup:"));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
/******************************************************************************/
|
|
|
@ -992,11 +1057,8 @@ KbdAddEvent(int down, int param1, int param2, int param3, int param4)
|
|
|
|
int is_spe;
|
|
|
|
int is_spe;
|
|
|
|
int type;
|
|
|
|
int type;
|
|
|
|
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
LLOGLN(10, ("KbdAddEvent: down=0x%x param1=0x%x param2=0x%x param3=0x%x "
|
|
|
|
fprintf(stderr, "down=0x%x param1=0x%x param2=0x%x param3=0x%x "
|
|
|
|
"param4=0x%x", down, param1, param2, param3, param4));
|
|
|
|
"param4=0x%x\n", down, param1, param2, param3, param4);
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
type = down ? KeyPress : KeyRelease;
|
|
|
|
type = down ? KeyPress : KeyRelease;
|
|
|
|
rdp_scancode = param3;
|
|
|
|
rdp_scancode = param3;
|
|
|
|
is_ext = param4 & 256; /* 0x100 */
|
|
|
|
is_ext = param4 & 256; /* 0x100 */
|
|
|
@ -1005,16 +1067,17 @@ KbdAddEvent(int down, int param1, int param2, int param3, int param4)
|
|
|
|
|
|
|
|
|
|
|
|
switch (rdp_scancode)
|
|
|
|
switch (rdp_scancode)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
case 58: /* caps lock */
|
|
|
|
case RDPSCAN_Caps_Lock: /* caps lock */
|
|
|
|
case 42: /* left shift */
|
|
|
|
case RDPSCAN_Shift_L: /* left shift */
|
|
|
|
case 54: /* right shift */
|
|
|
|
case RDPSCAN_Shift_R: /* right shift */
|
|
|
|
case 70: /* scroll lock */
|
|
|
|
case RDPSCAN_Scroll_Lock: /* scroll lock */
|
|
|
|
x_scancode = rdp_scancode + MIN_KEY_CODE;
|
|
|
|
x_scancode = rdp_scancode + MIN_KEY_CODE;
|
|
|
|
|
|
|
|
|
|
|
|
if (x_scancode > 0)
|
|
|
|
if (x_scancode > 0)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
/* left or right shift */
|
|
|
|
/* left or right shift */
|
|
|
|
if ((rdp_scancode == 42) || (rdp_scancode == 54))
|
|
|
|
if ((rdp_scancode == RDPSCAN_Shift_L) ||
|
|
|
|
|
|
|
|
(rdp_scancode == RDPSCAN_Shift_R))
|
|
|
|
{
|
|
|
|
{
|
|
|
|
g_shift_down = down ? x_scancode : 0;
|
|
|
|
g_shift_down = down ? x_scancode : 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -1022,22 +1085,22 @@ KbdAddEvent(int down, int param1, int param2, int param3, int param4)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 56: /* left - right alt button */
|
|
|
|
case RDPSCAN_Alt: /* left - right alt button */
|
|
|
|
|
|
|
|
|
|
|
|
if (is_ext)
|
|
|
|
if (is_ext)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
x_scancode = 113; /* right alt button */
|
|
|
|
x_scancode = XSCAN_Alt_R; /* right alt button */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
x_scancode = 64; /* left alt button */
|
|
|
|
x_scancode = XSCAN_Alt_L; /* left alt button */
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
g_alt_down = down ? x_scancode : 0;
|
|
|
|
g_alt_down = down ? x_scancode : 0;
|
|
|
|
rdpEnqueueKey(type, x_scancode);
|
|
|
|
rdpEnqueueKey(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 15: /* tab */
|
|
|
|
case RDPSCAN_Tab: /* tab */
|
|
|
|
|
|
|
|
|
|
|
|
if (!down && !g_tab_down)
|
|
|
|
if (!down && !g_tab_down)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -1045,13 +1108,13 @@ KbdAddEvent(int down, int param1, int param2, int param3, int param4)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
sendDownUpKeyEvent(type, 23);
|
|
|
|
sendDownUpKeyEvent(type, XSCAN_Tab);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
g_tab_down = down;
|
|
|
|
g_tab_down = down;
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 29: /* left or right ctrl */
|
|
|
|
case RDPSCAN_Control: /* left or right ctrl */
|
|
|
|
|
|
|
|
|
|
|
|
/* this is to handle special case with pause key sending control first */
|
|
|
|
/* this is to handle special case with pause key sending control first */
|
|
|
|
if (is_spe)
|
|
|
|
if (is_spe)
|
|
|
@ -1064,18 +1127,18 @@ KbdAddEvent(int down, int param1, int param2, int param3, int param4)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
x_scancode = is_ext ? 109 : 37;
|
|
|
|
x_scancode = is_ext ? XSCAN_Control_R : XSCAN_Control_L;
|
|
|
|
g_ctrl_down = down ? x_scancode : 0;
|
|
|
|
g_ctrl_down = down ? x_scancode : 0;
|
|
|
|
rdpEnqueueKey(type, x_scancode);
|
|
|
|
rdpEnqueueKey(type, x_scancode);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 69: /* Pause or Num Lock */
|
|
|
|
case RDPSCAN_Pause: /* Pause or Num Lock */
|
|
|
|
|
|
|
|
|
|
|
|
if (g_pause_spe)
|
|
|
|
if (g_pause_spe)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
x_scancode = 110;
|
|
|
|
x_scancode = XSCAN_Pause;
|
|
|
|
|
|
|
|
|
|
|
|
if (!down)
|
|
|
|
if (!down)
|
|
|
|
{
|
|
|
|
{
|
|
|
@ -1084,95 +1147,103 @@ KbdAddEvent(int down, int param1, int param2, int param3, int param4)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
x_scancode = g_ctrl_down ? 110 : 77;
|
|
|
|
x_scancode = g_ctrl_down ? XSCAN_Pause : XSCAN_Num_Lock;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
rdpEnqueueKey(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 28: /* Enter or Return */
|
|
|
|
case RDPSCAN_Return: /* Enter or Return */
|
|
|
|
x_scancode = is_ext ? 108 : 36;
|
|
|
|
x_scancode = is_ext ? XSCAN_Enter : XSCAN_Return;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 53: /* / */
|
|
|
|
case RDPSCAN_Slash: /* / */
|
|
|
|
x_scancode = is_ext ? 112 : 61;
|
|
|
|
x_scancode = is_ext ? XSCAN_KP_Divide : XSCAN_slash;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 55: /* * on KP or Print Screen */
|
|
|
|
case RDPSCAN_KP_Multiply: /* * on KP or Print Screen */
|
|
|
|
x_scancode = is_ext ? 111 : 63;
|
|
|
|
x_scancode = is_ext ? XSCAN_Print : XSCAN_KP_Multiply;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 71: /* 7 or Home */
|
|
|
|
case RDPSCAN_KP_7: /* 7 or Home */
|
|
|
|
x_scancode = is_ext ? 97 : 79;
|
|
|
|
x_scancode = is_ext ? XSCAN_Home : XSCAN_KP_7;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 72: /* 8 or Up */
|
|
|
|
case RDPSCAN_KP_8: /* 8 or Up */
|
|
|
|
x_scancode = is_ext ? 98 : 80;
|
|
|
|
x_scancode = is_ext ? XSCAN_Up : XSCAN_KP_8;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 73: /* 9 or PgUp */
|
|
|
|
case RDPSCAN_KP_9: /* 9 or PgUp */
|
|
|
|
x_scancode = is_ext ? 99 : 81;
|
|
|
|
x_scancode = is_ext ? XSCAN_Prior : XSCAN_KP_9;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 75: /* 4 or Left */
|
|
|
|
case RDPSCAN_KP_4: /* 4 or Left */
|
|
|
|
x_scancode = is_ext ? 100 : 83;
|
|
|
|
x_scancode = is_ext ? XSCAN_Left : XSCAN_KP_4;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 77: /* 6 or Right */
|
|
|
|
case RDPSCAN_KP_6: /* 6 or Right */
|
|
|
|
x_scancode = is_ext ? 102 : 85;
|
|
|
|
x_scancode = is_ext ? XSCAN_Right : XSCAN_KP_6;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 79: /* 1 or End */
|
|
|
|
case RDPSCAN_KP_1: /* 1 or End */
|
|
|
|
x_scancode = is_ext ? 103 : 87;
|
|
|
|
x_scancode = is_ext ? XSCAN_End : XSCAN_KP_1;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 80: /* 2 or Down */
|
|
|
|
case RDPSCAN_KP_2: /* 2 or Down */
|
|
|
|
x_scancode = is_ext ? 104 : 88;
|
|
|
|
x_scancode = is_ext ? XSCAN_Down : XSCAN_KP_2;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 81: /* 3 or PgDn */
|
|
|
|
case RDPSCAN_KP_3: /* 3 or PgDn */
|
|
|
|
x_scancode = is_ext ? 105 : 89;
|
|
|
|
x_scancode = is_ext ? XSCAN_Next : XSCAN_KP_3;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 82: /* 0 or Insert */
|
|
|
|
case RDPSCAN_KP_0: /* 0 or Insert */
|
|
|
|
x_scancode = is_ext ? 106 : 90;
|
|
|
|
x_scancode = is_ext ? XSCAN_Insert : XSCAN_KP_0;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 83: /* . or Delete */
|
|
|
|
case RDPSCAN_KP_Decimal: /* . or Delete */
|
|
|
|
x_scancode = is_ext ? 107 : 91;
|
|
|
|
x_scancode = is_ext ? XSCAN_Delete : XSCAN_KP_Decimal;
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 91: /* left win key */
|
|
|
|
case RDPSCAN_LWin: /* left win key */
|
|
|
|
rdpEnqueueKey(type, 115);
|
|
|
|
rdpEnqueueKey(type, XSCAN_LWin);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case RDPSCAN_RWin: /* right win key */
|
|
|
|
|
|
|
|
rdpEnqueueKey(type, XSCAN_RWin);
|
|
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
case RDPSCAN_Menu: /* menu key */
|
|
|
|
|
|
|
|
rdpEnqueueKey(type, XSCAN_Menu);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 92: /* right win key */
|
|
|
|
case RDPSCAN_89: /* left meta */
|
|
|
|
rdpEnqueueKey(type, 116);
|
|
|
|
rdpEnqueueKey(type, XSCAN_LMeta);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 93: /* menu key */
|
|
|
|
case RDPSCAN_90: /* right meta */
|
|
|
|
rdpEnqueueKey(type, 117);
|
|
|
|
rdpEnqueueKey(type, XSCAN_RMeta);
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 89: /* left meta */
|
|
|
|
case RDPSCAN_115:
|
|
|
|
rdpEnqueueKey(type, 156);
|
|
|
|
rdpEnqueueKey(type, XSCAN_97); /* "/ ?" on br keybaord */
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 90: /* right meta */
|
|
|
|
case RDPSCAN_126:
|
|
|
|
rdpEnqueueKey(type, 156);
|
|
|
|
rdpEnqueueKey(type, XSCAN_129); /* . on br keypad */
|
|
|
|
break;
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
default:
|
|
|
|
default:
|
|
|
@ -1180,6 +1251,8 @@ KbdAddEvent(int down, int param1, int param2, int param3, int param4)
|
|
|
|
|
|
|
|
|
|
|
|
if (x_scancode > 0)
|
|
|
|
if (x_scancode > 0)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
LLOGLN(10, ("KbdAddEvent: rdp_scancode %d x_scancode %d",
|
|
|
|
|
|
|
|
rdp_scancode, x_scancode));
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
sendDownUpKeyEvent(type, x_scancode);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -1200,21 +1273,21 @@ KbdSync(int param1)
|
|
|
|
|
|
|
|
|
|
|
|
if ((!(xkb_state & 0x02)) != (!(param1 & 4))) /* caps lock */
|
|
|
|
if ((!(xkb_state & 0x02)) != (!(param1 & 4))) /* caps lock */
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ErrorF("KbdSync: toggling caps lock\n");
|
|
|
|
LLOGLN(0, ("KbdSync: toggling caps lock"));
|
|
|
|
KbdAddEvent(1, 58, 0, 58, 0);
|
|
|
|
KbdAddEvent(1, 58, 0, 58, 0);
|
|
|
|
KbdAddEvent(0, 58, 49152, 58, 49152);
|
|
|
|
KbdAddEvent(0, 58, 49152, 58, 49152);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if ((!(xkb_state & 0x10)) != (!(param1 & 2))) /* num lock */
|
|
|
|
if ((!(xkb_state & 0x10)) != (!(param1 & 2))) /* num lock */
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ErrorF("KbdSync: toggling num lock\n");
|
|
|
|
LLOGLN(0, ("KbdSync: toggling num lock"));
|
|
|
|
KbdAddEvent(1, 69, 0, 69, 0);
|
|
|
|
KbdAddEvent(1, 69, 0, 69, 0);
|
|
|
|
KbdAddEvent(0, 69, 49152, 69, 49152);
|
|
|
|
KbdAddEvent(0, 69, 49152, 69, 49152);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if ((!(g_scroll_lock_down)) != (!(param1 & 1))) /* scroll lock */
|
|
|
|
if ((!(g_scroll_lock_down)) != (!(param1 & 1))) /* scroll lock */
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ErrorF("KbdSync: toggling scroll lock\n");
|
|
|
|
LLOGLN(0, ("KbdSync: toggling scroll lock"));
|
|
|
|
KbdAddEvent(1, 70, 0, 70, 0);
|
|
|
|
KbdAddEvent(1, 70, 0, 70, 0);
|
|
|
|
KbdAddEvent(0, 70, 49152, 70, 49152);
|
|
|
|
KbdAddEvent(0, 70, 49152, 70, 49152);
|
|
|
|
}
|
|
|
|
}
|
|
|
|