summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2003-04-05 22:20:14 +0000
committerDana Jansens <danakj@orodu.net>2003-04-05 22:20:14 +0000
commit7ebc5c797f0435286f25f077e8329ec821fc5e53 (patch)
tree99106008e8e8b238a48374c88204608717d936f5
parent69c9b6211bbfa0211426a511991502bbacd14672 (diff)
linear focus cycling of the gods
-rw-r--r--openbox/action.c16
-rw-r--r--openbox/action.h1
-rw-r--r--plugins/keyboard/keyboard.c43
3 files changed, 47 insertions, 13 deletions
diff --git a/openbox/action.c b/openbox/action.c
index 0e41e2eb..fccabfcd 100644
--- a/openbox/action.c
+++ b/openbox/action.c
@@ -1,4 +1,5 @@
#include "client.h"
+#include "focus.h"
#include "stacking.h"
#include "frame.h"
#include "screen.h"
@@ -666,9 +667,16 @@ void action_showmenu(union ActionData *data)
void action_cycle_windows(union ActionData *data)
{
if (data->cycle.linear) {
- if (!data->cycle.final) {
+ static Client *first = NULL;
+ static Client *t = NULL;
+
+ if (data->cycle.cancel) {
+ if (first) client_focus(first);
+ } else if (!data->cycle.final) {
GList *it, *start;
+ t = NULL;
+ first = focus_client;
start = it = g_list_find(client_list, data->cycle.c);
do {
if (data->cycle.forward) {
@@ -678,9 +686,13 @@ void action_cycle_windows(union ActionData *data)
it = it->prev;
if (it == NULL) it = g_list_last(client_list);
}
- if (client_focus(it->data))
+ if (client_focus(it->data)) {
+ t = it->data;
break;
+ }
} while (it != start);
+ } else {
+ if (t) stacking_raise(t);
}
} else {
}
diff --git a/openbox/action.h b/openbox/action.h
index 0fe42f64..a5b1708e 100644
--- a/openbox/action.h
+++ b/openbox/action.h
@@ -73,6 +73,7 @@ struct CycleWindows {
gboolean linear;
gboolean forward;
gboolean final;
+ gboolean cancel;
};
union ActionData {
diff --git a/plugins/keyboard/keyboard.c b/plugins/keyboard/keyboard.c
index b2c5debf..81809649 100644
--- a/plugins/keyboard/keyboard.c
+++ b/plugins/keyboard/keyboard.c
@@ -19,7 +19,7 @@ void plugin_setup_config()
KeyBindingTree *firstnode = NULL;
static KeyBindingTree *curpos;
-static guint reset_key, reset_state;
+static guint reset_key, reset_state, button_return, button_escape;
static gboolean grabbed;
static void grab_keys(gboolean grab)
@@ -90,17 +90,31 @@ static void event(ObEvent *e, void *foo)
{
static KeyBindingTree *grabbed_key = NULL;
- if (e->type == Event_X_KeyRelease) {
- if (grabbed_key) {
- if (!(grabbed_key->state & e->data.x.e->xkey.state)) {
- grabbed_key->action->data.cycle.final = TRUE;
- grabbed_key->action->func(&grabbed_key->action->data);
- grab_keyboard(FALSE);
- grabbed_key = FALSE;
+ if (grabbed_key) {
+ gboolean done = FALSE;
+
+ if ((e->type == Event_X_KeyRelease &&
+ !(grabbed_key->state & e->data.x.e->xkey.state)))
+ done = TRUE;
+ else if (e->type == Event_X_KeyPress) {
+ if (e->data.x.e->xkey.keycode == button_return)
+ done = TRUE;
+ else if (e->data.x.e->xkey.keycode == button_escape) {
+ grabbed_key->action->data.cycle.cancel = TRUE;
+ done = TRUE;
}
}
- return;
+ if (done) {
+ grabbed_key->action->data.cycle.final = TRUE;
+ grabbed_key->action->func(&grabbed_key->action->data);
+ grab_keyboard(FALSE);
+ grabbed_key = NULL;
+ reset_chains();
+ return;
+ }
}
+ if (e->type == Event_X_KeyRelease)
+ return;
if (e->data.x.e->xkey.keycode == reset_key &&
e->data.x.e->xkey.state == reset_state) {
@@ -130,12 +144,15 @@ static void event(ObEvent *e, void *foo)
g_assert(!(p->action->func == action_move ||
p->action->func == action_resize));
- if (p->action->func == action_cycle_windows)
+ if (p->action->func == action_cycle_windows) {
p->action->data.cycle.final = FALSE;
+ p->action->data.cycle.cancel = FALSE;
+ }
p->action->func(&p->action->data);
- if (p->action->func == action_cycle_windows) {
+ if (p->action->func == action_cycle_windows &&
+ !grabbed_key) {
grab_keyboard(TRUE);
grabbed_key = p;
}
@@ -152,12 +169,16 @@ static void event(ObEvent *e, void *foo)
void plugin_startup()
{
+ guint i;
+
curpos = NULL;
grabbed = FALSE;
dispatch_register(Event_X_KeyPress | Event_X_KeyRelease, (EventHandler)event, NULL);
translate_key("C-g", &reset_state, &reset_key);
+ translate_key("Escape", &i, &button_escape);
+ translate_key("Return", &i, &button_return);
}
void plugin_shutdown()