diff options
author | Geoff Greer <geoff@greer.fm> | 2018-05-10 23:44:35 -0700 |
---|---|---|
committer | Geoff Greer <geoff@greer.fm> | 2018-05-10 23:44:35 -0700 |
commit | 87fa84df131bd30251a789360e73b6fe8162d71f (patch) | |
tree | 1291fe91f136f269f7ad4dcefb980a863c3e15f4 /sway/commands | |
parent | 8d99edf7870fbf4bf72837d0dded3991ceed0a95 (diff) | |
download | sway-87fa84df131bd30251a789360e73b6fe8162d71f.tar.xz |
cmd_move_container: Focus a window on the source workspace.
In Sway 0.15, moving a window to another workspace would cause a window on the source workspace to be focused. This restores that behavior, allowing you to quickly move a lot of windows to another workspace.
Diffstat (limited to 'sway/commands')
-rw-r--r-- | sway/commands/move.c | 10 |
1 files changed, 6 insertions, 4 deletions
diff --git a/sway/commands/move.c b/sway/commands/move.c index a5273ba4..890b1a8c 100644 --- a/sway/commands/move.c +++ b/sway/commands/move.c @@ -90,12 +90,14 @@ static struct cmd_results *cmd_move_container(struct sway_container *current, } free(ws_name); struct sway_container *old_parent = current->parent; - struct sway_container *focus = seat_get_focus_inactive( + struct sway_container *destination = seat_get_focus_inactive( config->handler_context.seat, ws); - container_move_to(current, focus); - seat_set_focus(config->handler_context.seat, old_parent); + container_move_to(current, destination); + struct sway_container *focus = seat_get_focus_inactive( + config->handler_context.seat, old_parent); + seat_set_focus(config->handler_context.seat, focus); container_reap_empty(old_parent); - container_reap_empty(focus->parent); + container_reap_empty(destination->parent); return cmd_results_new(CMD_SUCCESS, NULL, NULL); } else if (strcasecmp(argv[1], "to") == 0 && strcasecmp(argv[2], "output") == 0) { |