38 |
#define KEYMAP_MAX_LINE_LENGTH 80 |
#define KEYMAP_MAX_LINE_LENGTH 80 |
39 |
|
|
40 |
extern Display *g_display; |
extern Display *g_display; |
41 |
|
extern Window g_wnd; |
42 |
extern char keymapname[16]; |
extern char keymapname[16]; |
43 |
extern int keylayout; |
extern int keylayout; |
44 |
extern int g_win_button_size; |
extern int g_win_button_size; |
186 |
MASK_ADD_BITS(modifiers, MapLeftShiftMask); |
MASK_ADD_BITS(modifiers, MapLeftShiftMask); |
187 |
} |
} |
188 |
|
|
|
if (strstr(line_rest, "numlock")) |
|
|
{ |
|
|
MASK_ADD_BITS(modifiers, MapNumLockMask); |
|
|
} |
|
|
|
|
189 |
if (strstr(line_rest, "localstate")) |
if (strstr(line_rest, "localstate")) |
190 |
{ |
{ |
191 |
MASK_ADD_BITS(modifiers, MapLocalStateMask); |
MASK_ADD_BITS(modifiers, MapLocalStateMask); |
276 |
} |
} |
277 |
} |
} |
278 |
|
|
279 |
|
static void |
280 |
|
reset_winkey(uint32 ev_time) |
281 |
|
{ |
282 |
|
if (g_use_rdp5) |
283 |
|
{ |
284 |
|
/* For some reason, it seems to suffice to release |
285 |
|
*either* the left or right winkey. */ |
286 |
|
rdp_send_scancode(ev_time, RDP_KEYRELEASE, SCANCODE_CHAR_LWIN); |
287 |
|
} |
288 |
|
} |
289 |
|
|
290 |
/* Handles, for example, multi-scancode keypresses (which is not |
/* Handles, for example, multi-scancode keypresses (which is not |
291 |
possible via keymap-files) */ |
possible via keymap-files) */ |
292 |
BOOL |
BOOL |
507 |
if (is_modifier(tr.scancode)) |
if (is_modifier(tr.scancode)) |
508 |
return; |
return; |
509 |
|
|
|
/* NumLock */ |
|
|
if (MASK_HAS_BITS(tr.modifiers, MapNumLockMask) |
|
|
!= MASK_HAS_BITS(remote_modifier_state, MapNumLockMask)) |
|
|
{ |
|
|
/* The remote modifier state is not correct */ |
|
|
uint16 new_remote_state; |
|
|
|
|
|
if (MASK_HAS_BITS(tr.modifiers, MapNumLockMask)) |
|
|
{ |
|
|
DEBUG_KBD(("Remote NumLock state is incorrect, activating NumLock.\n")); |
|
|
new_remote_state = KBD_FLAG_NUMLOCK; |
|
|
remote_modifier_state = MapNumLockMask; |
|
|
} |
|
|
else |
|
|
{ |
|
|
DEBUG_KBD(("Remote NumLock state is incorrect, deactivating NumLock.\n")); |
|
|
new_remote_state = 0; |
|
|
remote_modifier_state = 0; |
|
|
} |
|
|
|
|
|
rdp_send_input(0, RDP_INPUT_SYNCHRONIZE, 0, new_remote_state, 0); |
|
|
} |
|
|
|
|
510 |
/* Shift. Left shift and right shift are treated as equal; either is fine. */ |
/* Shift. Left shift and right shift are treated as equal; either is fine. */ |
511 |
if (MASK_HAS_BITS(tr.modifiers, MapShiftMask) |
if (MASK_HAS_BITS(tr.modifiers, MapShiftMask) |
512 |
!= MASK_HAS_BITS(remote_modifier_state, MapShiftMask)) |
!= MASK_HAS_BITS(remote_modifier_state, MapShiftMask)) |
555 |
} |
} |
556 |
|
|
557 |
|
|
558 |
|
unsigned int |
559 |
|
read_keyboard_state() |
560 |
|
{ |
561 |
|
unsigned int state; |
562 |
|
Window wdummy; |
563 |
|
int dummy; |
564 |
|
|
565 |
|
XQueryPointer(g_display, g_wnd, &wdummy, &wdummy, &dummy, &dummy, &dummy, &dummy, &state); |
566 |
|
return state; |
567 |
|
} |
568 |
|
|
569 |
|
|
570 |
|
uint16 |
571 |
|
ui_get_numlock_state(unsigned int state) |
572 |
|
{ |
573 |
|
uint16 numlock_state = 0; |
574 |
|
|
575 |
|
if (get_key_state(state, XK_Num_Lock)) |
576 |
|
numlock_state = KBD_FLAG_NUMLOCK; |
577 |
|
|
578 |
|
return numlock_state; |
579 |
|
} |
580 |
|
|
581 |
|
|
582 |
void |
void |
583 |
reset_modifier_keys(unsigned int state) |
reset_modifier_keys() |
584 |
{ |
{ |
585 |
|
unsigned int state = read_keyboard_state(); |
586 |
|
|
587 |
/* reset keys */ |
/* reset keys */ |
588 |
uint32 ev_time; |
uint32 ev_time; |
589 |
ev_time = time(NULL); |
ev_time = time(NULL); |
610 |
if (MASK_HAS_BITS(remote_modifier_state, MapRightAltMask) && |
if (MASK_HAS_BITS(remote_modifier_state, MapRightAltMask) && |
611 |
!get_key_state(state, XK_Alt_R) && !get_key_state(state, XK_Mode_switch)) |
!get_key_state(state, XK_Alt_R) && !get_key_state(state, XK_Mode_switch)) |
612 |
rdp_send_scancode(ev_time, RDP_KEYRELEASE, SCANCODE_CHAR_RALT); |
rdp_send_scancode(ev_time, RDP_KEYRELEASE, SCANCODE_CHAR_RALT); |
613 |
|
|
614 |
|
reset_winkey(ev_time); |
615 |
|
|
616 |
|
rdp_send_input(ev_time, RDP_INPUT_SYNCHRONIZE, 0, ui_get_numlock_state(state), 0); |
617 |
} |
} |
618 |
|
|
619 |
|
|
652 |
case SCANCODE_CHAR_RWIN: |
case SCANCODE_CHAR_RWIN: |
653 |
MASK_CHANGE_BIT(remote_modifier_state, MapRightWinMask, pressed); |
MASK_CHANGE_BIT(remote_modifier_state, MapRightWinMask, pressed); |
654 |
break; |
break; |
|
case SCANCODE_CHAR_NUMLOCK: |
|
|
/* KeyReleases for NumLocks are sent immediately. Toggle the |
|
|
modifier state only on Keypress */ |
|
|
if (pressed) |
|
|
{ |
|
|
BOOL newNumLockState; |
|
|
newNumLockState = |
|
|
(MASK_HAS_BITS |
|
|
(remote_modifier_state, MapNumLockMask) == False); |
|
|
MASK_CHANGE_BIT(remote_modifier_state, |
|
|
MapNumLockMask, newNumLockState); |
|
|
} |
|
|
break; |
|
655 |
} |
} |
656 |
|
|
657 |
#ifdef WITH_DEBUG_KBD |
#ifdef WITH_DEBUG_KBD |