wayland: Clean up the relative pointer if the seat capability is removed
Also use wl_pointer_release, when available, instead of destroy.
This commit is contained in:
parent
7c8171da92
commit
3ce68f80bc
1 changed files with 9 additions and 1 deletions
|
@ -1980,11 +1980,19 @@ static void seat_handle_capabilities(void *data, struct wl_seat *seat,
|
|||
input->pointer_id = SDL_GetNextObjectID();
|
||||
SDL_AddMouse(input->pointer_id, WAYLAND_DEFAULT_POINTER_NAME, true);
|
||||
} else if (!(caps & WL_SEAT_CAPABILITY_POINTER) && input->pointer) {
|
||||
if (input->relative_pointer) {
|
||||
zwp_relative_pointer_v1_destroy(input->relative_pointer);
|
||||
input->relative_pointer = NULL;
|
||||
}
|
||||
if (input->cursor_shape) {
|
||||
wp_cursor_shape_device_v1_destroy(input->cursor_shape);
|
||||
input->cursor_shape = NULL;
|
||||
}
|
||||
wl_pointer_destroy(input->pointer);
|
||||
if (wl_pointer_get_version(input->pointer) >= WL_POINTER_RELEASE_SINCE_VERSION) {
|
||||
wl_pointer_release(input->pointer);
|
||||
} else {
|
||||
wl_pointer_destroy(input->pointer);
|
||||
}
|
||||
input->pointer = NULL;
|
||||
input->display->pointer = NULL;
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue