mirror of
https://github.com/RetroDECK/Duckstation.git
synced 2025-01-17 22:25:37 +00:00
parent
2004de7170
commit
ef2796b780
|
@ -1,4 +1,5 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
#include "types.h"
|
||||||
#include <cstdarg>
|
#include <cstdarg>
|
||||||
#include <cstddef>
|
#include <cstddef>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
@ -24,7 +25,7 @@ bool WildcardMatch(const char* subject, const char* mask, bool case_sensitive =
|
||||||
std::size_t Strlcpy(char* dst, const char* src, std::size_t size);
|
std::size_t Strlcpy(char* dst, const char* src, std::size_t size);
|
||||||
|
|
||||||
/// Platform-independent strcasecmp
|
/// Platform-independent strcasecmp
|
||||||
inline int Strcasecmp(const char* s1, const char* s2)
|
static inline int Strcasecmp(const char* s1, const char* s2)
|
||||||
{
|
{
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
return _stricmp(s1, s2);
|
return _stricmp(s1, s2);
|
||||||
|
@ -35,7 +36,7 @@ inline int Strcasecmp(const char* s1, const char* s2)
|
||||||
|
|
||||||
/// Wrapper arond std::from_chars
|
/// Wrapper arond std::from_chars
|
||||||
template<typename T>
|
template<typename T>
|
||||||
std::optional<T> FromChars(const std::string_view str)
|
static inline std::optional<T> FromChars(std::string_view str)
|
||||||
{
|
{
|
||||||
T value;
|
T value;
|
||||||
|
|
||||||
|
@ -54,4 +55,10 @@ std::optional<T> FromChars(const std::string_view str)
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// starts_with from C++20
|
||||||
|
ALWAYS_INLINE static bool StartsWith(std::string_view str, const char* prefix)
|
||||||
|
{
|
||||||
|
return (str.compare(0, std::strlen(prefix), prefix) == 0);
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace StringUtil
|
} // namespace StringUtil
|
||||||
|
|
|
@ -214,7 +214,7 @@ bool CommonHostInterface::AddButtonToInputMap(const std::string& binding, const
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef WITH_SDL2
|
#ifdef WITH_SDL2
|
||||||
if (device == "Controller")
|
if (StringUtil::StartsWith(device, "Controller"))
|
||||||
{
|
{
|
||||||
const std::optional<int> controller_index = StringUtil::FromChars<int>(device.substr(10));
|
const std::optional<int> controller_index = StringUtil::FromChars<int>(device.substr(10));
|
||||||
if (!controller_index || *controller_index < 0)
|
if (!controller_index || *controller_index < 0)
|
||||||
|
@ -223,7 +223,7 @@ bool CommonHostInterface::AddButtonToInputMap(const std::string& binding, const
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (button.find_first_of("Button") == 0)
|
if (StringUtil::StartsWith(button, "Button"))
|
||||||
{
|
{
|
||||||
const std::optional<int> button_index = StringUtil::FromChars<int>(button.substr(6));
|
const std::optional<int> button_index = StringUtil::FromChars<int>(button.substr(6));
|
||||||
if (!button_index ||
|
if (!button_index ||
|
||||||
|
@ -235,7 +235,7 @@ bool CommonHostInterface::AddButtonToInputMap(const std::string& binding, const
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
else if (button.find_first_of("+Axis") == 0 || button.find_first_of("-Axis"))
|
else if (StringUtil::StartsWith(button, "+Axis") || StringUtil::StartsWith(button, "-Axis"))
|
||||||
{
|
{
|
||||||
const std::optional<int> axis_index = StringUtil::FromChars<int>(button.substr(5));
|
const std::optional<int> axis_index = StringUtil::FromChars<int>(button.substr(5));
|
||||||
const bool positive = (button[0] == '+');
|
const bool positive = (button[0] == '+');
|
||||||
|
@ -262,7 +262,7 @@ bool CommonHostInterface::AddAxisToInputMap(const std::string& binding, const st
|
||||||
const std::string_view& axis, InputAxisHandler handler)
|
const std::string_view& axis, InputAxisHandler handler)
|
||||||
{
|
{
|
||||||
#ifdef WITH_SDL2
|
#ifdef WITH_SDL2
|
||||||
if (device == "Controller")
|
if (StringUtil::StartsWith(device, "Controller"))
|
||||||
{
|
{
|
||||||
const std::optional<int> controller_index = StringUtil::FromChars<int>(device.substr(10));
|
const std::optional<int> controller_index = StringUtil::FromChars<int>(device.substr(10));
|
||||||
if (!controller_index || *controller_index < 0)
|
if (!controller_index || *controller_index < 0)
|
||||||
|
@ -271,7 +271,7 @@ bool CommonHostInterface::AddAxisToInputMap(const std::string& binding, const st
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (axis.find_first_of("Axis") == 0)
|
if (StringUtil::StartsWith(axis, "Axis"))
|
||||||
{
|
{
|
||||||
const std::optional<int> axis_index = StringUtil::FromChars<int>(axis.substr(4));
|
const std::optional<int> axis_index = StringUtil::FromChars<int>(axis.substr(4));
|
||||||
if (!axis_index ||
|
if (!axis_index ||
|
||||||
|
|
Loading…
Reference in a new issue