diff options
author | Stanislaw Halik <sthalik@misaki.pl> | 2018-10-25 18:01:20 +0200 |
---|---|---|
committer | Stanislaw Halik <sthalik@misaki.pl> | 2018-10-25 18:27:42 +0200 |
commit | c5db801886b22c3963689ee325ed7114ab94730d (patch) | |
tree | 55119b016fbebc2efe3d6b99bafafce1c78fa491 /options/value-traits.hpp | |
parent | 83867b413c449101bbe14615ff857a7785432ede (diff) |
options/value-traits: fix bool storage
Using int as `stored_type' for bool made Qt signals not
work. Evident when ticking the "asymmetric mapping"
checkboxes in the mapping window.
Remove some std::decay_t usage, there's no need for
either decay or remove_cvref.
In `value<t>::get()', `bundle::get_variant' of an
undefined key will fall back to `return def' so remove
the duplicate logic.
Diffstat (limited to 'options/value-traits.hpp')
-rw-r--r-- | options/value-traits.hpp | 32 |
1 files changed, 5 insertions, 27 deletions
diff --git a/options/value-traits.hpp b/options/value-traits.hpp index 31b6b534..f5b74f73 100644 --- a/options/value-traits.hpp +++ b/options/value-traits.hpp @@ -17,10 +17,9 @@ struct value_traits; template<typename t, typename u = t, typename Enable = void> struct default_value_traits { - using stored_type = std::decay_t<u>; - using value_type = std::decay_t<t>; - - using self = value_traits<t>; + using value_type = t; + using stored_type = u; + using self = value_traits<value_type>; static value_type value_with_default(const value_type& val, const value_type&) { @@ -91,33 +90,12 @@ struct value_traits<double> : default_value_traits<double> value_type x_, y_; - return I(std::round(std::modf(x, &x_) * K)) == I(std::round(std::modf(y, &y_) * K)) && - I(std::round(x_)) == I(std::round(y_)); + return I(std::modf(x, &x_) * K) == I(std::modf(y, &y_) * K) && + I(x_) == I(y_); } } }; -template<> struct value_traits<bool> : default_value_traits<bool, int> -{ - static stored_type storage_from_qvariant(const QVariant& x) - { - if (x.type() == QVariant::String) - return x.toBool(); - else - return !!x.toInt(); - } - - static QVariant qvariant_from_storage(const stored_type& val) - { - return QVariant::fromValue<int>(!!val); - } - - static value_type value_from_storage(const stored_type& x) - { - return !!x; - } -}; - template<> struct value_traits<float> : value_traits<float, double> { static constexpr inline value_type pass_value(const value_type& x) { return x; } |