mirror of
https://github.com/YGGverse/hlsdk-portable.git
synced 2025-01-11 15:38:12 +00:00
sdl loading refactoring
This commit is contained in:
parent
de8ce63282
commit
3574e73a91
@ -28,6 +28,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_SDL2
|
#ifdef USE_SDL2
|
||||||
|
#define ARRAYSIZE(p) ( sizeof(p) /sizeof(p[0]) )
|
||||||
#include <dlfcn.h>
|
#include <dlfcn.h>
|
||||||
#include <SDL2/SDL_mouse.h>
|
#include <SDL2/SDL_mouse.h>
|
||||||
#include <SDL2/SDL_gamecontroller.h>
|
#include <SDL2/SDL_gamecontroller.h>
|
||||||
@ -94,9 +95,23 @@ const char* safe_pfnSDL_GameControllerName(SDL_GameController* gamecontroller)
|
|||||||
return pfnSDL_GameControllerName(gamecontroller);
|
return pfnSDL_GameControllerName(gamecontroller);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
static void** const sdlFunctionPointers[] = {(void**)&pfnSDL_SetRelativeMouseMode, (void**)&pfnSDL_GetRelativeMouseState, (void**)&pfnSDL_NumJoysticks,
|
|
||||||
(void**)&pfnSDL_IsGameController, (void**)&pfnSDL_GameControllerOpen, (void**)&pfnSDL_GameControllerGetAxis,
|
struct SDLFunction
|
||||||
(void**)&pfnSDL_GameControllerGetButton, (void**)&pfnSDL_JoystickUpdate, (void**)&pfnSDL_GameControllerName};
|
{
|
||||||
|
void** ppfnFunc;
|
||||||
|
const char* name;
|
||||||
|
};
|
||||||
|
static SDLFunction sdlFunctions[] = {
|
||||||
|
{(void**)&pfnSDL_SetRelativeMouseMode, "SDL_SetRelativeMouseMode"},
|
||||||
|
{(void**)&pfnSDL_GetRelativeMouseState, "SDL_GetRelativeMouseState"},
|
||||||
|
{(void**)&pfnSDL_NumJoysticks, "SDL_NumJoysticks"},
|
||||||
|
{(void**)&pfnSDL_IsGameController, "SDL_IsGameController"},
|
||||||
|
{(void**)&pfnSDL_GameControllerOpen, "SDL_GameControllerOpen"},
|
||||||
|
{(void**)&pfnSDL_GameControllerGetAxis, "SDL_GameControllerGetAxis"},
|
||||||
|
{(void**)&pfnSDL_GameControllerGetButton, "SDL_GameControllerGetButton"},
|
||||||
|
{(void**)&pfnSDL_JoystickUpdate, "SDL_JoystickUpdate"},
|
||||||
|
{(void**)&pfnSDL_GameControllerName, "SDL_GameControllerName"}
|
||||||
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
@ -533,8 +548,8 @@ void GoldSourceInput::IN_Shutdown (void)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef USE_SDL2
|
#ifdef USE_SDL2
|
||||||
for (int j=0; j<sizeof(sdlFunctionPointers)/sizeof(sdlFunctionPointers[0]); ++j) {
|
for (int j=0; j<ARRAYSIZE(sdlFunctions); ++j) {
|
||||||
*(sdlFunctionPointers[j]) = NULL;
|
*(sdlFunctions[j].ppfnFunc) = NULL;
|
||||||
}
|
}
|
||||||
dlclose(sdl2Lib);
|
dlclose(sdl2Lib);
|
||||||
sdl2Lib = NULL;
|
sdl2Lib = NULL;
|
||||||
@ -1421,39 +1436,16 @@ void GoldSourceInput::IN_Init (void)
|
|||||||
|
|
||||||
#ifdef USE_SDL2
|
#ifdef USE_SDL2
|
||||||
#ifdef __APPLE__
|
#ifdef __APPLE__
|
||||||
#define SDL2_LIBNAME "libSDL2.dylib"
|
|
||||||
#define SDL2_FULL_LIBNAME "libsdl2-2.0.0.dylib"
|
#define SDL2_FULL_LIBNAME "libsdl2-2.0.0.dylib"
|
||||||
#else
|
#else
|
||||||
#define SDL2_LIBNAME "libSDL2.so"
|
|
||||||
#define SDL2_FULL_LIBNAME "libSDL2-2.0.so.0"
|
#define SDL2_FULL_LIBNAME "libSDL2-2.0.so.0"
|
||||||
#endif
|
#endif
|
||||||
sdl2Lib = dlopen(SDL2_LIBNAME, RTLD_NOW|RTLD_LOCAL);
|
|
||||||
if (!sdl2Lib) {
|
|
||||||
// libSDL2.so in goldsource is not really a symlink, but a regular file with symlink-like contents
|
|
||||||
FILE* libSDLfile = fopen(SDL2_LIBNAME, "r");
|
|
||||||
char buf[64];
|
|
||||||
if (libSDLfile) {
|
|
||||||
char* str = fgets(buf, sizeof(buf), libSDLfile);
|
|
||||||
if (str && *str) {
|
|
||||||
if (str[strlen(str)-1] == '\n') {
|
|
||||||
str[strlen(str)-1] = '\0';
|
|
||||||
}
|
|
||||||
sdl2Lib = dlopen(str, RTLD_NOW|RTLD_LOCAL);
|
|
||||||
}
|
|
||||||
fclose(libSDLfile);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!sdl2Lib) // try hardcoded name
|
|
||||||
sdl2Lib = dlopen(SDL2_FULL_LIBNAME, RTLD_NOW|RTLD_LOCAL);
|
sdl2Lib = dlopen(SDL2_FULL_LIBNAME, RTLD_NOW|RTLD_LOCAL);
|
||||||
if (sdl2Lib) {
|
if (sdl2Lib) {
|
||||||
const char* const sdlFuncNames[sizeof(sdlFunctionPointers)/sizeof(sdlFunctionPointers[0])] =
|
for (int j=0; j<ARRAYSIZE(sdlFunctions); ++j) {
|
||||||
{"SDL_SetRelativeMouseMode", "SDL_GetRelativeMouseState", "SDL_NumJoysticks",
|
*(sdlFunctions[j].ppfnFunc) = dlsym(sdl2Lib, sdlFunctions[j].name);
|
||||||
"SDL_IsGameController", "SDL_GameControllerOpen", "SDL_GameControllerGetAxis",
|
if (*sdlFunctions[j].ppfnFunc == NULL) {
|
||||||
"SDL_GameControllerGetButton", "SDL_JoystickUpdate", "SDL_GameControllerName"};
|
gEngfuncs.Con_Printf("Could not load SDL2 function %s: %s\n", sdlFunctions[j].name, dlerror());
|
||||||
for (int j=0; j<sizeof(sdlFunctionPointers)/sizeof(sdlFunctionPointers[0]); ++j) {
|
|
||||||
*(sdlFunctionPointers[j]) = dlsym(sdl2Lib, sdlFuncNames[j]);
|
|
||||||
if (*sdlFunctionPointers[j] == NULL) {
|
|
||||||
gEngfuncs.Con_Printf("Could not load SDL2 function %s: %s\n", sdlFuncNames[j], dlerror());
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user