]> git.mdlowis.com Git - proto/labwc.git/commitdiff
buffer: create cairo_t inside buffer_create()
authorJohan Malm <jgm323@gmail.com>
Sun, 13 Feb 2022 13:00:26 +0000 (13:00 +0000)
committerJohan Malm <jgm323@gmail.com>
Wed, 23 Feb 2022 21:47:01 +0000 (21:47 +0000)
include/buffer.h
src/buffer.c
src/osd.c

index dd84180398439e753919168c2c7e4907409559e4..63f92f877d6387b15ae6e0f11b9c49b6309b67fc 100644 (file)
@@ -38,7 +38,7 @@ struct lab_data_buffer {
        size_t stride;
 };
 
-struct lab_data_buffer *buffer_create(cairo_t *cairo);
-void buffer_destroy(struct lab_data_buffer *buffer);
+struct lab_data_buffer *buffer_create(uint32_t width, uint32_t height,
+       float scale);
 
 #endif /* __LABWC_BUFFER_H */
index 640a21890f46fa713106cd99f66247d2a0140885..69f55251727a6f35626fed4bac0713b1d9951bec 100644 (file)
@@ -42,7 +42,12 @@ static void
 data_buffer_destroy(struct wlr_buffer *wlr_buffer)
 {
        struct lab_data_buffer *buffer = data_buffer_from_buffer(wlr_buffer);
-       free(buffer->data);
+       if (buffer->cairo) {
+               cairo_destroy(buffer->cairo);
+       }
+       if (buffer->data) {
+               free(buffer->data);
+       }
        free(buffer);
 }
 
@@ -72,35 +77,26 @@ static const struct wlr_buffer_impl data_buffer_impl = {
 };
 
 struct lab_data_buffer *
-buffer_create(cairo_t *cairo)
+buffer_create(uint32_t width, uint32_t height, float scale)
 {
        struct lab_data_buffer *buffer = calloc(1, sizeof(*buffer));
        if (!buffer) {
                return NULL;
        }
-       cairo_surface_t *surf = cairo_get_target(cairo);
-       int width = cairo_image_surface_get_width(surf);
-       int height = cairo_image_surface_get_height(surf);
        wlr_buffer_init(&buffer->base, &data_buffer_impl, width, height);
 
-       buffer->cairo = cairo;
+       cairo_surface_t *surf =
+               cairo_image_surface_create(CAIRO_FORMAT_ARGB32, width, height);
+       cairo_surface_set_device_scale(surf, scale, scale);
+
+       buffer->cairo = cairo_create(surf);
        buffer->data = cairo_image_surface_get_data(surf);
        buffer->format = DRM_FORMAT_ARGB8888;
        buffer->stride = cairo_image_surface_get_stride(surf);
 
        if (!buffer->data) {
-               cairo_destroy(cairo);
+               cairo_destroy(buffer->cairo);
                free(buffer);
        }
        return buffer;
 }
-
-void
-buffer_destroy(struct lab_data_buffer *buffer)
-{
-       if (!buffer) {
-               return;
-       }
-       cairo_destroy(buffer->cairo);
-       wlr_buffer_drop(&buffer->base);
-}
index 9f7beea1a7764ad1b92c9c4f75313b37ff84f3ae..85b5e4feb67cba7f53e92b716e746e3d855766e4 100644 (file)
--- a/src/osd.c
+++ b/src/osd.c
@@ -103,10 +103,13 @@ osd_update(struct server *server)
                int w = (OSD_ITEM_WIDTH + (2 * OSD_BORDER_WIDTH)) * scale;
                int h = get_osd_height(&server->views) * scale;
 
-               cairo_surface_t *surf =
-                       cairo_image_surface_create(CAIRO_FORMAT_ARGB32, w, h);
-               cairo_surface_set_device_scale(surf, scale, scale);
-               cairo_t *cairo = cairo_create(surf);
+               if (output->osd_buffer) {
+                       wlr_buffer_drop(&output->osd_buffer->base);
+               }
+               output->osd_buffer = buffer_create(w, h, scale);
+
+               cairo_t *cairo = output->osd_buffer->cairo;
+               cairo_surface_t *surf = cairo_get_target(cairo);
 
                /* background */
                set_source(cairo, theme->osd_bg_color);
@@ -195,10 +198,7 @@ osd_update(struct server *server)
                        y += OSD_ITEM_HEIGHT;
                }
                g_object_unref(layout);
-
                cairo_surface_flush(surf);
-               buffer_destroy(output->osd_buffer);
-               output->osd_buffer = buffer_create(cairo);
 
                struct wlr_scene_buffer *scene_buffer = wlr_scene_buffer_create(
                        &server->osd_tree->node, &output->osd_buffer->base);