diff options
| author | untodesu <kirill@untode.su> | 2025-12-11 15:14:26 +0500 |
|---|---|---|
| committer | untodesu <kirill@untode.su> | 2025-12-11 15:14:26 +0500 |
| commit | f40d09cb8f712e87691af4912f3630d92d692779 (patch) | |
| tree | 7ac3a4168ff722689372fd489c6f94d0a2546e8f /src/core/config/number.hh | |
| parent | 8bcbd2729388edc63c82d77d314b583af1447c49 (diff) | |
| download | voxelius-f40d09cb8f712e87691af4912f3630d92d692779.tar.bz2 voxelius-f40d09cb8f712e87691af4912f3630d92d692779.zip | |
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
Diffstat (limited to 'src/core/config/number.hh')
| -rw-r--r-- | src/core/config/number.hh | 130 |
1 files changed, 130 insertions, 0 deletions
diff --git a/src/core/config/number.hh b/src/core/config/number.hh new file mode 100644 index 0000000..4f185e1 --- /dev/null +++ b/src/core/config/number.hh @@ -0,0 +1,130 @@ +#pragma once + +#include "core/config/ivalue.hh" + +#include "core/math/concepts.hh" + +namespace config +{ +template<math::arithmetic T> +class Number : public IValue { +public: + explicit Number(T default_value = T(0)); + explicit Number(T default_value, T min_value, T max_value); + virtual ~Number(void) = default; + + virtual void set(std::string_view value) override; + virtual std::string_view get(void) const override; + + T get_value(void) const; + void set_value(T value); + + T get_min_value(void) const; + T get_max_value(void) const; + void set_limits(T min_value, T max_value); + +private: + T m_value; + T m_min_value; + T m_max_value; + std::string m_string; +}; +} // namespace config + +namespace config +{ +class Int final : public Number<int> { +public: + using Number<int>::Number; +}; + +class Float final : public Number<float> { +public: + using Number<float>::Number; +}; + +class Unsigned final : public Number<unsigned int> { +public: + using Number<unsigned int>::Number; +}; + +class Unsigned64 final : public Number<std::uint64_t> { +public: + using Number<std::uint64_t>::Number; +}; + +class SizeType final : public Number<std::size_t> { +public: + using Number<std::size_t>::Number; +}; +} // namespace config + +template<math::arithmetic T> +inline config::Number<T>::Number(T default_value) +{ + m_value = default_value; + m_min_value = std::numeric_limits<T>::lowest(); + m_max_value = std::numeric_limits<T>::max(); + m_string = std::to_string(default_value); +} + +template<math::arithmetic T> +inline config::Number<T>::Number(T default_value, T min_value, T max_value) +{ + m_value = default_value; + m_min_value = min_value; + m_max_value = max_value; + m_string = std::to_string(default_value); +} + +template<math::arithmetic T> +inline void config::Number<T>::set(std::string_view value) +{ + T parsed_value; + auto result = std::from_chars(value.data(), value.data() + value.size(), parsed_value); + + if(result.ec == std::errc()) { + m_value = std::clamp(parsed_value, m_min_value, m_max_value); + m_string = std::to_string(m_value); + } +} + +template<math::arithmetic T> +inline std::string_view config::Number<T>::get(void) const +{ + return m_string; +} + +template<math::arithmetic T> +inline T config::Number<T>::get_value(void) const +{ + return m_value; +} + +template<math::arithmetic T> +inline void config::Number<T>::set_value(T value) +{ + m_value = std::clamp(value, m_min_value, m_max_value); + m_string = std::to_string(m_value); +} + +template<math::arithmetic T> +inline T config::Number<T>::get_min_value(void) const +{ + return m_min_value; +} + +template<math::arithmetic T> +inline T config::Number<T>::get_max_value(void) const +{ + return m_max_value; +} + +template<math::arithmetic T> +inline void config::Number<T>::set_limits(T min_value, T max_value) +{ + m_min_value = min_value; + m_max_value = max_value; + m_value = std::clamp(m_value, m_min_value, m_max_value); + m_string = std::to_string(m_value); +} |
