diff options
author | Drew DeVault <sir@cmpwn.com> | 2018-04-03 16:16:42 -0400 |
---|---|---|
committer | Drew DeVault <sir@cmpwn.com> | 2018-04-04 18:47:48 -0400 |
commit | 06fbd51ff5563f548599615a6baf5a1854bf9983 (patch) | |
tree | c1890f3554621ad8f1d44a054e88f72f065644ee /sway | |
parent | Refocus the last focused container on lock exit (diff) | |
download | sway-06fbd51ff5563f548599615a6baf5a1854bf9983.tar.gz sway-06fbd51ff5563f548599615a6baf5a1854bf9983.tar.zst sway-06fbd51ff5563f548599615a6baf5a1854bf9983.zip |
Add input inhibitor to input manager
Diffstat (limited to 'sway')
-rw-r--r-- | sway/input/input-manager.c | 27 | ||||
-rw-r--r-- | sway/input/seat.c | 5 |
2 files changed, 32 insertions, 0 deletions
diff --git a/sway/input/input-manager.c b/sway/input/input-manager.c index c3507f65..3b2d1d55 100644 --- a/sway/input/input-manager.c +++ b/sway/input/input-manager.c | |||
@@ -7,6 +7,7 @@ | |||
7 | #include <libinput.h> | 7 | #include <libinput.h> |
8 | #include <math.h> | 8 | #include <math.h> |
9 | #include <wlr/backend/libinput.h> | 9 | #include <wlr/backend/libinput.h> |
10 | #include <wlr/types/wlr_input_inhibitor.h> | ||
10 | #include "sway/config.h" | 11 | #include "sway/config.h" |
11 | #include "sway/input/input-manager.h" | 12 | #include "sway/input/input-manager.h" |
12 | #include "sway/input/seat.h" | 13 | #include "sway/input/seat.h" |
@@ -263,6 +264,24 @@ static void handle_new_input(struct wl_listener *listener, void *data) { | |||
263 | input_device->device_destroy.notify = handle_device_destroy; | 264 | input_device->device_destroy.notify = handle_device_destroy; |
264 | } | 265 | } |
265 | 266 | ||
267 | static void handle_inhibit_activate(struct wl_listener *listener, void *data) { | ||
268 | struct sway_input_manager *input_manager = wl_container_of( | ||
269 | listener, input_manager, inhibit_activate); | ||
270 | struct sway_seat *seat; | ||
271 | wl_list_for_each(seat, &input_manager->seats, link) { | ||
272 | seat_set_exclusive_client(seat, input_manager->inhibit->active_client); | ||
273 | } | ||
274 | } | ||
275 | |||
276 | static void handle_inhibit_deactivate(struct wl_listener *listener, void *data) { | ||
277 | struct sway_input_manager *input_manager = wl_container_of( | ||
278 | listener, input_manager, inhibit_deactivate); | ||
279 | struct sway_seat *seat; | ||
280 | wl_list_for_each(seat, &input_manager->seats, link) { | ||
281 | seat_set_exclusive_client(seat, NULL); | ||
282 | } | ||
283 | } | ||
284 | |||
266 | struct sway_input_manager *input_manager_create( | 285 | struct sway_input_manager *input_manager_create( |
267 | struct sway_server *server) { | 286 | struct sway_server *server) { |
268 | struct sway_input_manager *input = | 287 | struct sway_input_manager *input = |
@@ -281,6 +300,14 @@ struct sway_input_manager *input_manager_create( | |||
281 | input->new_input.notify = handle_new_input; | 300 | input->new_input.notify = handle_new_input; |
282 | wl_signal_add(&server->backend->events.new_input, &input->new_input); | 301 | wl_signal_add(&server->backend->events.new_input, &input->new_input); |
283 | 302 | ||
303 | input->inhibit = wlr_input_inhibit_manager_create(server->wl_display); | ||
304 | input->inhibit_activate.notify = handle_inhibit_activate; | ||
305 | wl_signal_add(&input->inhibit->events.activate, | ||
306 | &input->inhibit_activate); | ||
307 | input->inhibit_deactivate.notify = handle_inhibit_deactivate; | ||
308 | wl_signal_add(&input->inhibit->events.deactivate, | ||
309 | &input->inhibit_deactivate); | ||
310 | |||
284 | return input; | 311 | return input; |
285 | } | 312 | } |
286 | 313 | ||
diff --git a/sway/input/seat.c b/sway/input/seat.c index a6b42598..318fa9f6 100644 --- a/sway/input/seat.c +++ b/sway/input/seat.c | |||
@@ -460,6 +460,11 @@ void seat_set_focus_layer(struct sway_seat *seat, | |||
460 | } | 460 | } |
461 | } | 461 | } |
462 | 462 | ||
463 | void seat_set_exclusive_client(struct sway_seat *seat, | ||
464 | struct wl_client *client) { | ||
465 | // TODO | ||
466 | } | ||
467 | |||
463 | struct sway_container *seat_get_focus_inactive(struct sway_seat *seat, | 468 | struct sway_container *seat_get_focus_inactive(struct sway_seat *seat, |
464 | struct sway_container *container) { | 469 | struct sway_container *container) { |
465 | return seat_get_focus_by_type(seat, container, C_TYPES); | 470 | return seat_get_focus_by_type(seat, container, C_TYPES); |