summaryrefslogtreecommitdiff
path: root/openbox
diff options
context:
space:
mode:
authorDana Jansens <danakj@orodu.net>2010-06-09 10:38:55 -0400
committerDana Jansens <danakj@orodu.net>2010-06-14 12:19:01 -0400
commite1a51bdf10b336a0cc4779ebb6f62b55273c22e1 (patch)
tree34728b6150d071db1ddb919de68b37060bd264c6 /openbox
parent6d95e2441a1ebba1ec108860d08aceee852c6747 (diff)
keep stacking_list_tail a pointer to the tail of the stacking list
Diffstat (limited to 'openbox')
-rw-r--r--openbox/stacking.c6
-rw-r--r--openbox/stacking.h2
2 files changed, 8 insertions, 0 deletions
diff --git a/openbox/stacking.c b/openbox/stacking.c
index 405b7bd4..58a85eca 100644
--- a/openbox/stacking.c
+++ b/openbox/stacking.c
@@ -29,6 +29,7 @@
#include "obt/prop.h"
GList *stacking_list = NULL;
+GList *stacking_list_tail = NULL;
/*! When true, stacking changes will not be reflected on the screen. This is
to freeze the on-screen stacking order while a window is being temporarily
raised during focus cycling */
@@ -403,6 +404,7 @@ void stacking_raise(ObWindow *window)
do_raise(wins);
g_list_free(wins);
}
+ stacking_list_tail = g_list_last(stacking_list);
}
void stacking_lower(ObWindow *window)
@@ -418,6 +420,7 @@ void stacking_lower(ObWindow *window)
do_lower(wins);
g_list_free(wins);
}
+ stacking_list_tail = g_list_last(stacking_list);
}
void stacking_below(ObWindow *window, ObWindow *below)
@@ -432,6 +435,7 @@ void stacking_below(ObWindow *window, ObWindow *below)
before = g_list_next(g_list_find(stacking_list, below));
do_restack(wins, before);
g_list_free(wins);
+ stacking_list_tail = g_list_last(stacking_list);
}
void stacking_add(ObWindow *win)
@@ -444,6 +448,7 @@ void stacking_add(ObWindow *win)
stacking_list = g_list_append(stacking_list, win);
stacking_raise(win);
+ /* stacking_list_tail set by stacking_raise() */
}
static GList *find_highest_relative(ObClient *client)
@@ -556,6 +561,7 @@ void stacking_add_nonintrusive(ObWindow *win)
wins = g_list_append(NULL, win);
do_restack(wins, it_below);
g_list_free(wins);
+ stacking_list_tail = g_list_last(stacking_list);
}
/*! Returns TRUE if client is occluded by the sibling. If sibling is NULL it
diff --git a/openbox/stacking.h b/openbox/stacking.h
index 773f6588..c14aa2ed 100644
--- a/openbox/stacking.h
+++ b/openbox/stacking.h
@@ -40,6 +40,8 @@ typedef enum {
/* list of ObWindow*s in stacking order from highest to lowest */
extern GList *stacking_list;
+/* list of ObWindow*s in stacking order from lowest to highest */
+extern GList *stacking_list_tail;
/*! Sets the window stacking list on the root window from the
stacking_list */