X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fstacking.c;h=58a85ecade840762317ba5cadf64c3f8ec8f32d3;hb=e1a51bdf10b336a0cc4779ebb6f62b55273c22e1;hp=405b7bd4546e08e772a07a23bde4cb8171e291b5;hpb=6d95e2441a1ebba1ec108860d08aceee852c6747;p=chaz%2Fopenbox 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