]> git.mdlowis.com Git - proto/labwc.git/commitdiff
Refactor buffer implementation to take a cairo_t
authorJohan Malm <jgm323@gmail.com>
Sun, 13 Feb 2022 11:47:03 +0000 (11:47 +0000)
committerJohan Malm <jgm323@gmail.com>
Wed, 23 Feb 2022 21:47:01 +0000 (21:47 +0000)
Remove buffer_drop() and just destroy it.

include/buffer.h
src/buffer.c
src/osd.c

index 8c141f8a236fdd09e6b35ec59059734ec9479d7b..dd84180398439e753919168c2c7e4907409559e4 100644 (file)
 #ifndef __LABWC_BUFFER_H
 #define __LABWC_BUFFER_H
 
+#include <cairo.h>
 #include "labwc.h"
 
-/**
- * A read-only buffer that holds a data pointer.
- *
- * This is suitable for passing raw pixel data to a function that accepts a
- * wlr_buffer.
- */
 struct lab_data_buffer {
        struct wlr_buffer base;
 
-       const void *data;
+       cairo_t *cairo;
+       void *data;
        uint32_t format;
        size_t stride;
-
-       void *saved_data;
 };
 
-/**
- * Wraps a read-only data pointer into a wlr_buffer. The data pointer may be
- * accessed until readonly_data_buffer_drop() is called.
- */
-struct lab_data_buffer *buffer_create(uint32_t format, size_t stride,
-       uint32_t width, uint32_t height, const void *data);
-
-/**
- * Drops ownership of the buffer (see wlr_buffer_drop() for more details) and
- * perform a copy of the data pointer if a consumer still has the buffer locked.
- */
-bool buffer_drop(struct lab_data_buffer *buffer);
+struct lab_data_buffer *buffer_create(cairo_t *cairo);
+void buffer_destroy(struct lab_data_buffer *buffer);
 
 #endif /* __LABWC_BUFFER_H */
index 0188ee01bdedd6ac65341bdd835e03d76e1485ed..640a21890f46fa713106cd99f66247d2a0140885 100644 (file)
@@ -42,7 +42,7 @@ static void
 data_buffer_destroy(struct wlr_buffer *wlr_buffer)
 {
        struct lab_data_buffer *buffer = data_buffer_from_buffer(wlr_buffer);
-       free(buffer->saved_data);
+       free(buffer->data);
        free(buffer);
 }
 
@@ -50,13 +50,9 @@ static bool
 data_buffer_begin_data_ptr_access(struct wlr_buffer *wlr_buffer, uint32_t flags,
                void **data, uint32_t *format, size_t *stride)
 {
-       struct lab_data_buffer *buffer = data_buffer_from_buffer(wlr_buffer);
-       if (buffer->data == NULL) {
-               return false;
-       }
-       if (flags & WLR_BUFFER_DATA_PTR_ACCESS_WRITE) {
-               return false;
-       }
+       struct lab_data_buffer *buffer =
+               wl_container_of(wlr_buffer, buffer, base);
+       assert(buffer->data);
        *data = (void *)buffer->data;
        *format = buffer->format;
        *stride = buffer->stride;
@@ -76,38 +72,35 @@ static const struct wlr_buffer_impl data_buffer_impl = {
 };
 
 struct lab_data_buffer *
-buffer_create(uint32_t format, size_t stride, uint32_t width, uint32_t height,
-               const void *data)
+buffer_create(cairo_t *cairo)
 {
        struct lab_data_buffer *buffer = calloc(1, sizeof(*buffer));
-       if (buffer == NULL) {
+       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->data = data;
-       buffer->format = format;
-       buffer->stride = stride;
+
+       buffer->cairo = cairo;
+       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);
+               free(buffer);
+       }
        return buffer;
 }
 
-
-bool
-buffer_drop(struct lab_data_buffer *buffer)
+void
+buffer_destroy(struct lab_data_buffer *buffer)
 {
-       bool ok = true;
-
-       if (buffer->base.n_locks > 0) {
-               size_t size = buffer->stride * buffer->base.height;
-               buffer->saved_data = malloc(size);
-               if (!buffer->saved_data) {
-                       wlr_log_errno(WLR_ERROR, "allocation failed");
-                       ok = false;
-                       buffer->data = NULL;
-               } else {
-                       memcpy(buffer->saved_data, buffer->data, size);
-                       buffer->data = buffer->saved_data;
-               }
+       if (!buffer) {
+               return;
        }
+       cairo_destroy(buffer->cairo);
        wlr_buffer_drop(&buffer->base);
-       return ok;
 }
index f790cd16388edad7d3fd97f7902284d9543f0f42..9f7beea1a7764ad1b92c9c4f75313b37ff84f3ae 100644 (file)
--- a/src/osd.c
+++ b/src/osd.c
@@ -197,14 +197,8 @@ osd_update(struct server *server)
                g_object_unref(layout);
 
                cairo_surface_flush(surf);
-               unsigned char *data = cairo_image_surface_get_data(surf);
-               if (output->osd_buffer) {
-                       buffer_drop(output->osd_buffer);
-               }
-               output->osd_buffer = buffer_create(DRM_FORMAT_ARGB8888,
-                       cairo_image_surface_get_stride(surf), w, h, data);
-
-               cairo_surface_destroy(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);