mirror of
https://github.com/NickHu/sway
synced 2024-12-30 22:23:30 +01:00
5e925f06e0
Disable the i3-compatible behavior if the option '--i3' is not given. Previously it was only possible to disable it by changing the config file. Now it also works via swaymsg.
41 lines
1.2 KiB
C
41 lines
1.2 KiB
C
#include "sway/commands.h"
|
|
#include "sway/config.h"
|
|
#include "sway/tree/arrange.h"
|
|
#include "sway/tree/view.h"
|
|
|
|
struct cmd_results *cmd_hide_edge_borders(int argc, char **argv) {
|
|
struct cmd_results *error = NULL;
|
|
if ((error = checkarg(argc, "hide_edge_borders", EXPECTED_AT_LEAST, 1))) {
|
|
return error;
|
|
}
|
|
|
|
if (strcmp(*argv, "--i3") == 0) {
|
|
config->hide_lone_tab = true;
|
|
++argv;
|
|
--argc;
|
|
} else {
|
|
config->hide_lone_tab = false;
|
|
}
|
|
|
|
if (strcmp(argv[0], "none") == 0) {
|
|
config->hide_edge_borders = E_NONE;
|
|
} else if (strcmp(argv[0], "vertical") == 0) {
|
|
config->hide_edge_borders = E_VERTICAL;
|
|
} else if (strcmp(argv[0], "horizontal") == 0) {
|
|
config->hide_edge_borders = E_HORIZONTAL;
|
|
} else if (strcmp(argv[0], "both") == 0) {
|
|
config->hide_edge_borders = E_BOTH;
|
|
} else if (strcmp(argv[0], "smart") == 0) {
|
|
config->hide_edge_borders = E_SMART;
|
|
} else if (strcmp(argv[0], "smart_no_gaps") == 0) {
|
|
config->hide_edge_borders = E_SMART_NO_GAPS;
|
|
} else {
|
|
return cmd_results_new(CMD_INVALID, "Expected 'hide_edge_borders "
|
|
"[--i3] <none|vertical|horizontal|both|smart|smart_no_gaps>'");
|
|
}
|
|
config->saved_edge_borders = config->hide_edge_borders;
|
|
|
|
arrange_root();
|
|
|
|
return cmd_results_new(CMD_SUCCESS, NULL);
|
|
}
|