aboutsummaryrefslogtreecommitdiff
path: root/sway/handlers.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2016-10-12 21:26:06 -0400
committerGitHub <noreply@github.com>2016-10-12 21:26:06 -0400
commit4cba91803eb8c3c3ab4ebf22e94510b43f7a907d (patch)
tree5f80bbe3775f0e405895ab973c62f8bbd8ea1bf8 /sway/handlers.c
parent857eea8b6355deff7a12edd8b733f8057210142a (diff)
Revert "Fixes dealing with workspace_layout and related bugs [rfc]"
Diffstat (limited to 'sway/handlers.c')
-rw-r--r--sway/handlers.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/sway/handlers.c b/sway/handlers.c
index 9a84182a..2235bc8b 100644
--- a/sway/handlers.c
+++ b/sway/handlers.c
@@ -398,6 +398,17 @@ static bool handle_view_created(wlc_handle handle) {
if (workspace && workspace->fullscreen) {
set_focused_container(workspace->fullscreen);
}
+
+ // if parent container is a workspace, newview its only child and
+ // layout is tabbed/stacked, add a container around newview
+ swayc_t *parent_container = newview->parent;
+ if (parent_container && parent_container->type == C_WORKSPACE &&
+ parent_container->children && parent_container->children->length == 1 &&
+ (parent_container->layout == L_TABBED || parent_container->layout == L_STACKED)) {
+ swayc_t *container = new_container(newview, parent_container->layout);
+ set_focused_container(newview);
+ arrange_windows(container, -1, -1);
+ }
} else {
swayc_t *output = swayc_parent_by_type(focused, C_OUTPUT);
wlc_handle *h = malloc(sizeof(wlc_handle));