diff options
author | Ilia Bozhinov <ammen99@gmail.com> | 2019-03-25 22:21:17 +0100 |
---|---|---|
committer | Jari Vetoniemi <mailRoxas@gmail.com> | 2019-03-25 23:21:17 +0200 |
commit | 38069992ec97aa22da84a1e1dbb5e8ff9cd03d60 (patch) | |
tree | 4c476d8c56c8b1fe84c7858b6c8b61a46cadae21 /lib/renderers/wayland/window.c | |
parent | b375ef8b0bd2c40b4fc26bd0c4d38dcb4374c149 (diff) | |
download | bemenu-38069992ec97aa22da84a1e1dbb5e8ff9cd03d60.tar.gz bemenu-38069992ec97aa22da84a1e1dbb5e8ff9cd03d60.tar.bz2 bemenu-38069992ec97aa22da84a1e1dbb5e8ff9cd03d60.zip |
Add option to respect panel position (#48)
* implement option to make menu respect panel boundaries
* fixup! implement option to make menu respect panel boundaries
Diffstat (limited to 'lib/renderers/wayland/window.c')
-rw-r--r-- | lib/renderers/wayland/window.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/lib/renderers/wayland/window.c b/lib/renderers/wayland/window.c index 2141eff..55b8690 100644 --- a/lib/renderers/wayland/window.c +++ b/lib/renderers/wayland/window.c @@ -310,6 +310,14 @@ bm_wl_window_grab_keyboard(struct window *window, struct wl_display *display, bo wl_display_roundtrip(display); } +void +bm_wl_window_set_overlap(struct window *window, struct wl_display *display, bool overlap) +{ + zwlr_layer_surface_v1_set_exclusive_zone(window->layer_surface, overlap ? -1 : 0); + 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) { @@ -317,7 +325,6 @@ 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); wl_surface_commit(surface); |