aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoremersion <contact@emersion.fr>2017-10-09 13:12:38 +0200
committeremersion <contact@emersion.fr>2017-10-09 13:12:38 +0200
commit84921740881f638622c6a0c1b4ab319218f1f7ac (patch)
treeb8d37f782f19232ba1ed86784af872ba8163920a
parentf44c44502df83a6774947bce161784c51c79e645 (diff)
Switch back to compositor cursor when switching from one view to another
-rw-r--r--include/rootston/input.h2
-rw-r--r--rootston/cursor.c17
2 files changed, 9 insertions, 10 deletions
diff --git a/include/rootston/input.h b/include/rootston/input.h
index 43408516..fbabbdb6 100644
--- a/include/rootston/input.h
+++ b/include/rootston/input.h
@@ -79,7 +79,7 @@ struct roots_input {
struct wlr_xcursor_theme *theme;
struct wlr_xcursor *xcursor;
struct wlr_seat *wl_seat;
- bool client_cursor;
+ struct roots_view *client_cursor_view;
enum roots_cursor_mode mode;
struct roots_view *active_view, *last_active_view;
diff --git a/rootston/cursor.c b/rootston/cursor.c
index 2df9bcb5..eeb657ad 100644
--- a/rootston/cursor.c
+++ b/rootston/cursor.c
@@ -69,8 +69,6 @@ static void cursor_set_xcursor_image(struct roots_input *input,
return;
}
}
-
- input->client_cursor = false;
}
void cursor_update_position(struct roots_input *input, uint32_t time) {
@@ -82,15 +80,16 @@ void cursor_update_position(struct roots_input *input, uint32_t time) {
case ROOTS_CURSOR_PASSTHROUGH:
view = view_at(desktop, input->cursor->x, input->cursor->y, &surface,
&sx, &sy);
+ if (view != input->client_cursor_view) {
+ wlr_log(L_DEBUG, "Switching to compositor cursor");
+ cursor_set_xcursor_image(input, input->xcursor->images[0]);
+ input->client_cursor_view = NULL;
+ }
if (view) {
wlr_seat_pointer_notify_enter(input->wl_seat, surface, sx, sy);
wlr_seat_pointer_notify_motion(input->wl_seat, time, sx, sy);
} else {
wlr_seat_pointer_clear_focus(input->wl_seat);
- if (input->client_cursor) {
- wlr_log(L_DEBUG, "Switching to compositor cursor");
- cursor_set_xcursor_image(input, input->xcursor->images[0]);
- }
}
break;
case ROOTS_CURSOR_MOVE:
@@ -301,8 +300,8 @@ static void handle_request_set_cursor(struct wl_listener *listener,
struct wlr_surface *focused_surface = NULL;
double sx, sy;
- view_at(input->server->desktop, input->cursor->x, input->cursor->y,
- &focused_surface, &sx, &sy);
+ struct roots_view *focused_view = view_at(input->server->desktop,
+ input->cursor->x, input->cursor->y, &focused_surface, &sx, &sy);
bool ok = focused_surface != NULL;
if (focused_surface != NULL) {
struct wl_client *focused_client =
@@ -322,7 +321,7 @@ static void handle_request_set_cursor(struct wl_listener *listener,
event->hotspot_x, event->hotspot_y);
}
- input->client_cursor = true;
+ input->client_cursor_view = focused_view;
}
void cursor_initialize(struct roots_input *input) {