diff --git a/sway/commands/move.c b/sway/commands/move.c index 8891514c..15d44210 100644 --- a/sway/commands/move.c +++ b/sway/commands/move.c @@ -22,7 +22,7 @@ #include "util.h" static const char expected_syntax[] = - "Expected 'move <[px] px>' or " + "Expected 'move [ [px|ppt]]' or " "'move [--no-auto-back-and-forth] [to] workspace ' or " "'move [to] output ' or " "'move [to] mark '"; @@ -702,13 +702,21 @@ static struct cmd_results *cmd_move_workspace(int argc, char **argv) { static struct cmd_results *cmd_move_in_direction( enum wlr_direction direction, int argc, char **argv) { + //DEBUG + for (int i = 0; i < argc; i++) { + printf("argv[%d]: %s\n", i, argv[i]); + } int move_amt = 10; + bool is_ppt = false; if (argc) { char *inv; move_amt = (int)strtol(argv[0], &inv, 10); - if (*inv != '\0' && strcasecmp(inv, "px") != 0) { + if (*inv != '\0') { return cmd_results_new(CMD_FAILURE, "Invalid distance specified"); } + if (argc > 1 && strcasecmp(argv[1], "ppt") == 0) { + is_ppt = true; + } } struct sway_container *container = config->handler_context.container; @@ -725,16 +733,16 @@ static struct cmd_results *cmd_move_in_direction( double ly = container->pending.y; switch (direction) { case WLR_DIRECTION_LEFT: - lx -= move_amt; + lx -= is_ppt ? container->pending.width * ((double)move_amt / 100.0) : move_amt; break; case WLR_DIRECTION_RIGHT: - lx += move_amt; + lx += is_ppt ? container->pending.width * ((double)move_amt / 100.0) : move_amt; break; case WLR_DIRECTION_UP: - ly -= move_amt; + ly -= is_ppt ? container->pending.height * ((double)move_amt / 100.0) : move_amt; break; case WLR_DIRECTION_DOWN: - ly += move_amt; + ly += is_ppt ? container->pending.height * ((double)move_amt / 100.0) : move_amt; break; } container_floating_move_to(container, lx, ly); @@ -980,7 +988,7 @@ static struct cmd_results *cmd_move_to_scratchpad(void) { } static const char expected_full_syntax[] = "Expected " - "'move left|right|up|down [ [px]]'" + "'move left|right|up|down [ [px|ppt]]'" " or 'move [--no-auto-back-and-forth] [window|container] [to] workspace" " |next|prev|next_on_output|prev_on_output|current|(number )'" " or 'move [window|container] [to] output |left|right|up|down'" diff --git a/sway/sway.5.scd b/sway/sway.5.scd index 9bc03c9d..a4ce1c6b 100644 --- a/sway/sway.5.scd +++ b/sway/sway.5.scd @@ -231,10 +231,11 @@ set|plus|minus|toggle the per-output *allow_tearing* setting. See *sway-output*(5) for further details. -*move* left|right|up|down [ px] - Moves the focused container in the direction specified. The optional _px_ - argument specifies how many pixels to move the container. If unspecified, - the default is 10 pixels. Pixels are ignored when moving tiled containers. +*move* left|right|up|down [ [px|ppt]] + Moves the focused container in the specified direction. The distance can be + specified in pixels or percentage points, omitting the unit defaults to pixels. + If unspecified, the default is 10 pixels. Pixels are ignored when moving tiled + containers. *move* [absolute] position [px|ppt] [px|ppt] Moves the focused container to the specified position in the workspace.