aboutsummaryrefslogtreecommitdiffstats
path: root/sway/commands/layout.c
diff options
context:
space:
mode:
authorLibravatar Ian Fan <ianfan0@gmail.com>2018-07-29 12:27:34 +0100
committerLibravatar Ian Fan <ianfan0@gmail.com>2018-08-06 14:17:58 +0100
commitbe64c466245d4c537a70484abfe21adc9d60f3c5 (patch)
tree252ca8a3ac7b827a6b69820f092cdee2d530be6e /sway/commands/layout.c
parentcommands: allow __focused__ for con_id criterion (diff)
downloadsway-be64c466245d4c537a70484abfe21adc9d60f3c5.tar.gz
sway-be64c466245d4c537a70484abfe21adc9d60f3c5.tar.zst
sway-be64c466245d4c537a70484abfe21adc9d60f3c5.zip
commands: complete layout implementation
Diffstat (limited to 'sway/commands/layout.c')
-rw-r--r--sway/commands/layout.c76
1 files changed, 61 insertions, 15 deletions
diff --git a/sway/commands/layout.c b/sway/commands/layout.c
index c446f1f9..ec170591 100644
--- a/sway/commands/layout.c
+++ b/sway/commands/layout.c
@@ -1,3 +1,4 @@
1#include <stdbool.h>
1#include <string.h> 2#include <string.h>
2#include <strings.h> 3#include <strings.h>
3#include "sway/commands.h" 4#include "sway/commands.h"
@@ -5,6 +6,26 @@
5#include "sway/tree/container.h" 6#include "sway/tree/container.h"
6#include "log.h" 7#include "log.h"
7 8
9static bool parse_layout_string(char *s, enum sway_container_layout *ptr) {
10 if (strcasecmp(s, "splith") == 0) {
11 *ptr = L_HORIZ;
12 } else if (strcasecmp(s, "splitv") == 0) {
13 *ptr = L_VERT;
14 } else if (strcasecmp(s, "tabbed") == 0) {
15 *ptr = L_TABBED;
16 } else if (strcasecmp(s, "stacking") == 0) {
17 *ptr = L_STACKED;
18 } else {
19 return false;
20 }
21 return true;
22}
23
24static const char* expected_syntax =
25 "Expected 'layout default|tabbed|stacking|splitv|splith' or "
26 "'layout toggle [split|all]' or "
27 "'layout toggle [split|tabbed|stacking|splitv|splith] [split|tabbed|stacking|splitv|splith]...'";
28
8struct cmd_results *cmd_layout(int argc, char **argv) { 29struct cmd_results *cmd_layout(int argc, char **argv) {
9 struct cmd_results *error = NULL; 30 struct cmd_results *error = NULL;
10 if ((error = checkarg(argc, "layout", EXPECTED_MORE_THAN, 0))) { 31 if ((error = checkarg(argc, "layout", EXPECTED_MORE_THAN, 0))) {
@@ -23,30 +44,55 @@ struct cmd_results *cmd_layout(int argc, char **argv) {
23 44
24 if (strcasecmp(argv[0], "default") == 0) { 45 if (strcasecmp(argv[0], "default") == 0) {
25 parent->layout = parent->prev_layout; 46 parent->layout = parent->prev_layout;
26 if (parent->layout == L_NONE) {
27 parent->layout = container_get_default_layout(parent);
28 }
29 } else { 47 } else {
30 if (parent->layout != L_TABBED && parent->layout != L_STACKED) { 48 if (parent->layout != L_TABBED && parent->layout != L_STACKED) {
31 parent->prev_layout = parent->layout; 49 parent->prev_layout = parent->layout;
32 } 50 }
33 51
34 if (strcasecmp(argv[0], "splith") == 0) { 52 bool assigned_directly = parse_layout_string(argv[0], &parent->layout);
35 parent->layout = L_HORIZ; 53 if (!assigned_directly && strcasecmp(argv[0], "toggle") == 0) {
36 } else if (strcasecmp(argv[0], "splitv") == 0) { 54 if (argc == 1) {
37 parent->layout = L_VERT; 55 parent->layout =
38 } else if (strcasecmp(argv[0], "tabbed") == 0) { 56 parent->layout == L_STACKED ? L_TABBED :
39 parent->layout = L_TABBED; 57 parent->layout == L_TABBED ? parent->prev_layout : L_STACKED;
40 } else if (strcasecmp(argv[0], "stacking") == 0) { 58 } else if (argc == 2) {
41 parent->layout = L_STACKED; 59 if (strcasecmp(argv[1], "all") == 0) {
42 } else if (strcasecmp(argv[0], "toggle") == 0 && argc == 2 && strcasecmp(argv[1], "split") == 0) { 60 parent->layout =
43 if (parent->layout == L_HORIZ) { 61 parent->layout == L_HORIZ ? L_VERT :
44 parent->layout = L_VERT; 62 parent->layout == L_VERT ? L_STACKED :
63 parent->layout == L_STACKED ? L_TABBED : L_HORIZ;
64 } else if (strcasecmp(argv[1], "split") == 0) {
65 parent->layout = parent->layout == L_VERT ? L_HORIZ : L_VERT;
66 } else {
67 return cmd_results_new(CMD_INVALID, "layout", expected_syntax);
68 }
45 } else { 69 } else {
46 parent->layout = L_HORIZ; 70 bool valid;
71 enum sway_container_layout parsed_layout;
72 int curr = 1;
73 for (; curr < argc; curr++) {
74 valid = parse_layout_string(argv[curr], &parsed_layout);
75 if (valid && parsed_layout == parent->layout) {
76 break;
77 }
78 }
79 for (int i = curr + 1; i != curr; ++i) {
80 // cycle round to find next valid layout
81 if (i >= argc) {
82 i = 1;
83 }
84 if (parse_layout_string(argv[i], &parent->layout)) {
85 break;
86 } // invalid layout strings are silently ignored
87 }
47 } 88 }
89 } else {
90 return cmd_results_new(CMD_INVALID, "layout", expected_syntax);
48 } 91 }
49 } 92 }
93 if (parent->layout == L_NONE) {
94 parent->layout = container_get_default_layout(parent);
95 }
50 96
51 container_notify_subtree_changed(parent); 97 container_notify_subtree_changed(parent);
52 arrange_windows(parent); 98 arrange_windows(parent);