diff options
author | emersion <contact@emersion.fr> | 2019-02-12 22:55:23 +0100 |
---|---|---|
committer | emersion <contact@emersion.fr> | 2019-02-12 22:57:23 +0100 |
commit | 97c89b24b8e4a8e091f6974333457deb73b7800f (patch) | |
tree | f6e1e3686921968161fdd5091667b2794f6ca184 /sway/input | |
parent | fb4f29289fd8d1f94975e64fded6657222ed5390 (diff) | |
download | sway-97c89b24b8e4a8e091f6974333457deb73b7800f.tar.xz |
Rebase cursor when a layer surface maps
Also removes an extraneous arrange_outputs call, it's already called if
necessary in arrange_layers.
Updates https://github.com/swaywm/sway/issues/3080
Diffstat (limited to 'sway/input')
-rw-r--r-- | sway/input/cursor.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/sway/input/cursor.c b/sway/input/cursor.c index 1bf548db..263b6758 100644 --- a/sway/input/cursor.c +++ b/sway/input/cursor.c @@ -283,6 +283,19 @@ void cursor_rebase(struct sway_cursor *cursor) { cursor_do_rebase(cursor, time_msec, cursor->previous.node, surface, sx, sy); } +void cursor_rebase_all(void) { + if (!root->outputs->length) { + return; + } + + struct sway_seat *seat; + wl_list_for_each(seat, &server.input->seats, link) { + if (!seat_doing_seatop(seat)) { + cursor_rebase(seat->cursor); + } + } +} + static int hide_notify(void *data) { struct sway_cursor *cursor = data; wlr_cursor_set_image(cursor->cursor, NULL, 0, 0, 0, 0, 0, 0); |