]> Dogcows Code - chaz/openbox/blobdiff - openbox/action.c
prevent flicker in the follow actiosn again instead of in focus fallback. focus fallb...
[chaz/openbox] / openbox / action.c
index 3a4bab154b5c25c1b4eb20847e58ccd9cd76279d..081b68f5293b921d91f1ba94f138cf21dc1fb5af 100644 (file)
@@ -1587,9 +1587,8 @@ void action_send_to_desktop(union ActionData *data)
     if (data->sendto.desk < screen_num_desktops ||
         data->sendto.desk == DESKTOP_ALL) {
         client_set_desktop(c, data->sendto.desk, data->sendto.follow);
-        if (data->sendto.follow)
-            screen_set_desktop(data->sendto.desk,
-                               data->sendto.follow && c == focus_client);
+        if (data->sendto.follow && data->sendto.desk != screen_desktop)
+            screen_set_desktop(data->sendto.desk, c != focus_client);
     }
 }
 
@@ -1602,7 +1601,7 @@ void action_desktop(union ActionData *data)
     {
         screen_set_desktop(data->desktop.desk, TRUE);
         if (data->inter.any.interactive)
-            screen_desktop_popup(data->desktop.desk, TRUE);
+            screen_desktop_popup(data->desktop.desk, focus_client->desktop != DESKTOP_ALL);
     }
 }
 
@@ -1622,7 +1621,7 @@ void action_desktop_dir(union ActionData *data)
     if (!data->sendtodir.inter.any.interactive ||
         (data->sendtodir.inter.final && !data->sendtodir.inter.cancel))
     {
-        if (d != screen_desktop) screen_set_desktop(d, TRUE);
+        if (d != screen_desktop) screen_set_desktop(d, focus_client->desktop != DESKTOP_ALL);
     }
 }
 
@@ -1646,7 +1645,7 @@ void action_send_to_desktop_dir(union ActionData *data)
     {
         client_set_desktop(c, d, data->sendtodir.follow);
         if (data->sendtodir.follow && d != screen_desktop)
-            screen_set_desktop(d, data->sendtodir.follow && c == focus_client);
+            screen_set_desktop(d, c != focus_client);
     }
 }
 
This page took 0.02318 seconds and 4 git commands to generate.