123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109 |
- #include "rttr/detail/variant/variant_compare.h"
- #include "rttr/type.h"
- #include "rttr/variant.h"
- #include <cmath>
- #include <algorithm>
- namespace rttr
- {
- namespace detail
- {
- static RTTR_INLINE bool is_floating_point(const type& type)
- {
- return (type == type::get<float>() || type == type::get<double>());
- }
- static RTTR_INLINE bool almost_equal(double p1, double p2)
- {
- return (std::abs(p1 - p2) * 1000000000000. <= std::min(std::abs(p1), std::abs(p2)));
- }
- bool variant_compare_equal(const variant& lhs, const type& lhs_type, const variant& rhs, const type& rhs_type, bool& ok)
- {
- ok = true;
- if (is_floating_point(lhs_type) || is_floating_point(rhs_type))
- {
- return almost_equal(lhs.to_double(), rhs.to_double());
- }
- else
- {
- return (lhs.to_int64() == rhs.to_int64());
- }
- }
- bool variant_compare_less(const variant& lhs, const type& lhs_type, const variant& rhs, const type& rhs_type, bool& ok)
- {
- ok = true;
- if (lhs_type.is_arithmetic() && rhs_type.is_arithmetic())
- {
- if (is_floating_point(lhs_type) || is_floating_point(rhs_type))
- return (lhs.to_double() < rhs.to_double());
- else
- return (lhs.to_int64() < rhs.to_int64());
- }
- else
- {
- variant lhs_tmp;
- if (lhs.convert(rhs_type, lhs_tmp))
- return lhs_tmp.compare_less(rhs, ok);
- if (!lhs.is_nullptr() && rhs.is_nullptr())
- return false;
-
- bool ok1 = false;
- bool ok2 = false;
- auto ret = (lhs.to_string(&ok1) < rhs.to_string(&ok2));
- if (ok1 && ok2)
- {
- return ret;
- }
- else
- {
- ok = false;
- return false;
- }
- }
- }
- }
- }
|