From 85348c67cd1caf1aea83c4d23203f7a40d9dd1de Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Camilla=20L=C3=B6wy?= Date: Thu, 19 Aug 2021 18:50:17 +0200 Subject: [PATCH] Wayland: Load functions for new atomic marshalling The wayland-scanner program recently changed how it generates marshalling, requiring a couple of new core functions. Fixes #1949. --- README.md | 1 + src/wl_init.c | 4 ++++ src/wl_platform.h | 6 ++++++ 3 files changed, 11 insertions(+) diff --git a/README.md b/README.md index 44f7e3a8..0f5c2b9d 100644 --- a/README.md +++ b/README.md @@ -401,6 +401,7 @@ skills. - Martins Mozeiko - Julian Møller - ndogxj + - n3rdopolis - Kristian Nielsen - Kamil Nowakowski - onox diff --git a/src/wl_init.c b/src/wl_init.c index 33eeef8b..3d0236f2 100644 --- a/src/wl_init.c +++ b/src/wl_init.c @@ -1092,6 +1092,10 @@ int _glfwPlatformInit(void) _glfw_dlsym(_glfw.wl.client.handle, "wl_proxy_get_user_data"); _glfw.wl.client.proxy_set_user_data = (PFN_wl_proxy_set_user_data) _glfw_dlsym(_glfw.wl.client.handle, "wl_proxy_set_user_data"); + _glfw.wl.client.proxy_get_version = (PFN_wl_proxy_get_version) + _glfw_dlsym(_glfw.wl.client.handle, "wl_proxy_get_version"); + _glfw.wl.client.proxy_marshal_flags = (PFN_wl_proxy_marshal_flags) + _glfw_dlsym(_glfw.wl.client.handle, "wl_proxy_marshal_flags"); if (!_glfw.wl.client.display_flush || !_glfw.wl.client.display_cancel_read || diff --git a/src/wl_platform.h b/src/wl_platform.h index acb52685..a24943c9 100644 --- a/src/wl_platform.h +++ b/src/wl_platform.h @@ -70,6 +70,8 @@ typedef struct wl_proxy* (* PFN_wl_proxy_marshal_constructor)(struct wl_proxy*,u typedef struct wl_proxy* (* PFN_wl_proxy_marshal_constructor_versioned)(struct wl_proxy*,uint32_t,const struct wl_interface*,uint32_t,...); typedef void* (* PFN_wl_proxy_get_user_data)(struct wl_proxy*); typedef void (* PFN_wl_proxy_set_user_data)(struct wl_proxy*,void*); +typedef uint32_t (* PFN_wl_proxy_get_version)(struct wl_proxy*); +typedef struct wl_proxy* (* PFN_wl_proxy_marshal_flags)(struct wl_proxy*,uint32_t,const struct wl_interface*,uint32_t,uint32_t,...); #define wl_display_flush _glfw.wl.client.display_flush #define wl_display_cancel_read _glfw.wl.client.display_cancel_read #define wl_display_dispatch_pending _glfw.wl.client.display_dispatch_pending @@ -86,6 +88,8 @@ typedef void (* PFN_wl_proxy_set_user_data)(struct wl_proxy*,void*); #define wl_proxy_marshal_constructor_versioned _glfw.wl.client.proxy_marshal_constructor_versioned #define wl_proxy_get_user_data _glfw.wl.client.proxy_get_user_data #define wl_proxy_set_user_data _glfw.wl.client.proxy_set_user_data +#define wl_proxy_get_version _glfw.wl.client.proxy_get_version +#define wl_proxy_marshal_flags _glfw.wl.client.proxy_marshal_flags struct wl_shm; @@ -388,6 +392,8 @@ typedef struct _GLFWlibraryWayland PFN_wl_proxy_marshal_constructor_versioned proxy_marshal_constructor_versioned; PFN_wl_proxy_get_user_data proxy_get_user_data; PFN_wl_proxy_set_user_data proxy_set_user_data; + PFN_wl_proxy_get_version proxy_get_version; + PFN_wl_proxy_marshal_flags proxy_marshal_flags; } client; struct {