From 46c101dfaa29dab817569708e559c4b90754521a Mon Sep 17 00:00:00 2001 From: Sean Pringle Date: Tue, 30 Dec 2014 13:11:59 +1000 Subject: [PATCH] warp pointer on relevant keyboard actions --- action.c | 12 +++++++++--- spot.c | 15 +++++++++++++++ 2 files changed, 24 insertions(+), 3 deletions(-) diff --git a/action.c b/action.c index 4149031..d0e807a 100644 --- a/action.c +++ b/action.c @@ -29,6 +29,7 @@ void action_move(void *data, int num, Client *cli) if (!cli) return; client_raise_family(cli); client_place_spot(cli, num, cli->monitor, 1); + spot_warp_pointer(cli->spot, cli->monitor); } void action_move_direction(void *data, int num, Client *cli) @@ -36,16 +37,19 @@ void action_move_direction(void *data, int num, Client *cli) if (!cli) return; client_raise_family(cli); client_place_spot(cli, spot_choose_by_direction(cli->spot, cli->monitor, num), cli->monitor, 1); + spot_warp_pointer(cli->spot, cli->monitor); } void action_focus(void *data, int num, Client *cli) { spot_try_focus_top_window(num, current_mon, None); + spot_warp_pointer(current_spot, current_mon); } void action_focus_direction(void *data, int num, Client *cli) { spot_try_focus_top_window(spot_choose_by_direction(current_spot, current_mon, num), current_mon, None); + spot_warp_pointer(current_spot, current_mon); } void action_close(void *data, int num, Client *cli) @@ -87,7 +91,7 @@ void action_find_or_start(void *data, int num, Client *cli) int i; Client *c; char *class = data; for_windows(i, c) if (c->visible && c->manage && c->class && !strcasecmp(c->class, class)) - { client_activate(c); return; } + { client_activate(c); spot_warp_pointer(cli->spot, cli->monitor); return; } exec_cmd(class); } @@ -98,13 +102,15 @@ void action_move_monitor(void *data, int num, Client *cli) cli->monitor = MAX(0, MIN(current_mon+num, nmonitors-1)); client_place_spot(cli, cli->spot, cli->monitor, 1); current_mon = cli->monitor; + spot_warp_pointer(cli->spot, cli->monitor); } void action_focus_monitor(void *data, int num, Client *cli) { int i, mon = MAX(0, MIN(current_mon+num, nmonitors-1)); - if (spot_focus_top_window(current_spot, mon, None)) return; - for_spots(i) if (spot_focus_top_window(i, mon, None)) break; + if (!spot_focus_top_window(current_spot, mon, None)) + for_spots(i) if (spot_focus_top_window(i, mon, None)) break; + spot_warp_pointer(current_spot, current_mon); } void action_fullscreen(void *data, int num, Client *cli) diff --git a/spot.c b/spot.c index 8e262d0..c083977 100644 --- a/spot.c +++ b/spot.c @@ -85,6 +85,21 @@ void update_bars() spot_update_bar(j, i); } +void spot_warp_pointer(int spot, int mon) +{ + Window wroot, child; + int root_x, root_y, win_x, win_y; + unsigned int mask; + + if (XQueryPointer(display, root, &wroot, &child, &root_x, &root_y, &win_x, &win_y, &mask) + && !INTERSECT(monitors[mon].spots[spot].x, monitors[mon].spots[spot].y, monitors[mon].spots[spot].w, monitors[mon].spots[spot].h, root_x, root_y, 1, 1)) + { + XWarpPointer(display, None, root, 0, 0, 0, 0, + monitors[mon].spots[spot].x + monitors[mon].spots[spot].w - 10, + monitors[mon].spots[spot].y + 10); + } +} + Window spot_focus_top_window(int spot, int mon, Window except) { int i; Client *c;