aboutsummaryrefslogtreecommitdiffstats
path: root/sway/input/seat.c
diff options
context:
space:
mode:
authorLibravatar Dominique Martinet <asmadeus@codewreck.org>2018-01-16 21:16:04 +0100
committerLibravatar Dominique Martinet <asmadeus@codewreck.org>2018-01-22 07:26:37 +0100
commit5766f426aac11bf39234dcca4c479ee865081dad (patch)
tree0d1917761854db5d79c5d7478e46e3082bf14b8f /sway/input/seat.c
parentcommands: add 'reload' command (diff)
downloadsway-5766f426aac11bf39234dcca4c479ee865081dad.tar.gz
sway-5766f426aac11bf39234dcca4c479ee865081dad.tar.zst
sway-5766f426aac11bf39234dcca4c479ee865081dad.zip
config reload: destroy old seat when removed from config
This adds new sway_seat_destroy and sway_cursor_destroy helpers and compare new and old config on free
Diffstat (limited to 'sway/input/seat.c')
-rw-r--r--sway/input/seat.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/sway/input/seat.c b/sway/input/seat.c
index e9b375e0..9ea08eec 100644
--- a/sway/input/seat.c
+++ b/sway/input/seat.c
@@ -21,6 +21,16 @@ static void seat_device_destroy(struct sway_seat_device *seat_device) {
21 free(seat_device); 21 free(seat_device);
22} 22}
23 23
24void sway_seat_destroy(struct sway_seat *seat) {
25 struct sway_seat_device *seat_device, *next;
26 wl_list_for_each_safe(seat_device, next, &seat->devices, link) {
27 seat_device_destroy(seat_device);
28 }
29 sway_cursor_destroy(seat->cursor);
30 wl_list_remove(&seat->link);
31 wlr_seat_destroy(seat->wlr_seat);
32}
33
24struct sway_seat *sway_seat_create(struct sway_input_manager *input, 34struct sway_seat *sway_seat_create(struct sway_input_manager *input,
25 const char *seat_name) { 35 const char *seat_name) {
26 struct sway_seat *seat = calloc(1, sizeof(struct sway_seat)); 36 struct sway_seat *seat = calloc(1, sizeof(struct sway_seat));