mirror of
https://github.com/swaywm/sway.git
synced 2024-12-30 17:06:40 +01:00
implement resize command for absolute dimensions
This commit is contained in:
parent
6388e1e288
commit
889618d3ee
4 changed files with 40 additions and 16 deletions
|
@ -2,6 +2,7 @@
|
||||||
#define _SWAY_RESIZE_H
|
#define _SWAY_RESIZE_H
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
|
||||||
|
bool set_size_tiled(int amount, bool use_width);
|
||||||
bool resize_tiled(int amount, bool use_width);
|
bool resize_tiled(int amount, bool use_width);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -2000,33 +2000,38 @@ static struct cmd_results *cmd_resize(int argc, char **argv) {
|
||||||
struct cmd_results *error = NULL;
|
struct cmd_results *error = NULL;
|
||||||
if (config->reading) return cmd_results_new(CMD_FAILURE, "resize", "Can't be used in config file.");
|
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 (!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;
|
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) {
|
if (errno == ERANGE || amount == 0) {
|
||||||
errno = 0;
|
errno = 0;
|
||||||
return cmd_results_new(CMD_INVALID, "resize", "Number is out of range.");
|
return cmd_results_new(CMD_INVALID, "resize", "Number is out of range.");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strcmp(argv[0], "shrink") != 0 && strcmp(argv[0], "grow") != 0) {
|
if (strcmp(argv[0], "shrink") == 0 || strcmp(argv[0], "grow") == 0) {
|
||||||
return cmd_results_new(CMD_INVALID, "resize",
|
if (strcmp(argv[0], "shrink") == 0) {
|
||||||
"Expected 'resize <shrink|grow> <width|height> <amount>'");
|
amount *= -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (strcmp(argv[0], "shrink") == 0) {
|
if (strcmp(argv[1], "width") == 0) {
|
||||||
amount *= -1;
|
resize_tiled(amount, true);
|
||||||
}
|
} else if (strcmp(argv[1], "height") == 0) {
|
||||||
|
resize_tiled(amount, false);
|
||||||
if (strcmp(argv[1], "width") == 0) {
|
} else {
|
||||||
resize_tiled(amount, true);
|
return cmd_results_new(CMD_INVALID, "resize",
|
||||||
} else if (strcmp(argv[1], "height") == 0) {
|
"Expected 'resize <shrink|grow> <width|height> <amount>' or 'resize <width|height> <amount>'");
|
||||||
resize_tiled(amount, false);
|
}
|
||||||
|
} 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 {
|
} else {
|
||||||
return cmd_results_new(CMD_INVALID, "resize",
|
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);
|
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -5,6 +5,20 @@
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "input_state.h"
|
#include "input_state.h"
|
||||||
#include "handlers.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) {
|
bool resize_tiled(int amount, bool use_width) {
|
||||||
swayc_t *parent = get_focused_view(swayc_active_workspace());
|
swayc_t *parent = get_focused_view(swayc_active_workspace());
|
||||||
|
|
|
@ -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
|
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".
|
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>::
|
**split** <vertical|v|horizontal|h|toggle|t>::
|
||||||
Splits the current container, vertically or horizontally. If toggled then the
|
Splits the current container, vertically or horizontally. If toggled then the
|
||||||
current container is split opposite to the parent container.
|
current container is split opposite to the parent container.
|
||||||
|
|
Loading…
Reference in a new issue