all repos — openbox @ 50d70283347236df2ce43718c73b0568067b9629

openbox fork - make it a bit more like ryudo

move windows around before removing the focus order lists to prevent nasty segfault when it removes a window from an already freed list
Dana Jansens danakj@orodu.net
commit

50d70283347236df2ce43718c73b0568067b9629

parent

237cc7278bb57033dad93420d02552e6a910ae82

1 files changed, 11 insertions(+), 11 deletions(-)

jump to
M openbox/screen.copenbox/screen.c

@@ -366,29 +366,29 @@

/* may be some unnamed desktops that we need to fill in with names */ screen_update_desktop_names(); - /* update the focus lists */ - /* free our lists for the desktops which have disappeared */ - for (i = num; i < old; ++i) - g_list_free(focus_order[i]); - /* realloc the array */ - focus_order = g_renew(GList*, focus_order, num); - /* set the new lists to be empty */ - for (i = old; i < num; ++i) - focus_order[i] = NULL; - /* move windows on desktops that will no longer exist! */ for (it = client_list; it != NULL; it = it->next) { ObClient *c = it->data; if (c->desktop >= num && c->desktop != DESKTOP_ALL) client_set_desktop(c, num - 1, FALSE); } - + /* change our struts/area to match (after moving windows) */ screen_update_areas(); /* change our desktop if we're on one that no longer exists! */ if (screen_desktop >= screen_num_desktops) screen_set_desktop(num - 1); + + /* update the focus lists */ + /* free our lists for the desktops which have disappeared */ + for (i = num; i < old; ++i) + g_list_free(focus_order[i]); + /* realloc the array */ + focus_order = g_renew(GList*, focus_order, num); + /* set the new lists to be empty */ + for (i = old; i < num; ++i) + focus_order[i] = NULL; } void screen_set_desktop(guint num)