diff options
author | Daniel Stone <daniel@fooishbar.org> | 2012-05-30 16:32:06 +0100 |
---|---|---|
committer | Kristian Høgsberg <krh@bitplanet.net> | 2012-05-31 15:50:42 -0400 |
commit | bb1df6a7c149138693049ec17e492632135a2311 (patch) | |
tree | 2c34dea3acff0e7ddf4739f5dcfbf1489d58a9ce /src/compositor.c | |
parent | d65b909778e2f2d70c409e473572d0f5cc31562d (diff) |
Add keymap argument to weston_seat_init_keyboard
This allows backends to generate their own keymaps and pass them in for
use rather than always forcing a single global keymap, which is
particularly useful for nested compositors.
Signed-off-by: Daniel Stone <daniel@fooishbar.org>
Diffstat (limited to 'src/compositor.c')
-rw-r--r-- | src/compositor.c | 92 |
1 files changed, 52 insertions, 40 deletions
diff --git a/src/compositor.c b/src/compositor.c index f6676a7..311bb15 100644 --- a/src/compositor.c +++ b/src/compositor.c @@ -2224,13 +2224,15 @@ device_handle_new_drag_icon(struct wl_listener *listener, void *data) weston_seat_update_drag_surface(&seat->seat, 0, 0); } -static int weston_compositor_xkb_init(struct weston_compositor *ec, - struct xkb_rule_names *names) +static void weston_compositor_xkb_init(struct weston_compositor *ec, + struct xkb_rule_names *names) { - ec->xkb_context = xkb_context_new(0); if (ec->xkb_context == NULL) { - fprintf(stderr, "failed to create XKB context\n"); - return -1; + ec->xkb_context = xkb_context_new(0); + if (ec->xkb_context == NULL) { + fprintf(stderr, "failed to create XKB context\n"); + exit(1); + } } if (names) @@ -2241,8 +2243,6 @@ static int weston_compositor_xkb_init(struct weston_compositor *ec, ec->xkb_names.model = strdup("pc105"); if (!ec->xkb_names.layout) ec->xkb_names.layout = strdup("us"); - - return 0; } static void xkb_info_destroy(struct weston_xkb_info *xkb_info) @@ -2263,50 +2263,65 @@ static void weston_compositor_xkb_destroy(struct weston_compositor *ec) xkb_context_unref(ec->xkb_context); } -static int -weston_compositor_build_global_keymap(struct weston_compositor *ec) +static void +weston_xkb_info_get_mods(struct weston_xkb_info *xkb_info) { - if (!ec->xkb_context) - weston_compositor_xkb_init(ec, NULL); + xkb_info->ctrl_mod = xkb_map_mod_get_index(xkb_info->keymap, + XKB_MOD_NAME_CTRL); + xkb_info->alt_mod = xkb_map_mod_get_index(xkb_info->keymap, + XKB_MOD_NAME_ALT); + xkb_info->super_mod = xkb_map_mod_get_index(xkb_info->keymap, + XKB_MOD_NAME_LOGO); + xkb_info->num_led = xkb_map_led_get_index(xkb_info->keymap, + XKB_LED_NAME_NUM); + xkb_info->caps_led = xkb_map_led_get_index(xkb_info->keymap, + XKB_LED_NAME_CAPS); + xkb_info->scroll_led = xkb_map_led_get_index(xkb_info->keymap, + XKB_LED_NAME_SCROLL); +} + +static void +weston_compositor_build_global_keymap(struct weston_compositor *ec) +{ if (ec->xkb_info.keymap != NULL) - return 0; + return; + + if (ec->xkb_names.rules == NULL) + weston_compositor_xkb_init(ec, NULL); ec->xkb_info.keymap = xkb_map_new_from_names(ec->xkb_context, - &ec->xkb_names, 0); + &ec->xkb_names, + 0); if (ec->xkb_info.keymap == NULL) { - fprintf(stderr, "failed to compile XKB keymap\n"); - return -1; + fprintf(stderr, "failed to compile global XKB keymap\n"); + fprintf(stderr, + " tried rules %s, model %s, layout %s, variant %s, " + "options %s", + ec->xkb_names.rules, ec->xkb_names.model, + ec->xkb_names.layout, ec->xkb_names.variant, + ec->xkb_names.options); + exit(1); } - ec->xkb_info.ctrl_mod = xkb_map_mod_get_index(ec->xkb_info.keymap, - XKB_MOD_NAME_CTRL); - ec->xkb_info.alt_mod = xkb_map_mod_get_index(ec->xkb_info.keymap, - XKB_MOD_NAME_ALT); - ec->xkb_info.super_mod = xkb_map_mod_get_index(ec->xkb_info.keymap, - XKB_MOD_NAME_LOGO); - - ec->xkb_info.num_led = xkb_map_led_get_index(ec->xkb_info.keymap, - XKB_LED_NAME_NUM); - ec->xkb_info.caps_led = xkb_map_led_get_index(ec->xkb_info.keymap, - XKB_LED_NAME_CAPS); - ec->xkb_info.scroll_led = xkb_map_led_get_index(ec->xkb_info.keymap, - XKB_LED_NAME_SCROLL); - - return 0; + weston_xkb_info_get_mods(&ec->xkb_info); } WL_EXPORT void -weston_seat_init_keyboard(struct weston_seat *seat) +weston_seat_init_keyboard(struct weston_seat *seat, struct xkb_keymap *keymap) { if (seat->has_keyboard) return; - if (weston_compositor_build_global_keymap(seat->compositor) == -1) - return; - - seat->xkb_info = seat->compositor->xkb_info; - seat->xkb_info.keymap = xkb_map_ref(seat->xkb_info.keymap); + if (keymap != NULL) { + seat->xkb_info.keymap = xkb_map_ref(keymap); + weston_xkb_info_get_mods(&seat->xkb_info); + } + else { + weston_compositor_build_global_keymap(seat->compositor); + seat->xkb_info = seat->compositor->xkb_info; + seat->xkb_info.keymap = xkb_map_ref(seat->xkb_info.keymap); + } seat->xkb_state.state = xkb_state_new(seat->xkb_info.keymap); if (seat->xkb_state.state == NULL) { @@ -3115,10 +3130,7 @@ int main(int argc, char *argv[]) if (argv[1]) exit(EXIT_FAILURE); - if (weston_compositor_xkb_init(ec, &xkb_names) == -1) { - fprintf(stderr, "failed to initialise keyboard support\n"); - exit(EXIT_FAILURE); - } + weston_compositor_xkb_init(ec, &xkb_names); ec->option_idle_time = idle_time; ec->idle_time = idle_time; |