commit c1d57914828b33d24b14a27d371931b10721df11
parent bb67a3d80913a6690f1ebdf4097dc76d812e6a9a
Author: Mikkel Oscar Lyderik <mikkeloscar@gmail.com>
Date: Thu, 17 Mar 2016 17:02:17 +0100
Focus correct swaylock view in multimonitor setup
Swaylock spawns and focuses a view for each output in sway. This can
sometimes move the focus to a new output after locking and unlocking the
screens.
This patch makes sure that the output which had focus when swaylock
was invoked, will regain focus once swaylock is closed/unlocked.
Fix #499
Diffstat:
1 file changed, 6 insertions(+), 1 deletion(-)
diff --git a/sway/extensions.c b/sway/extensions.c
@@ -129,7 +129,12 @@ static void set_lock_surface(struct wl_client *client, struct wl_resource *resou
desktop_shell.is_locked = true;
// reset input state
input_init();
- set_focused_container(view);
+ // set focus if the lockscreen is spawned on the currently
+ // active output
+ swayc_t *focus_output = swayc_active_output();
+ if (focus_output == output) {
+ set_focused_container(view);
+ }
arrange_windows(workspace, -1, -1);
list_add(desktop_shell.lock_surfaces, surface);
wl_resource_set_destructor(surface, lock_surface_destructor);