aboutsummaryrefslogtreecommitdiff
path: root/sway/commands
diff options
context:
space:
mode:
authorBrian Ashworth <bosrsf04@gmail.com>2018-05-11 18:44:56 -0400
committerBrian Ashworth <bosrsf04@gmail.com>2018-05-11 18:44:56 -0400
commit3db7fc2bb2c35d545b2a0a72f5554af833bd447f (patch)
tree1da6e43dca62aa55501a10598acd33dcc2d7142e /sway/commands
parent2217518bd554d0f11dafa7ec4e8f35f2e4762fbd (diff)
downloadsway-3db7fc2bb2c35d545b2a0a72f5554af833bd447f.tar.xz
Implement hide_edge_borders
Diffstat (limited to 'sway/commands')
-rw-r--r--sway/commands/hide_edge_borders.c37
1 files changed, 37 insertions, 0 deletions
diff --git a/sway/commands/hide_edge_borders.c b/sway/commands/hide_edge_borders.c
new file mode 100644
index 00000000..7d70055b
--- /dev/null
+++ b/sway/commands/hide_edge_borders.c
@@ -0,0 +1,37 @@
+#include "sway/commands.h"
+#include "sway/config.h"
+#include "sway/tree/container.h"
+#include "sway/tree/view.h"
+
+static void _configure_view(struct sway_container *con, void *data) {
+ if (con->type == C_VIEW) {
+ view_autoconfigure(con->sway_view);
+ }
+}
+
+struct cmd_results *cmd_hide_edge_borders(int argc, char **argv) {
+ struct cmd_results *error = NULL;
+ if ((error = checkarg(argc, "hide_edge_borders", EXPECTED_EQUAL_TO, 1))) {
+ return error;
+ }
+
+ 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 {
+ return cmd_results_new(CMD_INVALID, "hide_edge_borders",
+ "Expected 'hide_edge_borders "
+ "<none|vertical|horizontal|both|smart>'");
+ }
+
+ container_for_each_descendant_dfs(&root_container, _configure_view, NULL);
+
+ return cmd_results_new(CMD_SUCCESS, NULL, NULL);
+}