summaryrefslogtreecommitdiff
path: root/lib/renderers/wayland/window.c
diff options
context:
space:
mode:
Diffstat (limited to 'lib/renderers/wayland/window.c')
-rw-r--r--lib/renderers/wayland/window.c16
1 files changed, 13 insertions, 3 deletions
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;
}