keep stacking_list_tail a pointer to the tail of the stacking list
Dana Jansens danakj@orodu.net
2 files changed,
8 insertions(+),
0 deletions(-)
M
openbox/stacking.c
→
openbox/stacking.c
@@ -29,6 +29,7 @@ #include "debug.h"
#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 @@ stacking_list = g_list_remove(stacking_list, 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 @@ stacking_list = g_list_remove(stacking_list, 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 @@ stacking_list = g_list_remove(stacking_list, window);
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 @@
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 @@
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
M
openbox/stacking.h
→
openbox/stacking.h
@@ -40,6 +40,8 @@ } ObStackingLayer;
/* 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 */