From bdc7cd06d1829a46ae4e7bb31955ae251b616241 Mon Sep 17 00:00:00 2001 From: Pekka Paalanen Date: Thu, 7 Jun 2012 15:07:07 +0300 Subject: compositor: fix a crash on missing keyboard device Signed-off-by: Pekka Paalanen --- src/compositor.c | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/src/compositor.c b/src/compositor.c index 3039c3d..94de667 100644 --- a/src/compositor.c +++ b/src/compositor.c @@ -1656,16 +1656,19 @@ weston_surface_activate(struct weston_surface *surface, { struct weston_compositor *compositor = seat->compositor; - wl_keyboard_set_focus(seat->seat.keyboard, &surface->surface); - wl_data_device_set_keyboard_focus(&seat->seat); - - if (seat->seat.keyboard->focus_resource) { - wl_keyboard_send_modifiers(seat->seat.keyboard->focus_resource, - wl_display_next_serial(compositor->wl_display), - seat->xkb_state.mods_depressed, - seat->xkb_state.mods_latched, - seat->xkb_state.mods_locked, - seat->xkb_state.group); + if (seat->seat.keyboard) { + wl_keyboard_set_focus(seat->seat.keyboard, &surface->surface); + wl_data_device_set_keyboard_focus(&seat->seat); + + if (seat->seat.keyboard->focus_resource) { + wl_keyboard_send_modifiers( + seat->seat.keyboard->focus_resource, + wl_display_next_serial(compositor->wl_display), + seat->xkb_state.mods_depressed, + seat->xkb_state.mods_latched, + seat->xkb_state.mods_locked, + seat->xkb_state.group); + } } wl_signal_emit(&compositor->activate_signal, surface); -- cgit v1.2.3