]> Dogcows Code - chaz/openbox/commitdiff
smarter picking valid focus cycle targets
authorDana Jansens <danakj@orodu.net>
Fri, 26 Sep 2003 19:04:18 +0000 (19:04 +0000)
committerDana Jansens <danakj@orodu.net>
Fri, 26 Sep 2003 19:04:18 +0000 (19:04 +0000)
openbox/focus.c

index dd83061f2dd83feb0002a1f4d67661c2ae635daa..302c4fc425fc7eca4c82b6937341c57863c325c4 100644 (file)
@@ -179,10 +179,6 @@ void focus_fallback(ObFocusFallbackType type)
     */
     focus_set_client(NULL);
 
-    if (!config_focus_last && config_focus_follow)
-        if (focus_under_pointer())
-            return;
-
     if (type == OB_FOCUS_FALLBACK_UNFOCUSING && old) {
         /* try for transient relations */
         if (old->transient_for) {
@@ -201,6 +197,10 @@ void focus_fallback(ObFocusFallbackType type)
             }
         }
 
+    if (!config_focus_last && config_focus_follow)
+        if (focus_under_pointer())
+            return;
+
 #if 0
         /* try for group relations */
         if (old->group) {
@@ -276,7 +276,7 @@ static gboolean valid_focus_target(ObClient *ft)
        focus an iconic window, but we want to be able to, so we just check
        if the focus flags on the window allow it, and its on the current
        desktop */
-    return (ft->transients == NULL && client_normal(ft) &&
+    return (ft == client_focus_target(ft) && client_normal(ft) &&
             ((ft->can_focus || ft->focus_notify) &&
              !ft->skip_taskbar &&
              (ft->desktop == screen_desktop || ft->desktop == DESKTOP_ALL)));
@@ -324,7 +324,6 @@ void focus_cycle(gboolean forward, gboolean linear,
             it = it->prev;
             if (it == NULL) it = g_list_last(list);
         }
-        /*ft = client_focus_target(it->data);*/
         ft = it->data;
         if (valid_focus_target(ft)) {
             if (ft != focus_cycle_target) { /* prevents flicker */
This page took 0.022759 seconds and 4 git commands to generate.