Skip to content

Commit

Permalink
Merge pull request #709 from zandrmartin/set-size-command
Browse files Browse the repository at this point in the history
implement resize command for absolute dimensions
  • Loading branch information
ddevault authored Jun 11, 2016
2 parents f126805 + a6f4bf6 commit 3ce8cc8
Show file tree
Hide file tree
Showing 4 changed files with 40 additions and 16 deletions.
1 change: 1 addition & 0 deletions include/resize.h
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
#define _SWAY_RESIZE_H
#include <stdbool.h>

bool set_size_tiled(int amount, bool use_width);
bool resize_tiled(int amount, bool use_width);

#endif
37 changes: 21 additions & 16 deletions sway/commands.c
Original file line number Diff line number Diff line change
Expand Up @@ -2000,33 +2000,38 @@ static struct cmd_results *cmd_resize(int argc, char **argv) {
struct cmd_results *error = NULL;
if (config->reading) return cmd_results_new(CMD_FAILURE, "resize", "Can't be used in config file.");
if (!config->active) return cmd_results_new(CMD_FAILURE, "resize", "Can only be used when sway is running.");
if ((error = checkarg(argc, "resize", EXPECTED_AT_LEAST, 3))) {
if ((error = checkarg(argc, "resize", EXPECTED_AT_LEAST, 2))) {
return error;
}
char *end;
int amount = (int)strtol(argv[2], &end, 10);

int amount = (int)strtol(argv[argc - 1], NULL, 10);
if (errno == ERANGE || amount == 0) {
errno = 0;
return cmd_results_new(CMD_INVALID, "resize", "Number is out of range.");
}

if (strcmp(argv[0], "shrink") != 0 && strcmp(argv[0], "grow") != 0) {
return cmd_results_new(CMD_INVALID, "resize",
"Expected 'resize <shrink|grow> <width|height> <amount>'");
}

if (strcmp(argv[0], "shrink") == 0) {
amount *= -1;
}
if (strcmp(argv[0], "shrink") == 0 || strcmp(argv[0], "grow") == 0) {
if (strcmp(argv[0], "shrink") == 0) {
amount *= -1;
}

if (strcmp(argv[1], "width") == 0) {
resize_tiled(amount, true);
} else if (strcmp(argv[1], "height") == 0) {
resize_tiled(amount, false);
if (strcmp(argv[1], "width") == 0) {
resize_tiled(amount, true);
} else if (strcmp(argv[1], "height") == 0) {
resize_tiled(amount, false);
} else {
return cmd_results_new(CMD_INVALID, "resize",
"Expected 'resize <shrink|grow> <width|height> <amount>' or 'resize <width|height> <amount>'");
}
} else if (strcmp(argv[0], "width") == 0) {
set_size_tiled(amount, true);
} else if (strcmp(argv[0], "height") == 0) {
set_size_tiled(amount, false);
} else {
return cmd_results_new(CMD_INVALID, "resize",
"Expected 'resize <shrink|grow> <width|height> <amount>'");
"Expected 'resize <shrink|grow> <width|height> <amount>' or 'resize <width|height> <amount>'");
}

return cmd_results_new(CMD_SUCCESS, NULL, NULL);
}

Expand Down
14 changes: 14 additions & 0 deletions sway/resize.c
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,20 @@
#include "log.h"
#include "input_state.h"
#include "handlers.h"
#include "resize.h"

bool set_size_tiled(int amount, bool use_width) {
int desired;
swayc_t *focused = get_focused_view(swayc_active_workspace());

if (use_width) {
desired = amount - focused->width;
} else {
desired = amount - focused->height;
}

return resize_tiled(desired, use_width);
}

bool resize_tiled(int amount, bool use_width) {
swayc_t *parent = get_focused_view(swayc_active_workspace());
Expand Down
4 changes: 4 additions & 0 deletions sway/sway.5.txt
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,10 @@ They are expected to be used with **bindsym** or at runtime through **swaymsg**(
Resizes the currently focused container or view by _amount_. _amount_ can be
specified as "n px" or "n ppt" or "n px or n ppt".

**resize** <width|height> <amount>::
Sets the _width_ or _height_ of the currently focused container to _amount_.
_amount_ can be specified as "n px" or "n ppt" or "n px or n ppt".

**split** <vertical|v|horizontal|h|toggle|t>::
Splits the current container, vertically or horizontally. If toggled then the
current container is split opposite to the parent container.
Expand Down

0 comments on commit 3ce8cc8

Please sign in to comment.