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.c31
1 files changed, 17 insertions, 14 deletions
diff --git a/lib/renderers/wayland/window.c b/lib/renderers/wayland/window.c
index d70d43b..a9c9edc 100644
--- a/lib/renderers/wayland/window.c
+++ b/lib/renderers/wayland/window.c
@@ -248,7 +248,7 @@ static const struct wl_callback_listener listener = {
};
void
-bm_wl_window_render(struct window *window, const struct bm_menu *menu, uint32_t lines)
+bm_wl_window_render(struct window *window, const struct bm_menu *menu)
{
assert(window && menu);
@@ -256,22 +256,25 @@ bm_wl_window_render(struct window *window, const struct bm_menu *menu, uint32_t
return;
struct buffer *buffer;
- if (!(buffer = next_buffer(window))) {
- fprintf(stderr, "could not get next buffer");
- exit(EXIT_FAILURE);
- }
+ for (int tries = 0; tries < 2; ++tries) {
+ if (!(buffer = next_buffer(window))) {
+ fprintf(stderr, "could not get next buffer");
+ exit(EXIT_FAILURE);
+ }
- cairo_font_extents_t fe;
- bm_cairo_get_font_extents(&buffer->cairo, &menu->font, &fe);
- window->height = MIN(lines * (fe.height + 4), window->max_height);
+ if (!window->notify.render)
+ break;
- if (window->height != buffer->height && !(buffer = next_buffer(window))) {
- fprintf(stderr, "could not get next buffer");
- exit(EXIT_FAILURE);
- }
+ struct cairo_paint_result result;
+ window->notify.render(&buffer->cairo, buffer->width, buffer->height, menu, &result);
+ window->displayed = result.displayed;
+
+ if (window->height == result.height)
+ break;
- if (window->notify.render)
- window->displayed = window->notify.render(&buffer->cairo, buffer->width, buffer->height, menu);
+ window->height = result.height;
+ destroy_buffer(buffer);
+ }
window->frame_cb = wl_surface_frame(window->surface);
wl_callback_add_listener(window->frame_cb, &listener, window);