]> git.sur5r.net Git - i3/i3/commitdiff
Bugfix: Correctly move to other workspaces when a floating window is focused on the...
authorMichael Stapelberg <michael@stapelberg.de>
Fri, 7 Jan 2011 22:56:32 +0000 (23:56 +0100)
committerMichael Stapelberg <michael@stapelberg.de>
Fri, 7 Jan 2011 22:56:32 +0000 (23:56 +0100)
src/con.c

index f105a27946f165eb87c25da15e546eadd0105092..ba42a13dbaedecc68a5db685771cd67682f5957c 100644 (file)
--- a/src/con.c
+++ b/src/con.c
@@ -467,12 +467,21 @@ void con_move_to_workspace(Con *con, Con *workspace) {
     if (next->type != CT_WORKSPACE)
         next = next->parent;
 
+    /* 4: if the target container is floating, we get the workspace instead.
+     * Only tiling windows need to get inserted next to the current container.
+     * */
+    Con *floatingcon = con_inside_floating(next);
+    if (floatingcon != NULL) {
+        DLOG("floatingcon, going up even further\n");
+        next = floatingcon->parent;
+    }
+
     DLOG("Re-attaching container to %p / %s\n", next, next->name);
-    /* 4: re-attach the con to the parent of this focused container */
+    /* 5: re-attach the con to the parent of this focused container */
     con_detach(con);
     con_attach(con, next, false);
 
-    /* 5: keep focus on the current workspace */
+    /* 6: keep focus on the current workspace */
     con_focus(focus_next);
 }