diff --git a/include/sway/input/seat.h b/include/sway/input/seat.h index a6c68fb8a..28a3ea377 100644 --- a/include/sway/input/seat.h +++ b/include/sway/input/seat.h @@ -198,8 +198,7 @@ void seat_set_focus_surface(struct sway_seat *seat, void seat_set_focus_layer(struct sway_seat *seat, struct wlr_layer_surface_v1 *layer); -void seat_set_exclusive_client(struct sway_seat *seat, - struct wl_client *client); +void seat_unfocus_unless_client(struct sway_seat *seat, struct wl_client *client); struct sway_node *seat_get_focus(struct sway_seat *seat); diff --git a/sway/input/seat.c b/sway/input/seat.c index b269a4cd6..31c9b72b0 100644 --- a/sway/input/seat.c +++ b/sway/input/seat.c @@ -1369,8 +1369,7 @@ void seat_set_focus_layer(struct sway_seat *seat, seat->focused_layer = layer; } -void seat_set_exclusive_client(struct sway_seat *seat, - struct wl_client *client) { +void seat_unfocus_unless_client(struct sway_seat *seat, struct wl_client *client) { if (seat->focused_layer) { if (wl_resource_get_client(seat->focused_layer->resource) != client) { seat_set_focus_layer(seat, NULL); diff --git a/sway/lock.c b/sway/lock.c index ec2a7695f..c4fbfe0ea 100644 --- a/sway/lock.c +++ b/sway/lock.c @@ -184,7 +184,7 @@ static void handle_session_lock(struct wl_listener *listener, void *data) { struct sway_seat *seat; wl_list_for_each(seat, &server.input->seats, link) { - seat_set_exclusive_client(seat, client); + seat_unfocus_unless_client(seat, client); } wl_signal_add(&lock->events.new_surface, &server.session_lock.lock_new_surface);