32 |
extern int g_height; |
extern int g_height; |
33 |
extern int g_xpos; |
extern int g_xpos; |
34 |
extern int g_ypos; |
extern int g_ypos; |
35 |
|
extern int g_pos; |
36 |
extern BOOL g_sendmotion; |
extern BOOL g_sendmotion; |
37 |
extern BOOL g_fullscreen; |
extern BOOL g_fullscreen; |
38 |
extern BOOL g_grab_keyboard; |
extern BOOL g_grab_keyboard; |
1164 |
wndwidth = g_fullscreen ? WidthOfScreen(g_screen) : g_width; |
wndwidth = g_fullscreen ? WidthOfScreen(g_screen) : g_width; |
1165 |
wndheight = g_fullscreen ? HeightOfScreen(g_screen) : g_height; |
wndheight = g_fullscreen ? HeightOfScreen(g_screen) : g_height; |
1166 |
|
|
1167 |
|
/* Handle -x-y portion of geometry string */ |
1168 |
|
if (g_xpos < 0 || (g_xpos == 0 && (g_pos & 2))) |
1169 |
|
g_xpos = WidthOfScreen(g_screen) + g_xpos - g_width; |
1170 |
|
if (g_ypos < 0 || (g_ypos == 0 && (g_pos & 4))) |
1171 |
|
g_ypos = HeightOfScreen(g_screen) + g_ypos - g_height; |
1172 |
|
|
1173 |
attribs.background_pixel = BlackPixelOfScreen(g_screen); |
attribs.background_pixel = BlackPixelOfScreen(g_screen); |
1174 |
attribs.border_pixel = WhitePixelOfScreen(g_screen); |
attribs.border_pixel = WhitePixelOfScreen(g_screen); |
1175 |
attribs.backing_store = g_ownbackstore ? NotUseful : Always; |
attribs.backing_store = g_ownbackstore ? NotUseful : Always; |
1213 |
if (sizehints) |
if (sizehints) |
1214 |
{ |
{ |
1215 |
sizehints->flags = PMinSize | PMaxSize; |
sizehints->flags = PMinSize | PMaxSize; |
1216 |
|
if (g_pos) |
1217 |
|
sizehints->flags |= PPosition; |
1218 |
sizehints->min_width = sizehints->max_width = g_width; |
sizehints->min_width = sizehints->max_width = g_width; |
1219 |
sizehints->min_height = sizehints->max_height = g_height; |
sizehints->min_height = sizehints->max_height = g_height; |
1220 |
XSetWMNormalHints(g_display, g_wnd, sizehints); |
XSetWMNormalHints(g_display, g_wnd, sizehints); |
1227 |
} |
} |
1228 |
|
|
1229 |
input_mask = KeyPressMask | KeyReleaseMask | ButtonPressMask | ButtonReleaseMask | |
input_mask = KeyPressMask | KeyReleaseMask | ButtonPressMask | ButtonReleaseMask | |
1230 |
VisibilityChangeMask | FocusChangeMask; |
VisibilityChangeMask | FocusChangeMask | StructureNotifyMask; |
1231 |
|
|
1232 |
if (g_sendmotion) |
if (g_sendmotion) |
1233 |
input_mask |= PointerMotionMask; |
input_mask |= PointerMotionMask; |
1341 |
} |
} |
1342 |
} |
} |
1343 |
|
|
1344 |
/* Process all events in Xlib queue |
/* Process events in Xlib queue |
1345 |
Returns 0 after user quit, 1 otherwise */ |
Returns 0 after user quit, 1 otherwise */ |
1346 |
static int |
static int |
1347 |
xwin_process_events(void) |
xwin_process_events(void) |
1350 |
KeySym keysym; |
KeySym keysym; |
1351 |
uint16 button, flags; |
uint16 button, flags; |
1352 |
uint32 ev_time; |
uint32 ev_time; |
|
key_translation tr; |
|
1353 |
char str[256]; |
char str[256]; |
1354 |
Status status; |
Status status; |
1355 |
|
int events = 0; |
1356 |
|
|
1357 |
while (XPending(g_display) > 0) |
while ((XPending(g_display) > 0) && events++ < 20) |
1358 |
{ |
{ |
1359 |
XNextEvent(g_display, &xevent); |
XNextEvent(g_display, &xevent); |
1360 |
|
|
1402 |
str, sizeof(str), &keysym, NULL); |
str, sizeof(str), &keysym, NULL); |
1403 |
} |
} |
1404 |
|
|
1405 |
DEBUG_KBD(("KeyPress for (keysym 0x%lx, %s)\n", keysym, |
DEBUG_KBD(("KeyPress for keysym (0x%lx, %s)\n", keysym, |
1406 |
get_ksname(keysym))); |
get_ksname(keysym))); |
1407 |
|
|
1408 |
ev_time = time(NULL); |
ev_time = time(NULL); |
1409 |
if (handle_special_keys(keysym, xevent.xkey.state, ev_time, True)) |
if (handle_special_keys(keysym, xevent.xkey.state, ev_time, True)) |
1410 |
break; |
break; |
1411 |
|
|
1412 |
tr = xkeymap_translate_key(keysym, |
xkeymap_send_keys(keysym, xevent.xkey.keycode, xevent.xkey.state, |
1413 |
xevent.xkey.keycode, xevent.xkey.state); |
ev_time, True, 0); |
|
|
|
|
if (tr.scancode == 0) |
|
|
break; |
|
|
|
|
|
save_remote_modifiers(tr.scancode); |
|
|
ensure_remote_modifiers(ev_time, tr); |
|
|
rdp_send_scancode(ev_time, RDP_KEYPRESS, tr.scancode); |
|
|
restore_remote_modifiers(ev_time, tr.scancode); |
|
|
|
|
1414 |
break; |
break; |
1415 |
|
|
1416 |
case KeyRelease: |
case KeyRelease: |
1418 |
XLookupString((XKeyEvent *) & xevent, str, |
XLookupString((XKeyEvent *) & xevent, str, |
1419 |
sizeof(str), &keysym, NULL); |
sizeof(str), &keysym, NULL); |
1420 |
|
|
1421 |
DEBUG_KBD(("\nKeyRelease for (keysym 0x%lx, %s)\n", keysym, |
DEBUG_KBD(("\nKeyRelease for keysym (0x%lx, %s)\n", keysym, |
1422 |
get_ksname(keysym))); |
get_ksname(keysym))); |
1423 |
|
|
1424 |
ev_time = time(NULL); |
ev_time = time(NULL); |
1425 |
if (handle_special_keys(keysym, xevent.xkey.state, ev_time, False)) |
if (handle_special_keys(keysym, xevent.xkey.state, ev_time, False)) |
1426 |
break; |
break; |
1427 |
|
|
1428 |
tr = xkeymap_translate_key(keysym, |
xkeymap_send_keys(keysym, xevent.xkey.keycode, xevent.xkey.state, |
1429 |
xevent.xkey.keycode, xevent.xkey.state); |
ev_time, False, 0); |
|
|
|
|
if (tr.scancode == 0) |
|
|
break; |
|
|
|
|
|
rdp_send_scancode(ev_time, RDP_KEYRELEASE, tr.scancode); |
|
1430 |
break; |
break; |
1431 |
|
|
1432 |
case ButtonPress: |
case ButtonPress: |
1584 |
case PropertyNotify: |
case PropertyNotify: |
1585 |
xclip_handle_PropertyNotify(&xevent.xproperty); |
xclip_handle_PropertyNotify(&xevent.xproperty); |
1586 |
break; |
break; |
1587 |
|
case MapNotify: |
1588 |
|
rdp_send_client_window_status(1); |
1589 |
|
break; |
1590 |
|
case UnmapNotify: |
1591 |
|
rdp_send_client_window_status(0); |
1592 |
|
break; |
1593 |
} |
} |
1594 |
} |
} |
1595 |
/* Keep going */ |
/* Keep going */ |