|
|
@ -125,17 +125,23 @@ static void roots_passthrough_cursor(struct roots_cursor *cursor,
|
|
|
|
if (view) {
|
|
|
|
if (view) {
|
|
|
|
struct roots_seat_view *seat_view =
|
|
|
|
struct roots_seat_view *seat_view =
|
|
|
|
roots_seat_view_from_view(seat, view);
|
|
|
|
roots_seat_view_from_view(seat, view);
|
|
|
|
if (cursor->pointer_view && (surface ||
|
|
|
|
|
|
|
|
seat_view != cursor->pointer_view)) {
|
|
|
|
if (cursor->pointer_view &&
|
|
|
|
|
|
|
|
!cursor->wlr_surface && (surface || seat_view != cursor->pointer_view)) {
|
|
|
|
seat_view_deco_leave(cursor->pointer_view);
|
|
|
|
seat_view_deco_leave(cursor->pointer_view);
|
|
|
|
cursor->pointer_view = NULL;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if (!surface) {
|
|
|
|
|
|
|
|
cursor->pointer_view = seat_view;
|
|
|
|
cursor->pointer_view = seat_view;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (!surface) {
|
|
|
|
seat_view_deco_motion(seat_view, sx, sy);
|
|
|
|
seat_view_deco_motion(seat_view, sx, sy);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
cursor->pointer_view = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
cursor->wlr_surface = surface;
|
|
|
|
|
|
|
|
|
|
|
|
if (surface) {
|
|
|
|
if (surface) {
|
|
|
|
focus_changed = (seat->seat->pointer_state.focused_surface != surface);
|
|
|
|
focus_changed = (seat->seat->pointer_state.focused_surface != surface);
|
|
|
|
wlr_seat_pointer_notify_enter(seat->seat, surface, sx, sy);
|
|
|
|
wlr_seat_pointer_notify_enter(seat->seat, surface, sx, sy);
|
|
|
|