mirror of
https://github.com/Ryujinx/SDL.git
synced 2025-01-09 09:35:31 +00:00
gamecontroller: Backport 3.0 'type:' field to 2.0
This commit is contained in:
parent
61cd57d378
commit
757c984ddb
|
@ -73,7 +73,8 @@ typedef enum
|
||||||
SDL_CONTROLLER_TYPE_NVIDIA_SHIELD,
|
SDL_CONTROLLER_TYPE_NVIDIA_SHIELD,
|
||||||
SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_JOYCON_LEFT,
|
SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_JOYCON_LEFT,
|
||||||
SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_JOYCON_RIGHT,
|
SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_JOYCON_RIGHT,
|
||||||
SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_JOYCON_PAIR
|
SDL_CONTROLLER_TYPE_NINTENDO_SWITCH_JOYCON_PAIR,
|
||||||
|
SDL_CONTROLLER_TYPE_MAX
|
||||||
} SDL_GameControllerType;
|
} SDL_GameControllerType;
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
|
|
|
@ -45,6 +45,8 @@
|
||||||
|
|
||||||
#define SDL_CONTROLLER_CRC_FIELD "crc:"
|
#define SDL_CONTROLLER_CRC_FIELD "crc:"
|
||||||
#define SDL_CONTROLLER_CRC_FIELD_SIZE 4 /* hard-coded for speed */
|
#define SDL_CONTROLLER_CRC_FIELD_SIZE 4 /* hard-coded for speed */
|
||||||
|
#define SDL_CONTROLLER_TYPE_FIELD "type:"
|
||||||
|
#define SDL_CONTROLLER_TYPE_FIELD_SIZE SDL_strlen(SDL_CONTROLLER_TYPE_FIELD)
|
||||||
#define SDL_CONTROLLER_PLATFORM_FIELD "platform:"
|
#define SDL_CONTROLLER_PLATFORM_FIELD "platform:"
|
||||||
#define SDL_CONTROLLER_PLATFORM_FIELD_SIZE SDL_strlen(SDL_CONTROLLER_PLATFORM_FIELD)
|
#define SDL_CONTROLLER_PLATFORM_FIELD_SIZE SDL_strlen(SDL_CONTROLLER_PLATFORM_FIELD)
|
||||||
#define SDL_CONTROLLER_HINT_FIELD "hint:"
|
#define SDL_CONTROLLER_HINT_FIELD "hint:"
|
||||||
|
@ -133,6 +135,7 @@ struct _SDL_GameController
|
||||||
int ref_count _guarded;
|
int ref_count _guarded;
|
||||||
|
|
||||||
const char *name _guarded;
|
const char *name _guarded;
|
||||||
|
SDL_GameControllerType type _guarded;
|
||||||
ControllerMapping_t *mapping _guarded;
|
ControllerMapping_t *mapping _guarded;
|
||||||
int num_bindings _guarded;
|
int num_bindings _guarded;
|
||||||
SDL_ExtendedGameControllerBind *bindings _guarded;
|
SDL_ExtendedGameControllerBind *bindings _guarded;
|
||||||
|
@ -850,6 +853,47 @@ static ControllerMapping_t *SDL_PrivateGetControllerMappingForGUID(SDL_JoystickG
|
||||||
return mapping;
|
return mapping;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *map_StringForGameControllerType[] = {
|
||||||
|
"unknown",
|
||||||
|
"xbox360",
|
||||||
|
"xboxone",
|
||||||
|
"ps3",
|
||||||
|
"ps4",
|
||||||
|
"switchpro",
|
||||||
|
"virtual",
|
||||||
|
"ps5",
|
||||||
|
"amazonluna",
|
||||||
|
"googlestadia",
|
||||||
|
"nvidiashield",
|
||||||
|
"joyconleft",
|
||||||
|
"joyconright",
|
||||||
|
"joyconpair"
|
||||||
|
};
|
||||||
|
SDL_COMPILE_TIME_ASSERT(map_StringForGameControllerType, SDL_arraysize(map_StringForGameControllerType) == SDL_CONTROLLER_TYPE_MAX);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* convert a string to its enum equivalent
|
||||||
|
*/
|
||||||
|
static SDL_GameControllerType SDL_GetGameControllerTypeFromString(const char *str)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (!str || str[0] == '\0') {
|
||||||
|
return SDL_CONTROLLER_TYPE_UNKNOWN;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (*str == '+' || *str == '-') {
|
||||||
|
++str;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (i = 0; i < SDL_arraysize(map_StringForGameControllerType); ++i) {
|
||||||
|
if (SDL_strcasecmp(str, map_StringForGameControllerType[i]) == 0) {
|
||||||
|
return (SDL_GameControllerType)i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return SDL_CONTROLLER_TYPE_UNKNOWN;
|
||||||
|
}
|
||||||
|
|
||||||
static const char *map_StringForControllerAxis[] = {
|
static const char *map_StringForControllerAxis[] = {
|
||||||
"leftx",
|
"leftx",
|
||||||
"lefty",
|
"lefty",
|
||||||
|
@ -1095,6 +1139,31 @@ static void SDL_PrivateGameControllerParseControllerConfigString(SDL_GameControl
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void SDL_UpdateGameControllerType(SDL_GameController *gamecontroller)
|
||||||
|
{
|
||||||
|
char *type_string, *comma;
|
||||||
|
|
||||||
|
SDL_AssertJoysticksLocked();
|
||||||
|
|
||||||
|
gamecontroller->type = SDL_CONTROLLER_TYPE_UNKNOWN;
|
||||||
|
|
||||||
|
type_string = SDL_strstr(gamecontroller->mapping->mapping, SDL_CONTROLLER_TYPE_FIELD);
|
||||||
|
if (type_string) {
|
||||||
|
type_string += SDL_CONTROLLER_TYPE_FIELD_SIZE;
|
||||||
|
comma = SDL_strchr(type_string, ',');
|
||||||
|
if (comma) {
|
||||||
|
*comma = '\0';
|
||||||
|
gamecontroller->type = SDL_GetGameControllerTypeFromString(type_string);
|
||||||
|
*comma = ',';
|
||||||
|
} else {
|
||||||
|
gamecontroller->type = SDL_GetGameControllerTypeFromString(type_string);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (gamecontroller->type == SDL_CONTROLLER_TYPE_UNKNOWN) {
|
||||||
|
gamecontroller->type = SDL_GetJoystickGameControllerTypeFromGUID(SDL_JoystickGetGUID(gamecontroller->joystick), SDL_JoystickName(gamecontroller->joystick));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Make a new button mapping struct
|
* Make a new button mapping struct
|
||||||
*/
|
*/
|
||||||
|
@ -1113,6 +1182,8 @@ static void SDL_PrivateLoadButtonMapping(SDL_GameController *gamecontroller, Con
|
||||||
|
|
||||||
SDL_PrivateGameControllerParseControllerConfigString(gamecontroller, pControllerMapping->mapping);
|
SDL_PrivateGameControllerParseControllerConfigString(gamecontroller, pControllerMapping->mapping);
|
||||||
|
|
||||||
|
SDL_UpdateGameControllerType(gamecontroller);
|
||||||
|
|
||||||
/* Set the zero point for triggers */
|
/* Set the zero point for triggers */
|
||||||
for (i = 0; i < gamecontroller->num_bindings; ++i) {
|
for (i = 0; i < gamecontroller->num_bindings; ++i) {
|
||||||
SDL_ExtendedGameControllerBind *binding = &gamecontroller->bindings[i];
|
SDL_ExtendedGameControllerBind *binding = &gamecontroller->bindings[i];
|
||||||
|
@ -1976,7 +2047,26 @@ const char *SDL_GameControllerPathForIndex(int joystick_index)
|
||||||
*/
|
*/
|
||||||
SDL_GameControllerType SDL_GameControllerTypeForIndex(int joystick_index)
|
SDL_GameControllerType SDL_GameControllerTypeForIndex(int joystick_index)
|
||||||
{
|
{
|
||||||
return SDL_GetJoystickGameControllerTypeFromGUID(SDL_JoystickGetDeviceGUID(joystick_index), SDL_JoystickNameForIndex(joystick_index));
|
SDL_JoystickGUID joystick_guid = SDL_JoystickGetDeviceGUID(joystick_index);
|
||||||
|
const char *mapping = SDL_GameControllerMappingForGUID(joystick_guid);
|
||||||
|
char *type_string, *comma;
|
||||||
|
SDL_GameControllerType type;
|
||||||
|
if (mapping) {
|
||||||
|
type_string = SDL_strstr(mapping, SDL_CONTROLLER_TYPE_FIELD);
|
||||||
|
if (type_string) {
|
||||||
|
type_string += SDL_CONTROLLER_TYPE_FIELD_SIZE;
|
||||||
|
comma = SDL_strchr(type_string, ',');
|
||||||
|
if (comma) {
|
||||||
|
*comma = '\0';
|
||||||
|
type = SDL_GetGameControllerTypeFromString(type_string);
|
||||||
|
*comma = ',';
|
||||||
|
} else {
|
||||||
|
type = SDL_GetGameControllerTypeFromString(type_string);
|
||||||
|
}
|
||||||
|
return type;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return SDL_GetJoystickGameControllerTypeFromGUID(joystick_guid, SDL_JoystickNameForIndex(joystick_index));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -2675,6 +2765,9 @@ SDL_GameControllerType SDL_GameControllerGetType(SDL_GameController *gamecontrol
|
||||||
if (!joystick) {
|
if (!joystick) {
|
||||||
return SDL_CONTROLLER_TYPE_UNKNOWN;
|
return SDL_CONTROLLER_TYPE_UNKNOWN;
|
||||||
}
|
}
|
||||||
|
if (gamecontroller->type != SDL_CONTROLLER_TYPE_UNKNOWN) {
|
||||||
|
return gamecontroller->type;
|
||||||
|
}
|
||||||
return SDL_GetJoystickGameControllerTypeFromGUID(SDL_JoystickGetGUID(joystick), SDL_JoystickName(joystick));
|
return SDL_GetJoystickGameControllerTypeFromGUID(SDL_JoystickGetGUID(joystick), SDL_JoystickName(joystick));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue