mirror of
https://github.com/Relintai/sdl2_frt.git
synced 2025-01-12 05:41:10 +01:00
wayland: libdecor support for GetWindowWMInfo
This commit is contained in:
parent
46919b1e8e
commit
93976ade3b
@ -138,6 +138,7 @@ void SDL_WAYLAND_UnloadSymbols(void);
|
|||||||
#define libdecor_frame_set_visibility (*WAYLAND_libdecor_frame_set_visibility)
|
#define libdecor_frame_set_visibility (*WAYLAND_libdecor_frame_set_visibility)
|
||||||
#define libdecor_frame_is_visible (*WAYLAND_libdecor_frame_is_visible)
|
#define libdecor_frame_is_visible (*WAYLAND_libdecor_frame_is_visible)
|
||||||
#define libdecor_frame_is_floating (*WAYLAND_libdecor_frame_is_floating)
|
#define libdecor_frame_is_floating (*WAYLAND_libdecor_frame_is_floating)
|
||||||
|
#define libdecor_frame_get_xdg_surface (*WAYLAND_libdecor_frame_get_xdg_surface)
|
||||||
#define libdecor_frame_map (*WAYLAND_libdecor_frame_map)
|
#define libdecor_frame_map (*WAYLAND_libdecor_frame_map)
|
||||||
#define libdecor_state_new (*WAYLAND_libdecor_state_new)
|
#define libdecor_state_new (*WAYLAND_libdecor_state_new)
|
||||||
#define libdecor_state_free (*WAYLAND_libdecor_state_free)
|
#define libdecor_state_free (*WAYLAND_libdecor_state_free)
|
||||||
|
@ -179,6 +179,7 @@ SDL_WAYLAND_SYM(bool, libdecor_frame_has_capability, (struct libdecor_frame *, \
|
|||||||
SDL_WAYLAND_SYM(void, libdecor_frame_set_visibility, (struct libdecor_frame *, bool))
|
SDL_WAYLAND_SYM(void, libdecor_frame_set_visibility, (struct libdecor_frame *, bool))
|
||||||
SDL_WAYLAND_SYM(bool, libdecor_frame_is_visible, (struct libdecor_frame *))
|
SDL_WAYLAND_SYM(bool, libdecor_frame_is_visible, (struct libdecor_frame *))
|
||||||
SDL_WAYLAND_SYM(bool, libdecor_frame_is_floating, (struct libdecor_frame *))
|
SDL_WAYLAND_SYM(bool, libdecor_frame_is_floating, (struct libdecor_frame *))
|
||||||
|
SDL_WAYLAND_SYM(struct xdg_surface *, libdecor_frame_get_xdg_surface, (struct libdecor_frame *))
|
||||||
SDL_WAYLAND_SYM(void, libdecor_frame_map, (struct libdecor_frame *))
|
SDL_WAYLAND_SYM(void, libdecor_frame_map, (struct libdecor_frame *))
|
||||||
SDL_WAYLAND_SYM(struct libdecor_state *, libdecor_state_new, (int, int))
|
SDL_WAYLAND_SYM(struct libdecor_state *, libdecor_state_new, (int, int))
|
||||||
SDL_WAYLAND_SYM(void, libdecor_state_free, (struct libdecor_state *))
|
SDL_WAYLAND_SYM(void, libdecor_state_free, (struct libdecor_state *))
|
||||||
|
@ -536,6 +536,7 @@ static const struct wl_surface_listener surface_listener = {
|
|||||||
SDL_bool
|
SDL_bool
|
||||||
Wayland_GetWindowWMInfo(_THIS, SDL_Window * window, SDL_SysWMinfo * info)
|
Wayland_GetWindowWMInfo(_THIS, SDL_Window * window, SDL_SysWMinfo * info)
|
||||||
{
|
{
|
||||||
|
SDL_VideoData *viddata = (SDL_VideoData *) _this->driverdata;
|
||||||
SDL_WindowData *data = (SDL_WindowData *) window->driverdata;
|
SDL_WindowData *data = (SDL_WindowData *) window->driverdata;
|
||||||
const Uint32 version = SDL_VERSIONNUM((Uint32)info->version.major,
|
const Uint32 version = SDL_VERSIONNUM((Uint32)info->version.major,
|
||||||
(Uint32)info->version.minor,
|
(Uint32)info->version.minor,
|
||||||
@ -564,7 +565,16 @@ Wayland_GetWindowWMInfo(_THIS, SDL_Window * window, SDL_SysWMinfo * info)
|
|||||||
}
|
}
|
||||||
|
|
||||||
info->info.wl.shell_surface = NULL;
|
info->info.wl.shell_surface = NULL;
|
||||||
|
#ifdef HAVE_LIBDECOR_H
|
||||||
|
if (viddata->shell.libdecor && data->shell_surface.libdecor.frame != NULL) {
|
||||||
|
info->info.wl.xdg_surface = libdecor_frame_get_xdg_surface(data->shell_surface.libdecor.frame);
|
||||||
|
} else
|
||||||
|
#endif
|
||||||
|
if (viddata->shell.xdg && data->shell_surface.xdg.surface != NULL) {
|
||||||
info->info.wl.xdg_surface = data->shell_surface.xdg.surface;
|
info->info.wl.xdg_surface = data->shell_surface.xdg.surface;
|
||||||
|
} else {
|
||||||
|
info->info.wl.xdg_surface = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
info->subsystem = SDL_SYSWM_WAYLAND;
|
info->subsystem = SDL_SYSWM_WAYLAND;
|
||||||
|
Loading…
Reference in New Issue
Block a user