wayland server имплементация, создание глобальных объектов
В ходе соединения ничего не происходит.
Как сделать так чтобы вызывалась wl_output_handle_bind() из wl_output_interface по запросу на биндинг от клиента?
wl_global_create() шаблон исходя из /usr/include/wayland-server-core.h это:
struct wl_global *
wl_global_create(struct wl_display *display,
const struct wl_interface *interface,
int version,
void *data, wl_global_bind_func_t bind);
Текущий вывод приложения таков:
client
info: wl_output
info: binding
server
unable to lock lockfile /run/user/1000/wayland-0.lock, maybe another compositor is running
running wayland display on wayland-1
Код серверной реализации:
// server.c
#include <stdlib.h>
#include <stdio.h>
#include <wayland-server.h>
struct server_state { void *data; };
struct composed_output { struct server_state *state; struct wl_resource *resource; };
// resource_container_flush () ..
// resource_container_add () ..
static void wl_output_handle_resource_destroy (struct wl_resource *resource) {
struct composed_output *client_output = wl_resource_get_user_data (resource);
// to do: clean up global{,s} resourcing
// resource_container_flush (client_output->state->data, client_output);
}
static void wl_output_handle_release (struct wl_client *client,
struct wl_resource *resource) {
printf ("info: release event handler: processing global remove event\n");
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 server_state *state = data;
struct composed_output *client_output = calloc (1, sizeof (struct composed_output));
printf ("info: binding event handler\n");
}
int main (int argc, char *argv[]) {
struct wl_display *display = wl_display_create ();
if (!display) {
fprintf (stderr, "unable to create wayland display\n");
return 1;
}
const char *socket = wl_display_add_socket_auto (display);
if (!socket) {
fprintf (stderr, "unable to add socket to wayland display\n");
return 1;
}
struct server_state state = { .data = NULL };
wl_global_create (display, &wl_output_interface,
1, &state, wl_output_handle_bind);
fprintf (stderr, "running wayland display on %s\n", socket);
wl_display_run (display);
wl_display_destroy (display);
return 0;
}
Код клиентской реализации:
// client.c
#include <stdint.h>
#include <stdio.h>
#include <wayland-client.h>
static void registry_handle_global (void *data,
struct wl_registry *registry,
uint32_t name,
const char *interface,
uint32_t version) {
printf ("info: %s\n", interface);
if (strcmp (interface, wl_output_interface.name) == 0) {
printf ("info: binding\n");
wl_registry_bind (registry, name, &wl_output_interface, 1);
}
}
static void registry_handle_global_remove (void *data,
struct wl_registry *registry,
uint32_t name) {
// this function implementation from handle is blank in this exercise
}
static const struct wl_registry_listener registry_listener = {
.global = registry_handle_global,
.global_remove = registry_handle_global_remove,
};
int main (int argc, char *argv[]) {
struct wl_display *display = wl_display_connect ("wayland-1");
struct wl_registry *registry = wl_display_get_registry (display);
if (display == NULL) { fprintf (stderr, "can't connect to display\n"); return 1; }
if (registry == NULL) { fprintf (stderr, "can't connect to registry\n"); return 1; }
wl_registry_add_listener (registry, ®istry_listener, NULL);
wl_display_roundtrip (display);
return 0;
}
Отладочный лог (в т.ч. и через coredump значения те же):
export WAYLAND_DEBUG=1; ./server
unable to lock lockfile /run/user/1000/wayland-0.lock, maybe another compositor is running
running wayland display on wayland-1
[1960331.814] wl_display@1.get_registry(new id wl_registry@2)
[1960331.839] -> wl_registry@2.global(1, "wl_output", 3)
[1960331.860] wl_display@1.sync(new id wl_callback@3)
[1960331.866] -> wl_callback@3.done(0)
[1960331.871] -> wl_display@1.delete_id(3)
[1960331.946] wl_registry@2.bind(1, "wl_output", 3, new id [unknown]@4)
info: wl_output binding event handler; interface version: 3
zsh: segmentation fault (core dumped) ./server