diff options
author | Jari Vetoniemi <mailRoxas@gmail.com> | 2018-04-29 19:51:57 +0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-04-29 19:51:57 +0300 |
commit | 5ecb57085785c8e3fac68d8a2f2b6cf2e44c1092 (patch) | |
tree | 28685517342ee943414de4047900e2c8f83171ce | |
parent | f7bb9f953df41d61beb1bce750ca10df1993ec99 (diff) | |
parent | 67c3c04acbc8e00a9fcbcba63940eea66dd3d01f (diff) | |
download | bemenu-5ecb57085785c8e3fac68d8a2f2b6cf2e44c1092.tar.gz bemenu-5ecb57085785c8e3fac68d8a2f2b6cf2e44c1092.tar.bz2 bemenu-5ecb57085785c8e3fac68d8a2f2b6cf2e44c1092.zip |
Merge pull request #33 from martinetd/wayland
More wayland fixes
-rw-r--r-- | client/common/common.c | 2 | ||||
-rw-r--r-- | lib/renderers/wayland/wayland.c | 15 | ||||
-rw-r--r-- | lib/renderers/wayland/wayland.h | 3 | ||||
-rw-r--r-- | lib/renderers/wayland/window.c | 16 |
4 files changed, 30 insertions, 6 deletions
diff --git a/client/common/common.c b/client/common/common.c index 7782925..f59088c 100644 --- a/client/common/common.c +++ b/client/common/common.c @@ -82,7 +82,7 @@ usage(FILE *out, const char *name) " c = ncurses, w == wayland, x == x11\n" " (...) At end of help indicates the backend support for option.\n\n" - " -b, --bottom appears at the bottom of the screen. (x)\n" + " -b, --bottom appears at the bottom of the screen. (wx)\n" " -f, --grab show the menu before reading stdin. (wx)\n" " -m, --monitor index of monitor where menu will appear. (x)\n" " --fn defines the font to be used ('name [size]'). (wx)\n" diff --git a/lib/renderers/wayland/wayland.c b/lib/renderers/wayland/wayland.c index 69ca230..dd97009 100644 --- a/lib/renderers/wayland/wayland.c +++ b/lib/renderers/wayland/wayland.c @@ -40,7 +40,7 @@ render(const struct bm_menu *menu) if (wayland->input.code != wayland->input.last_code) { struct window *window; wl_list_for_each(window, &wayland->windows, link) { - bm_wl_window_render(window, menu); + bm_wl_window_render(window, wayland->display, menu); } wayland->input.last_code = wayland->input.code; } @@ -190,6 +190,18 @@ set_bottom(const struct bm_menu *menu, bool bottom) } static void +grab_keyboard(const struct bm_menu *menu, bool grab) +{ + struct wayland *wayland = menu->renderer->internal; + assert(wayland); + + struct window *window; + wl_list_for_each(window, &wayland->windows, link) { + bm_wl_window_grab_keyboard(window, wayland->display, grab); + } +} + +static void destructor(struct bm_menu *menu) { struct wayland *wayland = menu->renderer->internal; @@ -282,6 +294,7 @@ register_renderer(struct render_api *api) api->poll_key = poll_key; api->render = render; api->set_bottom = set_bottom; + api->grab_keyboard = grab_keyboard; api->priorty = BM_PRIO_GUI; api->version = BM_PLUGIN_VERSION; return "wayland"; diff --git a/lib/renderers/wayland/wayland.h b/lib/renderers/wayland/wayland.h index 9fd9dc7..cc50feb 100644 --- a/lib/renderers/wayland/wayland.h +++ b/lib/renderers/wayland/wayland.h @@ -117,8 +117,9 @@ struct wayland { void bm_wl_repeat(struct wayland *wayland); bool bm_wl_registry_register(struct wayland *wayland); void bm_wl_registry_destroy(struct wayland *wayland); -void bm_wl_window_render(struct window *window, const struct bm_menu *menu); +void bm_wl_window_render(struct window *window, struct wl_display *display, const struct bm_menu *menu); void bm_wl_window_set_bottom(struct window *window, struct wl_display *display, bool bottom); +void bm_wl_window_grab_keyboard(struct window *window, struct wl_display *display, bool grab); bool bm_wl_window_create(struct window *window, struct wl_display *display, struct wl_shm *shm, struct wl_output *output, struct zwlr_layer_shell_v1 *layer_shell, struct wl_surface *surface); void bm_wl_window_destroy(struct window *window); diff --git a/lib/renderers/wayland/window.c b/lib/renderers/wayland/window.c index e195e38..4669f20 100644 --- a/lib/renderers/wayland/window.c +++ b/lib/renderers/wayland/window.c @@ -204,7 +204,7 @@ static const struct wl_callback_listener listener = { }; void -bm_wl_window_render(struct window *window, const struct bm_menu *menu) +bm_wl_window_render(struct window *window, struct wl_display *display, const struct bm_menu *menu) { assert(window && menu); @@ -229,6 +229,9 @@ bm_wl_window_render(struct window *window, const struct bm_menu *menu) break; window->height = result.height; + zwlr_layer_surface_v1_set_size(window->layer_surface, 0, window->height); + wl_surface_commit(window->surface); + wl_display_roundtrip(display); destroy_buffer(buffer); } @@ -292,6 +295,14 @@ bm_wl_window_set_bottom(struct window *window, struct wl_display *display, bool wl_display_roundtrip(display); } +void +bm_wl_window_grab_keyboard(struct window *window, struct wl_display *display, bool grab) +{ + zwlr_layer_surface_v1_set_keyboard_interactivity(window->layer_surface, grab); + wl_surface_commit(window->surface); + wl_display_roundtrip(display); +} + bool bm_wl_window_create(struct window *window, struct wl_display *display, struct wl_shm *shm, struct wl_output *output, struct zwlr_layer_shell_v1 *layer_shell, struct wl_surface *surface) { @@ -299,9 +310,9 @@ bm_wl_window_create(struct window *window, struct wl_display *display, struct wl if (layer_shell && (window->layer_surface = zwlr_layer_shell_v1_get_layer_surface(layer_shell, surface, output, ZWLR_LAYER_SHELL_V1_LAYER_TOP, "menu"))) { zwlr_layer_surface_v1_add_listener(window->layer_surface, &layer_surface_listener, window); + zwlr_layer_surface_v1_set_exclusive_zone(window->layer_surface, -1); zwlr_layer_surface_v1_set_anchor(window->layer_surface, (window->bottom ? ZWLR_LAYER_SURFACE_V1_ANCHOR_BOTTOM : ZWLR_LAYER_SURFACE_V1_ANCHOR_TOP) | ZWLR_LAYER_SURFACE_V1_ANCHOR_LEFT | ZWLR_LAYER_SURFACE_V1_ANCHOR_RIGHT); zwlr_layer_surface_v1_set_size(window->layer_surface, 0, 32); - zwlr_layer_surface_v1_set_keyboard_interactivity(window->layer_surface, true); wl_surface_commit(surface); wl_display_roundtrip(display); } else { @@ -310,7 +321,6 @@ bm_wl_window_create(struct window *window, struct wl_display *display, struct wl window->shm = shm; window->surface = surface; - wl_surface_damage(surface, 0, 0, window->width, window->height); return true; } |