stacked and linear cycling

This commit is contained in:
Dana Jansens 2003-04-05 22:44:50 +00:00
parent 7ebc5c797f
commit ec4e24a422

View file

@ -168,6 +168,14 @@ Action *action_from_string(char *name)
a = action_new(action_cycle_windows); a = action_new(action_cycle_windows);
a->data.cycle.linear = TRUE; a->data.cycle.linear = TRUE;
a->data.cycle.forward = FALSE; a->data.cycle.forward = FALSE;
} else if (!g_ascii_strcasecmp(name, "nextwindow")) {
a = action_new(action_cycle_windows);
a->data.cycle.linear = FALSE;
a->data.cycle.forward = TRUE;
} else if (!g_ascii_strcasecmp(name, "previouswindow")) {
a = action_new(action_cycle_windows);
a->data.cycle.linear = FALSE;
a->data.cycle.forward = FALSE;
} }
return a; return a;
@ -666,25 +674,38 @@ void action_showmenu(union ActionData *data)
void action_cycle_windows(union ActionData *data) void action_cycle_windows(union ActionData *data)
{ {
if (data->cycle.linear) {
static Client *first = NULL; static Client *first = NULL;
static Client *t = NULL; static Client *t = NULL;
static GList *order = NULL;
GList *it, *start, *list;
if (data->cycle.cancel) { if (data->cycle.cancel) {
if (first) client_focus(first); if (first) client_focus(first);
} else if (!data->cycle.final) { goto done_cycle;
GList *it, *start; }
if (!first) first = focus_client;
if (data->cycle.linear)
list = client_list;
else {
if (!order) order = g_list_copy(focus_order[screen_desktop]);
list = order;
}
start = it = g_list_find(list, data->cycle.c);
if (!start) goto done_cycle;
if (!data->cycle.final) {
t = NULL; t = NULL;
first = focus_client; if (!start) /* switched desktops or something? */
start = it = g_list_find(client_list, data->cycle.c); goto done_cycle;
do { do {
if (data->cycle.forward) { if (data->cycle.forward) {
it = it->next; it = it->next;
if (it == NULL) it = client_list; if (it == NULL) it = list;
} else { } else {
it = it->prev; it = it->prev;
if (it == NULL) it = g_list_last(client_list); if (it == NULL) it = g_list_last(list);
} }
if (client_focus(it->data)) { if (client_focus(it->data)) {
t = it->data; t = it->data;
@ -693,8 +714,13 @@ void action_cycle_windows(union ActionData *data)
} while (it != start); } while (it != start);
} else { } else {
if (t) stacking_raise(t); if (t) stacking_raise(t);
goto done_cycle;
} }
} else { return;
}
done_cycle:
first = NULL;
g_list_free(order);
order = NULL;
} }