summaryrefslogtreecommitdiffstats
path: root/sway/workspace.c
diff options
context:
space:
mode:
authorLibravatar Drew DeVault <sir@cmpwn.com>2015-08-15 16:03:45 -0400
committerLibravatar Drew DeVault <sir@cmpwn.com>2015-08-15 16:03:45 -0400
commitf606508bccac841925e8d669fe90595697fac8af (patch)
treee150b723ffb01ab4b482fc9f7d2fccda8daaf6bf /sway/workspace.c
parentFix build (diff)
downloadsway-f606508bccac841925e8d669fe90595697fac8af.tar.gz
sway-f606508bccac841925e8d669fe90595697fac8af.tar.zst
sway-f606508bccac841925e8d669fe90595697fac8af.zip
Fix switching focus between outputs
Diffstat (limited to 'sway/workspace.c')
-rw-r--r--sway/workspace.c18
1 files changed, 14 insertions, 4 deletions
diff --git a/sway/workspace.c b/sway/workspace.c
index 9748c23f..6f46dd6b 100644
--- a/sway/workspace.c
+++ b/sway/workspace.c
@@ -94,7 +94,7 @@ swayc_t *workspace_find_by_name(const char* name) {
94} 94}
95 95
96void workspace_switch(swayc_t *workspace) { 96void workspace_switch(swayc_t *workspace) {
97 swayc_t *parent = workspace; 97 swayc_t *parent = workspace->parent;
98 while (parent->type != C_OUTPUT) { 98 while (parent->type != C_OUTPUT) {
99 parent = parent->parent; 99 parent = parent->parent;
100 } 100 }
@@ -111,11 +111,21 @@ void workspace_switch(swayc_t *workspace) {
111 container_map(workspace, set_mask, &mask); 111 container_map(workspace, set_mask, &mask);
112 wlc_output_set_mask(wlc_get_focused_output(), 2); 112 wlc_output_set_mask(wlc_get_focused_output(), 2);
113 113
114 unfocus_all(&root_container);
115 focus_view(workspace);
116
117 destroy_workspace(c_workspace); 114 destroy_workspace(c_workspace);
118 } 115 }
116 unfocus_all(&root_container);
117 focus_view(workspace);
118
119 // focus the output this workspace is on
120 swayc_t *output = workspace->parent;
121 sway_log(L_DEBUG, "Switching focus to output %p (%d)", output, output->type);
122 while (output && output->type != C_OUTPUT) {
123 output = output->parent;
124 }
125 if (output) {
126 sway_log(L_DEBUG, "Switching focus to output %p (%d)", output, output->type);
127 wlc_output_focus(output->handle);
128 }
119 active_workspace = workspace; 129 active_workspace = workspace;
120} 130}
121 131