aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorixru <anon@anon.com>2018-10-08 15:58:24 +0200
committerixru <anon@anon.com>2018-10-08 15:58:24 +0200
commit8d0997a5e70d3c110add04bca70657204490bd23 (patch)
tree1f823e8a85869ca7086dd461a7ecebf9a2e35032
parent6a9995d18cfa5be560cd49b56ba6b751d19f3425 (diff)
Better placement of visibility check
-rw-r--r--types/wlr_output.c5
1 files changed, 2 insertions, 3 deletions
diff --git a/types/wlr_output.c b/types/wlr_output.c
index 5f07d51a..874678d0 100644
--- a/types/wlr_output.c
+++ b/types/wlr_output.c
@@ -853,6 +853,7 @@ static void output_cursor_commit(struct wlr_output_cursor *cursor,
cursor->enabled = wlr_surface_has_buffer(surface);
cursor->width = surface->current.width * cursor->output->scale;
cursor->height = surface->current.height * cursor->output->scale;
+ output_cursor_update_visible(cursor);
if (update_hotspot) {
cursor->hotspot_x -= surface->current.dx * cursor->output->scale;
cursor->hotspot_y -= surface->current.dy * cursor->output->scale;
@@ -874,7 +875,6 @@ static void output_cursor_handle_commit(struct wl_listener *listener,
struct wlr_output_cursor *cursor =
wl_container_of(listener, cursor, surface_commit);
output_cursor_commit(cursor, true);
- output_cursor_update_visible(cursor);
}
static void output_cursor_handle_destroy(struct wl_listener *listener,
@@ -916,10 +916,9 @@ void wlr_output_cursor_set_surface(struct wlr_output_cursor *cursor,
if (surface != NULL) {
wl_signal_add(&surface->events.commit, &cursor->surface_commit);
wl_signal_add(&surface->events.destroy, &cursor->surface_destroy);
- output_cursor_commit(cursor, false);
cursor->visible = false;
- output_cursor_update_visible(cursor);
+ output_cursor_commit(cursor, false);
} else {
cursor->enabled = false;
cursor->width = 0;