X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fstacking.c;h=4d04bb24bcce44f7193d912df676c028e6cdd9c6;hb=4ccc4c5ed7d5cffc4bf733191f7bc30fbbf069c8;hp=863263d21c781380ef238be3ad0509627fa25164;hpb=364dfe10ab3cb225dae100f81fe2684ce9f309c6;p=chaz%2Fopenbox diff --git a/openbox/stacking.c b/openbox/stacking.c index 863263d2..4d04bb24 100644 --- a/openbox/stacking.c +++ b/openbox/stacking.c @@ -42,13 +42,16 @@ static void do_restack(GList *wins, GList *before) Window *win; int i; +#ifdef DEBUG /* pls only restack stuff in the same layer at a time */ for (it = wins; it; it = next) { next = g_list_next(it); if (!next) break; g_assert (window_layer(it->data) == window_layer(next->data)); } - + if (before) + g_assert(window_layer(it->data) >= window_layer(before->data)); +#endif win = g_new(Window, g_list_length(wins) + 1); @@ -66,12 +69,14 @@ static void do_restack(GList *wins, GList *before) stacking_list = g_list_insert_before(stacking_list, before, it->data); } - /* XXX some debug checking of the stacking list's order */ +#ifdef DEBUG + /* some debug checking of the stacking list's order */ for (it = stacking_list; ; it = next) { next = g_list_next(it); if (!next) break; g_assert(window_layer(it->data) >= window_layer(next->data)); } +#endif XRestackWindows(ob_display, win, i); g_free(win); @@ -205,7 +210,9 @@ static GList *pick_windows(ObClient *top, ObClient *selected, gboolean raise) return ret; } -static GList *pick_group_windows(ObClient *top, ObClient *selected, gboolean raise) +#if 0 +static GList *pick_group_windows(ObClient *top, ObClient *selected, + gboolean raise) { GList *ret = NULL; GList *it, *next, *prev; @@ -232,6 +239,7 @@ static GList *pick_group_windows(ObClient *top, ObClient *selected, gboolean rai } return ret; } +#endif void stacking_raise(ObWindow *window) { @@ -241,7 +249,8 @@ void stacking_raise(ObWindow *window) ObClient *c; ObClient *selected; selected = WINDOW_AS_CLIENT(window); - c = client_search_top_transient(selected); + g_message("raising 0x%x", selected->window); + /*c = client_search_top_transient(selected);*/ c = selected; wins = pick_windows(c, selected, TRUE); /*wins = g_list_concat(wins, pick_group_windows(c, selected, TRUE));*/ } else { @@ -271,6 +280,20 @@ void stacking_lower(ObWindow *window) g_list_free(wins); } +void stacking_below(ObWindow *window, ObWindow *below) +{ + GList *wins, *before; + + if (window_layer(window) != window_layer(below)) + return; + + wins = g_list_append(NULL, window); + 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); +} + void stacking_add(ObWindow *win) { ObStackingLayer l;