]> Dogcows Code - chaz/openbox/commitdiff
hilight the fallback target before it actually gets focused to avoid flickering
authorDana Jansens <danakj@orodu.net>
Fri, 3 Oct 2003 04:43:18 +0000 (04:43 +0000)
committerDana Jansens <danakj@orodu.net>
Fri, 3 Oct 2003 04:43:18 +0000 (04:43 +0000)
openbox/screen.c

index 9c4620b293e7cbea6478e2c53c4a5a26e2cd7577..f7c71abe07d0445c166595ea5b6889b9f6f93ff2 100644 (file)
@@ -418,6 +418,7 @@ void screen_set_desktop(guint num)
 {
     GList *it;
     guint old;
+    ObClient *target;
      
     g_assert(num < screen_num_desktops);
 
@@ -438,16 +439,16 @@ void screen_set_desktop(guint num)
     /* show windows before hiding the rest to lessen the enter/leave events */
 
     /* show windows from top to bottom */
-    for (it = stacking_list; it != NULL; it = it->next) {
+    for (it = stacking_list; it; it = g_list_next(it)) {
         if (WINDOW_IS_CLIENT(it->data)) {
             ObClient *c = it->data;
-            if (!c->frame->visible && client_should_show(c))
+            if (client_should_show(c))
                 frame_show(c->frame);
         }
     }
 
     /* hide windows from bottom to top */
-    for (it = g_list_last(stacking_list); it != NULL; it = it->prev) {
+    for (it = g_list_last(stacking_list); it; it = g_list_previous(it)) {
         if (WINDOW_IS_CLIENT(it->data)) {
             ObClient *c = it->data;
             if (c->frame->visible && !client_should_show(c))
@@ -457,13 +458,18 @@ void screen_set_desktop(guint num)
 
     event_ignore_queued_enters();
 
-    /*!
-      When this focus_client check is not used, you can end up with races, as
-      demonstrated with gnome-panel, sometmies the window you click on on
-      another desktop ends up losing focus cuz of the fallback.
-    */
-    if (!focus_client)
-        focus_fallback(OB_FOCUS_FALLBACK_NOFOCUS);
+    target = focus_fallback_target(OB_FOCUS_FALLBACK_NOFOCUS);
+    if (target) {
+        frame_adjust_focus(target->frame, TRUE);
+
+        /*!
+          When this focus_client check is not used, you can end up with races,
+          as demonstrated with gnome-panel, sometmies the window you click on
+          another desktop ends up losing focus cuz of the focus change here.
+        */
+        if (!focus_client)
+            client_focus(target);
+    }
 }
 
 static void get_row_col(guint d, guint *r, guint *c)
This page took 0.025889 seconds and 4 git commands to generate.