aboutsummaryrefslogtreecommitdiff
path: root/examples/compositor
diff options
context:
space:
mode:
Diffstat (limited to 'examples/compositor')
-rw-r--r--examples/compositor/main.c2
-rw-r--r--examples/compositor/wl_compositor.c2
-rw-r--r--examples/compositor/wlr_surface.c120
-rw-r--r--examples/compositor/wlr_surface.h24
4 files changed, 2 insertions, 146 deletions
diff --git a/examples/compositor/main.c b/examples/compositor/main.c
index 01292f51..8e5fcc34 100644
--- a/examples/compositor/main.c
+++ b/examples/compositor/main.c
@@ -10,11 +10,11 @@
#include <wlr/render.h>
#include <wlr/render/gles2.h>
#include <wlr/types/wlr_output.h>
+#include <wlr/types/wlr_surface.h>
#include <xkbcommon/xkbcommon.h>
#include <wlr/util/log.h>
#include "shared.h"
#include "compositor.h"
-#include "wlr_surface.h"
struct sample_state {
struct wlr_renderer *renderer;
diff --git a/examples/compositor/wl_compositor.c b/examples/compositor/wl_compositor.c
index 8c8ee3b6..89d23d6a 100644
--- a/examples/compositor/wl_compositor.c
+++ b/examples/compositor/wl_compositor.c
@@ -2,8 +2,8 @@
#include <stdlib.h>
#include <wayland-server.h>
#include <wlr/util/log.h>
+#include <wlr/types/wlr_surface.h>
#include "compositor.h"
-#include "compositor/wlr_surface.h"
static void destroy_surface_listener(struct wl_listener *listener, void *data) {
struct wl_compositor_state *state;
diff --git a/examples/compositor/wlr_surface.c b/examples/compositor/wlr_surface.c
deleted file mode 100644
index 5a5c3e0d..00000000
--- a/examples/compositor/wlr_surface.c
+++ /dev/null
@@ -1,120 +0,0 @@
-#include <assert.h>
-#include <stdlib.h>
-#include <wayland-server.h>
-#include <wlr/util/log.h>
-#include <wlr/render/interface.h>
-#include "wlr_surface.h"
-
-static void surface_destroy(struct wl_client *client, struct wl_resource *resource) {
- struct wlr_surface *surface = wl_resource_get_user_data(resource);
- wl_signal_emit(&surface->signals.destroy, surface);
- wl_resource_destroy(resource);
-}
-
-static void surface_attach(struct wl_client *client,
- struct wl_resource *resource,
- struct wl_resource *buffer, int32_t sx, int32_t sy) {
- struct wlr_surface *surface = wl_resource_get_user_data(resource);
- surface->pending_buffer = buffer;
- surface->pending_attached = true;
-}
-
-static void surface_damage(struct wl_client *client,
- struct wl_resource *resource,
- int32_t x, int32_t y, int32_t width, int32_t height) {
- wlr_log(L_DEBUG, "TODO: surface damage");
-}
-
-static void surface_frame(struct wl_client *client,
- struct wl_resource *resource, uint32_t callback) {
- wlr_log(L_DEBUG, "TODO: surface frame");
-}
-
-static void surface_set_opaque_region(struct wl_client *client,
- struct wl_resource *resource,
- struct wl_resource *region_resource) {
- wlr_log(L_DEBUG, "TODO: surface opaque region");
-}
-
-static void surface_set_input_region(struct wl_client *client,
- struct wl_resource *resource,
- struct wl_resource *region_resource) {
-
- wlr_log(L_DEBUG, "TODO: surface input region");
-}
-
-static void surface_commit(struct wl_client *client,
- struct wl_resource *resource) {
- struct wlr_surface *surface = wl_resource_get_user_data(resource);
-
- // apply pending state
- if (surface->pending_attached) {
- surface->attached = surface->pending_buffer;
- if (surface->pending_buffer) {
- struct wl_shm_buffer *buffer = wl_shm_buffer_get(surface->pending_buffer);
- if (!buffer) {
- wlr_log(L_INFO, "Unknown buffer handle attached");
- } else {
- uint32_t format = wl_shm_buffer_get_format(buffer);
- wlr_texture_upload_shm(surface->texture, format, buffer);
- }
- }
- }
-
- // reset pending state
- surface->pending_buffer = NULL;
- surface->pending_attached = false;
-
- wl_signal_emit(&surface->signals.commit, surface);
-}
-
-static void surface_set_buffer_transform(struct wl_client *client,
- struct wl_resource *resource, int transform) {
- wlr_log(L_DEBUG, "TODO: surface surface buffer transform");
-}
-
-static void surface_set_buffer_scale(struct wl_client *client,
- struct wl_resource *resource,
- int32_t scale) {
- wlr_log(L_DEBUG, "TODO: surface set buffer scale");
-}
-
-
-static void surface_damage_buffer(struct wl_client *client,
- struct wl_resource *resource,
- int32_t x, int32_t y, int32_t width,
- int32_t height) {
- wlr_log(L_DEBUG, "TODO: surface damage buffer");
-}
-
-const struct wl_surface_interface surface_interface = {
- surface_destroy,
- surface_attach,
- surface_damage,
- surface_frame,
- surface_set_opaque_region,
- surface_set_input_region,
- surface_commit,
- surface_set_buffer_transform,
- surface_set_buffer_scale,
- surface_damage_buffer
-};
-
-static void destroy_surface(struct wl_resource *resource) {
- struct wlr_surface *surface = wl_resource_get_user_data(resource);
- wl_signal_emit(&surface->signals.destroy, surface);
- wlr_texture_destroy(surface->texture);
-}
-
-struct wlr_surface *wlr_surface_create(struct wl_resource *res,
- struct wlr_renderer *renderer) {
- struct wlr_surface *surface = calloc(1, sizeof(struct wlr_surface));
- surface->texture = wlr_render_texture_init(renderer);
- surface->resource = res;
- wl_signal_init(&surface->signals.commit);
- wl_signal_init(&surface->signals.destroy);
- wl_resource_set_implementation(res, &surface_interface,
- surface, destroy_surface);
-
- return surface;
-}
diff --git a/examples/compositor/wlr_surface.h b/examples/compositor/wlr_surface.h
deleted file mode 100644
index d294bdef..00000000
--- a/examples/compositor/wlr_surface.h
+++ /dev/null
@@ -1,24 +0,0 @@
-#ifndef _EXAMPLES_COMPOSITOR_SURFACE_H
-#define _EXAMPLES_COMPOSITOR_SURFACE_H
-
-#include <wayland-server.h>
-
-struct wlr_surface {
- struct wl_resource *pending_buffer;
- bool pending_attached;
- bool attached; // whether the surface currently has a buffer attached
-
- struct wlr_texture *texture;
- const char *role; // the lifetime-bound role or null
- struct wl_resource *resource;
-
- struct {
- struct wl_signal destroy;
- struct wl_signal commit;
- } signals;
-};
-
-struct wlr_surface *wlr_surface_create(struct wl_resource *res,
- struct wlr_renderer *renderer);
-
-#endif