From e47401a08de31f800efa49cf02d1b33ba1f58ec0 Mon Sep 17 00:00:00 2001 From: Florian RICHER Date: Thu, 6 Jun 2024 22:47:34 +0200 Subject: [PATCH] NotStable: 5.2 part --- src/server/main.c | 60 +++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 60 insertions(+) diff --git a/src/server/main.c b/src/server/main.c index 6904579..9972b4a 100644 --- a/src/server/main.c +++ b/src/server/main.c @@ -1,5 +1,61 @@ #include #include +#include + +struct my_output { + struct wl_resource *resource; + struct my_state *state; +}; + +struct my_state { + struct my_output **client_outputs +}; + +static void +wl_output_handle_resource_destroy(struct wl_resource *resource) +{ + struct my_output *client_output = wl_resource_get_user_data(resource); + + // TODO: Clean up resource + + remove_to_list(client_output->state->client_outputs, client_output); +} + +static void +wl_output_handle_release(struct wl_client *client, struct wl_resource *resource) +{ + wl_resource_destroy(resource); +} + +static const struct wl_output_interface +wl_output_implementation = { + .release = wl_output_handle_release, +}; + +static void +wl_output_handle_bind(struct wl_client *client, void *data, + uint32_t version, uint32_t id) +{ + struct my_state *state = data; + + struct my_output *client_output = calloc(1, sizeof(struct client_output)); + + struct wl_resource *resource = wl_resource_create( + client, &wl_output_implementation, wl_output_interface.version, id); + + wl_resource_set_implementation(resource, wl_output_implementation, + client_output, wl_output_handle_resource_destroy); + + client_output->resource = resource; + client_output->state = state; + + wl_output_send_geometry(resource, 0, 0, 1920, 1080, + WL_OUTPUT_SUBPIXEL_UNKNOWN, "Foobar, Inc", + "Fancy Monitor 9001 4K HD 120 FPS Noscope", + WL_OUTPUT_TRANSFORM_NORMAL); + + add_to_list(state->client_outputs, client_output); +} int main(int argc, char *argv[]) { @@ -9,6 +65,10 @@ int main(int argc, char *argv[]) return 1; } + struct my_state state = {}; + wl_global_create(display, &wl_output_interface, + 1, &state, wl_output_handle_bind); + const char *socket = wl_display_add_socket_auto(display); if (!socket) { fprintf(stderr, "Unable to add socket to Wayland display.\n");