From f40d09cb8f712e87691af4912f3630d92d692779 Mon Sep 17 00:00:00 2001 From: untodesu Date: Thu, 11 Dec 2025 15:14:26 +0500 Subject: Shuffle stuff around - Use the new and improved hierarchy I figured out when making Prospero chat - Re-add NSIS scripts, again from Prospero - Update most build and utility scripts with their most recent versions --- src/game/client/config/gamepad_axis.hh | 38 ++++++++++++++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 src/game/client/config/gamepad_axis.hh (limited to 'src/game/client/config/gamepad_axis.hh') diff --git a/src/game/client/config/gamepad_axis.hh b/src/game/client/config/gamepad_axis.hh new file mode 100644 index 0000000..9392a35 --- /dev/null +++ b/src/game/client/config/gamepad_axis.hh @@ -0,0 +1,38 @@ +#pragma once + +#include "core/config/ivalue.hh" + +struct GLFWgamepadstate; + +namespace config +{ +class GamepadAxis final : public IValue { +public: + explicit GamepadAxis(void); + explicit GamepadAxis(int axis, bool inverted); + virtual ~GamepadAxis(void) = default; + + virtual std::string_view get(void) const override; + virtual void set(std::string_view value) override; + + int get_axis(void) const; + void set_axis(int axis); + + bool is_inverted(void) const; + void set_inverted(bool inverted); + + float get_value(const GLFWgamepadstate& state, float deadzone = 0.0f) const; + + // Conventional get/set methods implemented by + // this configuration value actually contain the + // inversion flag. Since we're updating that flag + // in the UI by means of a separate checkbox, we only need the name here + std::string_view get_name(void) const; + +private: + bool m_inverted; + int m_gamepad_axis; + std::string m_full_string; + std::string_view m_name; +}; +} // namespace config -- cgit