From d731ad769d510ef9cd66f44dd2ebf7f67e21963c Mon Sep 17 00:00:00 2001 From: Frank Praznik Date: Fri, 15 Jul 2022 10:44:38 -0400 Subject: [PATCH] wayland: Fix include order when building with libdecor The libdecor header internally includes wayland-client.h, which pulls in the wayland-client-protocol.h file from the system include path and overrides the local one generated from the included Wayland protocol spec files. Move the Wayland protocol header inclusion above the libdecor header inclusion to ensure that the locally generated protocol header is used instead. --- src/video/wayland/SDL_waylanddyn.h | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/src/video/wayland/SDL_waylanddyn.h b/src/video/wayland/SDL_waylanddyn.h index 43a3372d6..1346e9814 100644 --- a/src/video/wayland/SDL_waylanddyn.h +++ b/src/video/wayland/SDL_waylanddyn.h @@ -119,6 +119,13 @@ void SDL_WAYLAND_UnloadSymbols(void); #define wl_data_source_interface (*WAYLAND_wl_data_source_interface) #define wl_data_device_manager_interface (*WAYLAND_wl_data_device_manager_interface) +/* + * These must be included before libdecor.h, otherwise the libdecor header + * pulls in the system Wayland protocol headers instead of ours. + */ +#include "wayland-client-protocol.h" +#include "wayland-egl.h" + #ifdef HAVE_LIBDECOR_H /* Must be included before our defines */ #include @@ -164,9 +171,6 @@ void SDL_WAYLAND_UnloadSymbols(void); #endif /* SDL_VIDEO_DRIVER_WAYLAND_DYNAMIC */ -#include "wayland-client-protocol.h" -#include "wayland-egl.h" - #endif /* SDL_waylanddyn_h_ */ /* vi: set ts=4 sw=4 expandtab: */