diff options
author | Drew DeVault <sir@cmpwn.com> | 2016-10-12 21:26:06 -0400 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-10-12 21:26:06 -0400 |
commit | 4cba91803eb8c3c3ab4ebf22e94510b43f7a907d (patch) | |
tree | 5f80bbe3775f0e405895ab973c62f8bbd8ea1bf8 /sway/handlers.c | |
parent | 857eea8b6355deff7a12edd8b733f8057210142a (diff) |
Revert "Fixes dealing with workspace_layout and related bugs [rfc]"
Diffstat (limited to 'sway/handlers.c')
-rw-r--r-- | sway/handlers.c | 11 |
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)); |