Split weston_seat_init up into pointer/keyboard/touch
So we don't unnecessarily advertise interfaces the seat doesn't support. Signed-off-by: Daniel Stone <daniel@fooishbar.org>
This commit is contained in:
parent
97f685449e
commit
74419a2237
@ -639,6 +639,7 @@ input_handle_capabilities(void *data, struct wl_seat *seat,
|
|||||||
wl_pointer_set_user_data(input->pointer, input);
|
wl_pointer_set_user_data(input->pointer, input);
|
||||||
wl_pointer_add_listener(input->pointer, &pointer_listener,
|
wl_pointer_add_listener(input->pointer, &pointer_listener,
|
||||||
input);
|
input);
|
||||||
|
weston_seat_init_pointer((struct weston_seat *) seat);
|
||||||
} else if (!(caps & WL_SEAT_CAPABILITY_POINTER) && input->pointer) {
|
} else if (!(caps & WL_SEAT_CAPABILITY_POINTER) && input->pointer) {
|
||||||
wl_pointer_destroy(input->pointer);
|
wl_pointer_destroy(input->pointer);
|
||||||
input->pointer = NULL;
|
input->pointer = NULL;
|
||||||
@ -649,6 +650,7 @@ input_handle_capabilities(void *data, struct wl_seat *seat,
|
|||||||
wl_keyboard_set_user_data(input->keyboard, input);
|
wl_keyboard_set_user_data(input->keyboard, input);
|
||||||
wl_keyboard_add_listener(input->keyboard, &keyboard_listener,
|
wl_keyboard_add_listener(input->keyboard, &keyboard_listener,
|
||||||
input);
|
input);
|
||||||
|
weston_seat_init_keyboard((struct weston_seat *) seat);
|
||||||
} else if (!(caps & WL_SEAT_CAPABILITY_KEYBOARD) && input->keyboard) {
|
} else if (!(caps & WL_SEAT_CAPABILITY_KEYBOARD) && input->keyboard) {
|
||||||
wl_keyboard_destroy(input->keyboard);
|
wl_keyboard_destroy(input->keyboard);
|
||||||
input->keyboard = NULL;
|
input->keyboard = NULL;
|
||||||
|
@ -98,6 +98,8 @@ x11_input_create(struct x11_compositor *c)
|
|||||||
|
|
||||||
memset(input, 0, sizeof *input);
|
memset(input, 0, sizeof *input);
|
||||||
weston_seat_init(&input->base, &c->base);
|
weston_seat_init(&input->base, &c->base);
|
||||||
|
weston_seat_init_pointer(&input->base);
|
||||||
|
weston_seat_init_keyboard(&input->base);
|
||||||
|
|
||||||
c->base.seat = &input->base;
|
c->base.seat = &input->base;
|
||||||
|
|
||||||
|
@ -2278,16 +2278,49 @@ static void weston_compositor_xkb_destroy(struct weston_compositor *ec)
|
|||||||
free((char *) ec->xkb_info.names.options);
|
free((char *) ec->xkb_info.names.options);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
WL_EXPORT void
|
||||||
|
weston_seat_init_pointer(struct weston_seat *seat)
|
||||||
|
{
|
||||||
|
if (seat->has_pointer)
|
||||||
|
return;
|
||||||
|
|
||||||
|
wl_pointer_init(&seat->pointer);
|
||||||
|
wl_seat_set_pointer(&seat->seat, &seat->pointer);
|
||||||
|
|
||||||
|
seat->has_pointer = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
WL_EXPORT void
|
||||||
|
weston_seat_init_keyboard(struct weston_seat *seat)
|
||||||
|
{
|
||||||
|
if (seat->has_keyboard)
|
||||||
|
return;
|
||||||
|
|
||||||
|
wl_keyboard_init(&seat->keyboard);
|
||||||
|
wl_seat_set_keyboard(&seat->seat, &seat->keyboard);
|
||||||
|
|
||||||
|
seat->has_keyboard = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
WL_EXPORT void
|
||||||
|
weston_seat_init_touch(struct weston_seat *seat)
|
||||||
|
{
|
||||||
|
if (seat->has_touch)
|
||||||
|
return;
|
||||||
|
|
||||||
|
wl_touch_init(&seat->touch);
|
||||||
|
wl_seat_set_touch(&seat->seat, &seat->touch);
|
||||||
|
|
||||||
|
seat->has_touch = 1;
|
||||||
|
}
|
||||||
|
|
||||||
WL_EXPORT void
|
WL_EXPORT void
|
||||||
weston_seat_init(struct weston_seat *seat, struct weston_compositor *ec)
|
weston_seat_init(struct weston_seat *seat, struct weston_compositor *ec)
|
||||||
{
|
{
|
||||||
wl_seat_init(&seat->seat);
|
wl_seat_init(&seat->seat);
|
||||||
wl_pointer_init(&seat->pointer);
|
seat->has_pointer = 0;
|
||||||
wl_seat_set_pointer(&seat->seat, &seat->pointer);
|
seat->has_keyboard = 0;
|
||||||
wl_keyboard_init(&seat->keyboard);
|
seat->has_touch = 0;
|
||||||
wl_seat_set_keyboard(&seat->seat, &seat->keyboard);
|
|
||||||
wl_touch_init(&seat->touch);
|
|
||||||
wl_seat_set_touch(&seat->seat, &seat->touch);
|
|
||||||
|
|
||||||
wl_display_add_global(ec->wl_display, &wl_seat_interface, seat,
|
wl_display_add_global(ec->wl_display, &wl_seat_interface, seat,
|
||||||
bind_seat);
|
bind_seat);
|
||||||
@ -2334,6 +2367,7 @@ weston_seat_release(struct weston_seat *seat)
|
|||||||
if (seat->sprite)
|
if (seat->sprite)
|
||||||
destroy_surface(&seat->sprite->surface.resource);
|
destroy_surface(&seat->sprite->surface.resource);
|
||||||
|
|
||||||
|
if (seat->xkb_state.state != NULL)
|
||||||
xkb_state_unref(seat->xkb_state.state);
|
xkb_state_unref(seat->xkb_state.state);
|
||||||
|
|
||||||
wl_seat_release(&seat->seat);
|
wl_seat_release(&seat->seat);
|
||||||
|
@ -165,8 +165,12 @@ struct weston_output {
|
|||||||
struct weston_seat {
|
struct weston_seat {
|
||||||
struct wl_seat seat;
|
struct wl_seat seat;
|
||||||
struct wl_pointer pointer;
|
struct wl_pointer pointer;
|
||||||
|
int has_pointer;
|
||||||
struct wl_keyboard keyboard;
|
struct wl_keyboard keyboard;
|
||||||
|
int has_keyboard;
|
||||||
struct wl_touch touch;
|
struct wl_touch touch;
|
||||||
|
int has_touch;
|
||||||
|
|
||||||
struct weston_compositor *compositor;
|
struct weston_compositor *compositor;
|
||||||
struct weston_surface *sprite;
|
struct weston_surface *sprite;
|
||||||
struct weston_surface *drag_surface;
|
struct weston_surface *drag_surface;
|
||||||
@ -636,6 +640,12 @@ weston_output_destroy(struct weston_output *output);
|
|||||||
|
|
||||||
void
|
void
|
||||||
weston_seat_init(struct weston_seat *seat, struct weston_compositor *ec);
|
weston_seat_init(struct weston_seat *seat, struct weston_compositor *ec);
|
||||||
|
void
|
||||||
|
weston_seat_init_pointer(struct weston_seat *seat);
|
||||||
|
void
|
||||||
|
weston_seat_init_keyboard(struct weston_seat *seat);
|
||||||
|
void
|
||||||
|
weston_seat_init_touch(struct weston_seat *seat);
|
||||||
|
|
||||||
void
|
void
|
||||||
weston_seat_release(struct weston_seat *seat);
|
weston_seat_release(struct weston_seat *seat);
|
||||||
|
@ -440,6 +440,14 @@ evdev_configure_device(struct evdev_input_device *device)
|
|||||||
if (has_abs && !has_key)
|
if (has_abs && !has_key)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
|
if ((device->caps &
|
||||||
|
(EVDEV_MOTION_ABS | EVDEV_MOTION_REL | EVDEV_BUTTON)))
|
||||||
|
weston_seat_init_pointer(&device->master->base);
|
||||||
|
if ((device->caps & EVDEV_KEYBOARD))
|
||||||
|
weston_seat_init_keyboard(&device->master->base);
|
||||||
|
if ((device->caps & EVDEV_TOUCH))
|
||||||
|
weston_seat_init_touch(&device->master->base);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user