From 5a079a2d114f96d4847d1ee305d5b7c16eeec50e Mon Sep 17 00:00:00 2001 From: 3gg <3gg@shellblade.net> Date: Sat, 27 Dec 2025 12:03:39 -0800 Subject: Initial commit --- contrib/SDL-3.2.8/src/video/x11/SDL_x11dyn.h | 113 +++++++++++++++++++++++++++ 1 file changed, 113 insertions(+) create mode 100644 contrib/SDL-3.2.8/src/video/x11/SDL_x11dyn.h (limited to 'contrib/SDL-3.2.8/src/video/x11/SDL_x11dyn.h') diff --git a/contrib/SDL-3.2.8/src/video/x11/SDL_x11dyn.h b/contrib/SDL-3.2.8/src/video/x11/SDL_x11dyn.h new file mode 100644 index 0000000..e9831fc --- /dev/null +++ b/contrib/SDL-3.2.8/src/video/x11/SDL_x11dyn.h @@ -0,0 +1,113 @@ +/* + Simple DirectMedia Layer + Copyright (C) 1997-2025 Sam Lantinga + + This software is provided 'as-is', without any express or implied + warranty. In no event will the authors be held liable for any damages + arising from the use of this software. + + Permission is granted to anyone to use this software for any purpose, + including commercial applications, and to alter it and redistribute it + freely, subject to the following restrictions: + + 1. The origin of this software must not be misrepresented; you must not + claim that you wrote the original software. If you use this software + in a product, an acknowledgment in the product documentation would be + appreciated but is not required. + 2. Altered source versions must be plainly marked as such, and must not be + misrepresented as being the original software. + 3. This notice may not be removed or altered from any source distribution. +*/ +#include "SDL_internal.h" + +#ifndef SDL_x11dyn_h_ +#define SDL_x11dyn_h_ + +#include +#include +#include +#include + +#ifdef SDL_VIDEO_DRIVER_X11_HAS_XKBLOOKUPKEYSYM +#include +#endif + +// Apparently some X11 systems can't include this multiple times... +#ifndef SDL_INCLUDED_XLIBINT_H +#define SDL_INCLUDED_XLIBINT_H 1 +#include +#endif + +#include +#include + +#ifndef NO_SHARED_MEMORY +#include +#include +#include +#endif + +#ifdef SDL_VIDEO_DRIVER_X11_XCURSOR +#include +#endif +#ifdef SDL_VIDEO_DRIVER_X11_XDBE +#include +#endif +#if defined(SDL_VIDEO_DRIVER_X11_XINPUT2) || defined(SDL_VIDEO_DRIVER_X11_XFIXES) +#include +#endif +#ifdef SDL_VIDEO_DRIVER_X11_XFIXES +#include +#endif +#ifdef SDL_VIDEO_DRIVER_X11_XSYNC +#include +#endif +#ifdef SDL_VIDEO_DRIVER_X11_XRANDR +#include +#endif +#ifdef SDL_VIDEO_DRIVER_X11_XSCRNSAVER +#include +#endif +#ifdef SDL_VIDEO_DRIVER_X11_XSHAPE +#include +#endif + +#ifdef __cplusplus +extern "C" { +#endif + +// evil function signatures... +typedef Bool (*SDL_X11_XESetWireToEventRetType)(Display *, XEvent *, xEvent *); +typedef int (*SDL_X11_XSynchronizeRetType)(Display *); +typedef Status (*SDL_X11_XESetEventToWireRetType)(Display *, XEvent *, xEvent *); + +extern bool SDL_X11_LoadSymbols(void); +extern void SDL_X11_UnloadSymbols(void); + +// Declare all the function pointers and wrappers... +#define SDL_X11_SYM(rc, fn, params, args, ret) \ + typedef rc(*SDL_DYNX11FN_##fn) params; \ + extern SDL_DYNX11FN_##fn X11_##fn; +#include "SDL_x11sym.h" + +// Annoying varargs entry point... +#ifdef X_HAVE_UTF8_STRING +typedef XIC (*SDL_DYNX11FN_XCreateIC)(XIM, ...); +typedef char *(*SDL_DYNX11FN_XGetICValues)(XIC, ...); +typedef char *(*SDL_DYNX11FN_XSetICValues)(XIC, ...); +typedef XVaNestedList (*SDL_DYNX11FN_XVaCreateNestedList)(int, ...); +extern SDL_DYNX11FN_XCreateIC X11_XCreateIC; +extern SDL_DYNX11FN_XGetICValues X11_XGetICValues; +extern SDL_DYNX11FN_XSetICValues X11_XSetICValues; +extern SDL_DYNX11FN_XVaCreateNestedList X11_XVaCreateNestedList; +#endif + +/* These SDL_X11_HAVE_* flags are here whether you have dynamic X11 or not. */ +#define SDL_X11_MODULE(modname) extern int SDL_X11_HAVE_##modname; +#include "SDL_x11sym.h" + +#ifdef __cplusplus +} +#endif + +#endif // !defined SDL_x11dyn_h_ -- cgit v1.2.3