all repos — openbox @ 65abaf0d5078b043581c04f356c5b18575d9ed72

openbox fork - make it a bit more like ryudo

warp the pointer on a workspace change to the focused window
Dana Jansens danakj@orodu.net
commit

65abaf0d5078b043581c04f356c5b18575d9ed72

parent

a91a6f97daeb058f346246081e1c83a788787f9b

1 files changed, 20 insertions(+), 10 deletions(-)

jump to
M plugins/focus.cplugins/focus.c

@@ -3,14 +3,29 @@ #include "../kernel/screen.h"

#include "../kernel/client.h" #include "../kernel/focus.h" #include "../kernel/stacking.h" +#include "../kernel/openbox.h" static GSList **focus_order = NULL; +static void focus_fallback(guint desk, gboolean warp) +{ + GSList *it; + + for (it = focus_order[desk]; it != NULL; it = it->next) + if (client_focus(it->data)) { + if (warp) { /* XXX make this configurable */ + Client *c = it->data; + XWarpPointer(ob_display, None, c->window, 0, 0, 0, 0, + c->area.width / 2, c->area.height / 2); + } + break; + } +} + static void events(ObEvent *e, void *foo) { guint i; guint new, old; - GSList *it; switch (e->type) { case Event_Client_Mapped:

@@ -50,19 +65,14 @@ break;

case Event_Ob_Desktop: /* focus the next available target */ - new = e->data.o.num[0]; - for (it = focus_order[new]; it != NULL; it = it->next) - if (client_focus(it->data)) - break; + focus_fallback(e->data.o.num[0], TRUE); break; case Event_Client_Unfocus: - if (focus_client == NULL) { /* nothing is left with focus! */ + /* nothing is left with focus! */ + if (focus_client == NULL) /* focus the next available target */ - for (it = focus_order[screen_desktop]; it != NULL; it = it->next) - if (client_focus(it->data)) - break; - } + focus_fallback(screen_desktop, FALSE); break; case Event_Client_Focus: