diff options
| author | Dana Jansens <danakj@orodu.net> | 2003-03-18 09:21:07 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2003-03-18 09:21:07 +0000 |
| commit | 65abaf0d5078b043581c04f356c5b18575d9ed72 (patch) | |
| tree | ac30d14862cde47395fe615070ddb5743cd761d3 /plugins | |
| parent | a91a6f97daeb058f346246081e1c83a788787f9b (diff) | |
warp the pointer on a workspace change to the focused window
Diffstat (limited to 'plugins')
| -rw-r--r-- | plugins/focus.c | 30 |
1 files changed, 20 insertions, 10 deletions
diff --git a/plugins/focus.c b/plugins/focus.c index a95f8d69..52e6f99e 100644 --- a/plugins/focus.c +++ b/plugins/focus.c @@ -3,14 +3,29 @@ #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 @@ static void events(ObEvent *e, void *foo) 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: |
