keep stacking_list_tail a pointer to the tail of the stacking list

This commit is contained in:
Dana Jansens 2010-06-09 10:38:55 -04:00
parent 6d95e2441a
commit e1a51bdf10
2 changed files with 8 additions and 0 deletions

View file

@ -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

View file

@ -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 */