diff options
| author | Furkan Sahin <furkan-dev@proton.me> | 2025-02-25 10:52:52 +0100 |
|---|---|---|
| committer | Furkan Sahin <furkan-dev@proton.me> | 2025-02-25 10:52:52 +0100 |
| commit | 17f7a15861219d5f5494aeb48c42c471ea816e36 (patch) | |
| tree | 093e9381c82a2804ea202315e06d549d23a5e3e4 | |
| parent | f3b64a44cfa370039acbc940542db4f22dee6323 (diff) | |
sway_text_node: Apply max_width when rendering
max_width was applied to the source box, but not to the cairo surface.
The cairo surface would therefore take on arbitrarily large dimensions
according to the required dimensions to fit the text input, which if
large enough would cause failures during output rendering and leave a
black hole in the titlebar.
| -rw-r--r-- | sway/sway_text_node.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/sway/sway_text_node.c b/sway/sway_text_node.c index 7c781355..4bc8d996 100644 --- a/sway/sway_text_node.c +++ b/sway/sway_text_node.c @@ -87,7 +87,7 @@ static void render_backing_buffer(struct text_buffer *buffer) { } float scale = buffer->scale; - int width = ceil(buffer->props.width * scale); + int width = ceil(get_text_width(&buffer->props) * scale); int height = ceil(buffer->props.height * scale); float *color = (float *)&buffer->props.color; float *background = (float *)&buffer->props.background; @@ -153,7 +153,7 @@ static void render_backing_buffer(struct text_buffer *buffer) { pixman_region32_init(&opaque); if (background[3] == 1) { pixman_region32_union_rect(&opaque, &opaque, 0, 0, - buffer->props.width, buffer->props.height); + get_text_width(&buffer->props), buffer->props.height); } wlr_scene_buffer_set_opaque_region(buffer->buffer_node, &opaque); pixman_region32_fini(&opaque); |
