commit 6f424ff6b82d86a174319ffd534e517b2ae6d367
parent b79a49a394ede1c07773dadab97b00a4c7b4d835
Author: taiyu <taiyu.len@gmail.com>
Date: Wed, 19 Aug 2015 16:15:17 -0700
fixed default active_workspace, and more use of set_focused_container_for(...)
Diffstat:
2 files changed, 5 insertions(+), 3 deletions(-)
diff --git a/sway/container.c b/sway/container.c
@@ -150,6 +150,7 @@ swayc_t *new_container(swayc_t *child, enum swayc_layouts layout) {
// give them proper layouts
cont->layout = workspace->layout;
workspace->layout = layout;
+ set_focused_container_for(workspace, get_focused_view(workspace));
} else { // Or is built around container
swayc_t *parent = replace_child(child, cont);
if (parent) {
diff --git a/sway/layout.c b/sway/layout.c
@@ -33,8 +33,9 @@ void add_child(swayc_t *parent, swayc_t *child) {
child->width, child->height, parent, parent->type, parent->width, parent->height);
list_add(parent->children, child);
child->parent = parent;
+ //set focus for this container
if (parent->children->length == 1) {
- parent->focused = child;
+ set_focused_container_for(parent, child);
}
}
@@ -45,7 +46,7 @@ void add_floating(swayc_t *ws, swayc_t *child) {
child->parent = ws;
child->is_floating = true;
if (!ws->focused) {
- ws->focused = child;
+ set_focused_container_for(ws, child);
}
}
@@ -70,7 +71,7 @@ swayc_t *replace_child(swayc_t *child, swayc_t *new_child) {
new_child->parent = child->parent;
if (child->parent->focused == child) {
- child->parent->focused = new_child;
+ set_focused_container_for(child->parent, new_child);
}
child->parent = NULL;
return parent;