mirror of
https://github.com/NickHu/sway
synced 2025-01-07 05:24:44 +01:00
35b8d185ac
For workspace containers, swayc_change_layout also changes ->layout alongside ->workspace_layout when it's a sensible thing to do. There is an additional test for 'layout toggle' command which ensures that containers will be tiled horizontally after toggling from tabbed or stacked.
66 lines
2.2 KiB
C
66 lines
2.2 KiB
C
#include <string.h>
|
|
#include "sway/commands.h"
|
|
#include "sway/container.h"
|
|
#include "sway/layout.h"
|
|
|
|
struct cmd_results *cmd_layout(int argc, char **argv) {
|
|
struct cmd_results *error = NULL;
|
|
if (config->reading) return cmd_results_new(CMD_FAILURE, "layout", "Can't be used in config file.");
|
|
if (!config->active) return cmd_results_new(CMD_FAILURE, "layout", "Can only be used when sway is running.");
|
|
if ((error = checkarg(argc, "layout", EXPECTED_MORE_THAN, 0))) {
|
|
return error;
|
|
}
|
|
swayc_t *parent = get_focused_container(&root_container);
|
|
if (parent->is_floating) {
|
|
return cmd_results_new(CMD_FAILURE, "layout", "Unable to change layout of floating windows");
|
|
}
|
|
|
|
while (parent->type == C_VIEW) {
|
|
parent = parent->parent;
|
|
}
|
|
|
|
enum swayc_layouts old_layout = parent->layout;
|
|
|
|
if (strcasecmp(argv[0], "default") == 0) {
|
|
swayc_change_layout(parent, parent->prev_layout);
|
|
if (parent->layout == L_NONE) {
|
|
swayc_t *output = swayc_parent_by_type(parent, C_OUTPUT);
|
|
swayc_change_layout(parent, default_layout(output));
|
|
}
|
|
} else {
|
|
if (parent->layout != L_TABBED && parent->layout != L_STACKED) {
|
|
parent->prev_layout = parent->layout;
|
|
}
|
|
|
|
if (strcasecmp(argv[0], "tabbed") == 0) {
|
|
if (parent->type != C_CONTAINER && !swayc_is_empty_workspace(parent)){
|
|
parent = new_container(parent, L_TABBED);
|
|
}
|
|
|
|
swayc_change_layout(parent, L_TABBED);
|
|
} else if (strcasecmp(argv[0], "stacking") == 0) {
|
|
if (parent->type != C_CONTAINER && !swayc_is_empty_workspace(parent)) {
|
|
parent = new_container(parent, L_STACKED);
|
|
}
|
|
|
|
swayc_change_layout(parent, L_STACKED);
|
|
} else if (strcasecmp(argv[0], "splith") == 0) {
|
|
swayc_change_layout(parent, L_HORIZ);
|
|
} else if (strcasecmp(argv[0], "splitv") == 0) {
|
|
swayc_change_layout(parent, L_VERT);
|
|
} else if (strcasecmp(argv[0], "toggle") == 0 && argc == 2 && strcasecmp(argv[1], "split") == 0) {
|
|
if (parent->layout == L_HORIZ && (parent->workspace_layout == L_NONE || parent->workspace_layout == L_HORIZ)) {
|
|
swayc_change_layout(parent, L_VERT);
|
|
} else {
|
|
swayc_change_layout(parent, L_HORIZ);
|
|
}
|
|
}
|
|
}
|
|
|
|
update_layout_geometry(parent, old_layout);
|
|
update_geometry(parent);
|
|
|
|
arrange_windows(parent, parent->width, parent->height);
|
|
|
|
return cmd_results_new(CMD_SUCCESS, NULL, NULL);
|
|
}
|