summaryrefslogtreecommitdiffstats
path: root/xorg/X11R7.6/rdp/rdpinput.c
diff options
context:
space:
mode:
authorJay Sorg <jay.sorg@gmail.com>2012-03-13 17:18:10 -0700
committerJay Sorg <jay.sorg@gmail.com>2012-03-13 17:18:10 -0700
commit35bc7a1588a1a6c40fe1d20c07b2bc66e93b88e9 (patch)
tree316eee90522c1e36233caad309dee58aff67cba8 /xorg/X11R7.6/rdp/rdpinput.c
parent288961c60f5e7472a61a0c4cc65d3dc568148114 (diff)
downloadxrdp-proprietary-35bc7a1588a1a6c40fe1d20c07b2bc66e93b88e9.tar.gz
xrdp-proprietary-35bc7a1588a1a6c40fe1d20c07b2bc66e93b88e9.zip
xorg: added DAMAGE, fix keyboard sync
Diffstat (limited to 'xorg/X11R7.6/rdp/rdpinput.c')
-rw-r--r--xorg/X11R7.6/rdp/rdpinput.c95
1 files changed, 17 insertions, 78 deletions
diff --git a/xorg/X11R7.6/rdp/rdpinput.c b/xorg/X11R7.6/rdp/rdpinput.c
index 0a6798d0..35dc7b70 100644
--- a/xorg/X11R7.6/rdp/rdpinput.c
+++ b/xorg/X11R7.6/rdp/rdpinput.c
@@ -45,8 +45,9 @@ keyboard and mouse stuff
#endif
extern ScreenPtr g_pScreen; /* in rdpmain.c */
+extern DeviceIntPtr g_pointer; /* in rdpmain.c */
+extern DeviceIntPtr g_keyboard; /* in rdpmain.c */
-static DeviceIntPtr g_kbdDevice = 0;
static int g_old_button_mask = 0;
static int g_pause_spe = 0;
static int g_ctrl_down = 0;
@@ -57,9 +58,6 @@ static int g_tab_down = 0;
above *_down vars */
static int g_scroll_lock_down = 0;
-static DeviceIntPtr g_mouse = 0;
-static DeviceIntPtr g_keyboard = 0;
-
#define MIN_KEY_CODE 8
#define MAX_KEY_CODE 255
#define NO_OF_KEYS ((MAX_KEY_CODE - MIN_KEY_CODE) + 1)
@@ -255,7 +253,6 @@ KbdDeviceInit(DeviceIntPtr pDevice, KeySymsPtr pKeySyms, CARD8* pModMap)
int i;
DEBUG_OUT_INPUT(("KbdDeviceInit\n"));
- g_kbdDevice = pDevice;
for (i = 0; i < MAP_LENGTH; i++)
{
pModMap[i] = NoSymbol;
@@ -328,7 +325,6 @@ rdpKeybdProc(DeviceIntPtr pDevice, int onoff)
XkbRMLVOSet set;
DEBUG_OUT_INPUT(("rdpKeybdProc\n"));
-#if 1
pDev = (DevicePtr)pDevice;
switch (onoff)
{
@@ -347,7 +343,6 @@ rdpKeybdProc(DeviceIntPtr pDevice, int onoff)
case DEVICE_ON:
pDev->on = 1;
KbdDeviceOn();
- g_keyboard = pDevice;
break;
case DEVICE_OFF:
pDev->on = 0;
@@ -360,7 +355,6 @@ rdpKeybdProc(DeviceIntPtr pDevice, int onoff)
}
break;
}
-#endif
return Success;
}
@@ -437,9 +431,6 @@ rdpMouseProc(DeviceIntPtr pDevice, int onoff)
case DEVICE_ON:
pDev->on = 1;
PtrDeviceOn(pDevice);
-
- g_mouse = pDevice;
-
break;
case DEVICE_OFF:
pDev->on = 0;
@@ -688,18 +679,18 @@ rdpEnqueueMotion(int x, int y)
EventListPtr rdp_events;
xEvent* pev;
- miPointerSetPosition(g_mouse, &x, &y);
+ miPointerSetPosition(g_pointer, &x, &y);
valuators[0] = x;
valuators[1] = y;
GetEventList(&rdp_events);
- n = GetPointerEvents(rdp_events, g_mouse, MotionNotify, 0,
+ n = GetPointerEvents(rdp_events, g_pointer, MotionNotify, 0,
POINTER_ABSOLUTE | POINTER_SCREEN,
0, 2, valuators);
for (i = 0; i < n; i++)
{
pev = (rdp_events + i)->event;
- mieqEnqueue(g_mouse, (InternalEvent*)pev);
+ mieqEnqueue(g_pointer, (InternalEvent*)pev);
}
}
@@ -713,11 +704,11 @@ rdpEnqueueButton(int type, int buttons)
xEvent* pev;
i = GetEventList(&rdp_events);
- n = GetPointerEvents(rdp_events, g_mouse, type, buttons, 0, 0, 0, 0);
+ n = GetPointerEvents(rdp_events, g_pointer, type, buttons, 0, 0, 0, 0);
for (i = 0; i < n; i++)
{
pev = (rdp_events + i)->event;
- mieqEnqueue(g_mouse, (InternalEvent*)pev);
+ mieqEnqueue(g_pointer, (InternalEvent*)pev);
}
}
@@ -769,7 +760,6 @@ PtrAddEvent(int buttonMask, int x, int y)
g_old_button_mask = buttonMask;
}
-
/******************************************************************************/
void
check_keysa(void)
@@ -930,84 +920,33 @@ KbdAddEvent(int down, int param1, int param2, int param3, int param4)
/******************************************************************************/
/* notes -
- we should use defines or something for the keyc->state below
+ we should use defines or something for the
+ g_keyboard->key->xkbInfo->state below
scroll lock doesn't seem to be a modifier in X
*/
void
KbdSync(int param1)
{
+ int xkb_state;
-#if 0
-
- KeyClassPtr keyc;
- int mask;
- int latches;
- int status;
-
- if (g_kbdDevice == 0)
- {
- return;
- }
-
- mask = 0;
- latches = 0;
-
- mask |= 1 << 1;
- if (param1 & 4)
- {
- latches |= 1 << 1;
- }
- mask |= Mod1Mask;
- if (param1 & 4)
- {
- latches |= Mod1Mask;
- }
-
- ErrorF("mask 0x%x latches 0x%x\n", mask, latches);
-
- status = XkbLatchModifiers(g_keyboard, mask, latches);
-
- ErrorF("status %d\n", status);
-
-#if 0
-
- keyc = g_kbdDevice->key;
- if (keyc == 0)
- {
- return;
- }
-
-
- ErrorF("0x%x mods 0x%x\n", param1, keyc->xkbInfo->state.mods);
-
- hexdump(keyc->down, DOWN_LENGTH);
-
- hexdump(keyc->modifierKeyCount, 32);
-
- hexdump(keyc->xkbInfo, sizeof(struct _XkbSrvInfo));
-
-#if 1
- //if ((!(keyc->xkbInfo->state & 0x02)) != (!(param1 & 4))) /* caps lock */
- if (param1 & 4) /* caps lock */
+ xkb_state = XkbStateFieldFromRec(&(g_keyboard->key->xkbInfo->state));
+ if ((!(xkb_state & 0x02)) != (!(param1 & 4))) /* caps lock */
{
+ ErrorF("KbdSync: toggling caps lock\n");
KbdAddEvent(1, 58, 0, 58, 0);
KbdAddEvent(0, 58, 49152, 58, 49152);
}
- //if ((!(keyc->state & 0x10)) != (!(param1 & 2))) /* num lock */
- if (param1 & 2) /* num lock */
+
+ if ((!(xkb_state & 0x10)) != (!(param1 & 2))) /* num lock */
{
+ ErrorF("KbdSync: toggling num lock\n");
KbdAddEvent(1, 69, 0, 69, 0);
KbdAddEvent(0, 69, 49152, 69, 49152);
}
-#endif
if ((!(g_scroll_lock_down)) != (!(param1 & 1))) /* scroll lock */
{
+ ErrorF("KbdSync: toggling scroll lock\n");
KbdAddEvent(1, 70, 0, 70, 0);
KbdAddEvent(0, 70, 49152, 70, 49152);
}
-
-#endif
-
-#endif
-
}