mirror of
https://gitlab.freedesktop.org/wlroots/wlroots.git
synced 2026-02-21 01:40:48 -05:00
single-pixel-buffer: Add try_from_buffer() function
Add wlr_single_pixel_buffer_v1_try_from_buffer() and move `struct wlr_single_pixel_buffer_v1` to wlr_buffer.h. This allows other code to find out if a wlr_buffer is a single-pixel buffer and, if so, find out what color it is.
This commit is contained in:
parent
709fc8fd8e
commit
5563d23b81
2 changed files with 36 additions and 9 deletions
|
|
@ -8,15 +8,6 @@
|
|||
|
||||
#define SINGLE_PIXEL_MANAGER_VERSION 1
|
||||
|
||||
struct wlr_single_pixel_buffer_v1 {
|
||||
struct wlr_buffer base;
|
||||
struct wl_resource *resource;
|
||||
uint32_t r, g, b, a;
|
||||
uint8_t argb8888[4]; // packed little-endian DRM_FORMAT_ARGB8888
|
||||
|
||||
struct wl_listener release;
|
||||
};
|
||||
|
||||
static void destroy_resource(struct wl_client *client,
|
||||
struct wl_resource *resource) {
|
||||
wl_resource_destroy(resource);
|
||||
|
|
@ -180,3 +171,14 @@ struct wlr_single_pixel_buffer_manager_v1 *wlr_single_pixel_buffer_manager_v1_cr
|
|||
|
||||
return manager;
|
||||
}
|
||||
|
||||
struct wlr_single_pixel_buffer_v1 *wlr_single_pixel_buffer_v1_try_from_buffer(
|
||||
struct wlr_buffer *buffer) {
|
||||
|
||||
if (buffer->impl != &buffer_impl) {
|
||||
return NULL;
|
||||
}
|
||||
|
||||
return wl_container_of(buffer,
|
||||
(struct wlr_single_pixel_buffer_v1 *)NULL, base);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue