diff options
| author | Dana Jansens <danakj@orodu.net> | 2007-06-22 14:09:57 +0000 |
|---|---|---|
| committer | Dana Jansens <danakj@orodu.net> | 2007-06-22 14:09:57 +0000 |
| commit | 6c5f6ed1f5d501c79977a55c0f2430ebdd32ef6c (patch) | |
| tree | a597f90dd3de04e455a0942f79307dcb65428caa /openbox/actions/focus.c | |
| parent | d642be361fde438e2b29b7374b4d6465f47ad9e9 (diff) | |
remove the activate action, make the focus action "activate" but not raise or unshade
Diffstat (limited to 'openbox/actions/focus.c')
| -rw-r--r-- | openbox/actions/focus.c | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/openbox/actions/focus.c b/openbox/actions/focus.c new file mode 100644 index 00000000..9be6741c --- /dev/null +++ b/openbox/actions/focus.c @@ -0,0 +1,62 @@ +#include "openbox/actions.h" +#include "openbox/event.h" +#include "openbox/client.h" +#include "openbox/focus.h" + +typedef struct { + gboolean here; +} Options; + +static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node); +static void free_func(gpointer options); +static gboolean run_func(ObActionsData *data, gpointer options); + +void action_focus_startup() +{ + actions_register("Focus", + setup_func, + free_func, + run_func, + NULL, NULL); +} + +static gpointer setup_func(ObParseInst *i, xmlDocPtr doc, xmlNodePtr node) +{ + xmlNodePtr n; + Options *o; + + o = g_new0(Options, 1); + + if ((n = parse_find_node("here", node))) + o->here = parse_bool(doc, n); + return o; +} + +static void free_func(gpointer options) +{ + Options *o = options; + + g_free(o); +} + +/* Always return FALSE because its not interactive */ +static gboolean run_func(ObActionsData *data, gpointer options) +{ + Options *o = options; + + if (data->client) { + if (data->button == 0 || client_mouse_focusable(data->client) || + data->context != OB_FRAME_CONTEXT_CLIENT || + data->context != OB_FRAME_CONTEXT_FRAME) + { + client_activate(data->client, o->here, FALSE, FALSE, TRUE); + } + } else { + /* focus action on something other than a client, make keybindings + work for this openbox instance, but don't focus any specific client + */ + focus_nothing(); + } + + return FALSE; +} |
