From: Michael Stapelberg Date: Fri, 7 Jan 2011 22:56:32 +0000 (+0100) Subject: Bugfix: Correctly move to other workspaces when a floating window is focused on the... X-Git-Tag: tree-pr2~127 X-Git-Url: https://git.sur5r.net/?a=commitdiff_plain;h=b660769fe0f306552ee92a00c60650d6f3ef06c8;p=i3%2Fi3 Bugfix: Correctly move to other workspaces when a floating window is focused on the target ws (Thanks mseed) --- diff --git a/src/con.c b/src/con.c index f105a279..ba42a13d 100644 --- 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); }