]> Dogcows Code - chaz/openbox/commitdiff
move windows around before removing the focus order lists to prevent nasty segfault...
authorDana Jansens <danakj@orodu.net>
Mon, 8 Sep 2003 00:58:10 +0000 (00:58 +0000)
committerDana Jansens <danakj@orodu.net>
Mon, 8 Sep 2003 00:58:10 +0000 (00:58 +0000)
openbox/screen.c

index 53dce6e78f56827fffa728f8b2f4b7d41abdf7d7..656206bf712d94420821126f69a85564112ba1d4 100644 (file)
@@ -366,29 +366,29 @@ void screen_set_num_desktops(guint num)
     /* 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)
This page took 0.026642 seconds and 4 git commands to generate.