From e4a184e77e735c7bc387c832cae2d6454c4f9da9 Mon Sep 17 00:00:00 2001 From: Oliver Graff Date: Sat, 31 Mar 2018 15:56:59 -0400 Subject: [PATCH] Workspace renaming: Interpret outputs as nondirectional Currently when renaming outputs, an output assignment of "left" will cause the workspace to move left. Treat this assignment as a proper name instead (even though it is unlikely an output will be named "left"). Move logic for determining output to move to out of `workspace_move_to_output` Add test for ignoring direcionality during rename. Fixes #3208. --- include/workspace.h | 2 +- src/commands.c | 23 +++++++++++++++++++-- src/workspace.c | 10 ++------- testcases/t/522-rename-assigned-workspace.t | 12 +++++++++++ 4 files changed, 36 insertions(+), 11 deletions(-) diff --git a/include/workspace.h b/include/workspace.h index 1cb24939..ae287422 100644 --- a/include/workspace.h +++ b/include/workspace.h @@ -207,4 +207,4 @@ Con *workspace_encapsulate(Con *ws); * This returns true if and only if moving the workspace was successful. * */ -bool workspace_move_to_output(Con *ws, const char *output); +bool workspace_move_to_output(Con *ws, Output *output); diff --git a/src/commands.c b/src/commands.c index d2d15618..d6733a30 100644 --- a/src/commands.c +++ b/src/commands.c @@ -1128,7 +1128,21 @@ void cmd_move_workspace_to_output(I3_CMD, const char *name) { continue; } - bool success = workspace_move_to_output(ws, name); + Output *current_output = get_output_for_con(ws); + if (current_output == NULL) { + ELOG("Cannot get current output. This is a bug in i3.\n"); + ysuccess(false); + return; + } + + Output *target_output = get_output_from_string(current_output, name); + if (!target_output) { + ELOG("Could not get output from string \"%s\"\n", name); + ysuccess(false); + return; + } + + bool success = workspace_move_to_output(ws, target_output); if (!success) { ELOG("Failed to move workspace to output.\n"); ysuccess(false); @@ -1990,7 +2004,12 @@ void cmd_rename_workspace(I3_CMD, const char *old_name, const char *new_name) { continue; } - workspace_move_to_output(workspace, assignment->output); + Output *target_output = get_output_by_name(assignment->output, true); + if (!target_output) { + LOG("Could not get output named \"%s\"\n", assignment->output); + continue; + } + workspace_move_to_output(workspace, target_output); if (previously_focused) workspace_show(con_get_workspace(previously_focused)); diff --git a/src/workspace.c b/src/workspace.c index 643b78dd..a16479a5 100644 --- a/src/workspace.c +++ b/src/workspace.c @@ -923,8 +923,8 @@ Con *workspace_encapsulate(Con *ws) { * Move the given workspace to the specified output. * This returns true if and only if moving the workspace was successful. */ -bool workspace_move_to_output(Con *ws, const char *name) { - LOG("Trying to move workspace %p / %s to output \"%s\".\n", ws, ws->name, name); +bool workspace_move_to_output(Con *ws, Output *output) { + LOG("Trying to move workspace %p / %s to output %p / \"%s\".\n", ws, ws->name, output, output_primary_name(output)); Output *current_output = get_output_for_con(ws); if (current_output == NULL) { @@ -932,12 +932,6 @@ bool workspace_move_to_output(Con *ws, const char *name) { return false; } - Output *output = get_output_from_string(current_output, name); - if (!output) { - ELOG("Could not get output from string \"%s\"\n", name); - return false; - } - Con *content = output_get_content(output->con); LOG("got output %p with content %p\n", output, content); diff --git a/testcases/t/522-rename-assigned-workspace.t b/testcases/t/522-rename-assigned-workspace.t index 981471f7..8a6edc85 100644 --- a/testcases/t/522-rename-assigned-workspace.t +++ b/testcases/t/522-rename-assigned-workspace.t @@ -28,6 +28,7 @@ workspace 1 output fake-0 workspace 2 output fake-1 workspace 3:foo output fake-1 workspace baz output fake-1 +workspace 5 output left EOT my $i3 = i3(get_socket_path()); @@ -82,4 +83,15 @@ cmd 'rename workspace to baz'; is(get_output_for_workspace('baz'), 'fake-1', 'Renaming the workspace to a number and name should move it to the assigned output'); +########################################################################## +# Renaming a workspace so that it is assigned a directional output does +# not move the workspace or crash +########################################################################## + +cmd 'focus output fake-0'; +cmd 'workspace bar'; +cmd 'rename workspace to 5'; +is(get_output_for_workspace('5'), 'fake-0', + 'Renaming the workspace to a workspace assigned to a directional output should not move the workspace'); + done_testing; -- 2.39.2