From 306695dd258c3bbf5c0a00bc2b29ae7ac5e88181 Mon Sep 17 00:00:00 2001 From: Florian Weber Date: Sun, 26 Apr 2015 14:31:31 +0200 Subject: [PATCH] fix typos and improve operator== --- src/json.hpp | 68 ++++++++++++++++------------------------------- src/json.hpp.re2c | 68 ++++++++++++++++------------------------------- 2 files changed, 46 insertions(+), 90 deletions(-) diff --git a/src/json.hpp b/src/json.hpp index 4eb073b1..67bfcea6 100644 --- a/src/json.hpp +++ b/src/json.hpp @@ -1868,74 +1868,52 @@ class basic_json */ friend bool operator==(const_reference lhs, const_reference rhs) noexcept { - switch (lhs.type()) + const auto lhs_type = lhs.type(); + const auto rhs_type = rhs.type(); + if (lhs_type == rhs_type) { - case (value_t::array): + switch (lhs_type) { - if (rhs.type() == value_t::array) + case (value_t::array): { return *lhs.m_value.array == *rhs.m_value.array; } - break; - } - case (value_t::object): - { - if (rhs.type() == value_t::object) + case (value_t::object): { return *lhs.m_value.object == *rhs.m_value.object; } - break; - } - case (value_t::null): - { - if (rhs.type() == value_t::null) + case (value_t::null): { return true; } - break; - } - case (value_t::string): - { - if (rhs.type() == value_t::string) + case (value_t::string): { return *lhs.m_value.string == *rhs.m_value.string; } - break; - } - case (value_t::boolean): - { - if (rhs.type() == value_t::boolean) + case (value_t::boolean): { return lhs.m_value.boolean == rhs.m_value.boolean; } - break; - } - case (value_t::number_integer): - { - if (rhs.type() == value_t::number_integer) + case (value_t::number_integer): { return lhs.m_value.number_integer == rhs.m_value.number_integer; } - if (rhs.type() == value_t::number_float) - { - return lhs.m_value.number_integer == static_cast(rhs.m_value.number_float); - } - break; - } - case (value_t::number_float): - { - if (rhs.type() == value_t::number_integer) - { - return approx(lhs.m_value.number_float, static_cast(rhs.m_value.number_integer)); - } - if (rhs.type() == value_t::number_float) + case (value_t::number_float): { return approx(lhs.m_value.number_float, rhs.m_value.number_float); } - break; } } - + else if (lhs_type == value_t::number_integer and rhs_type == value_t::number_float) + { + return lhs.m_value.number_integer == + static_cast(rhs.m_value.number_float); + } + else if (lhs_type == value_t::number_float and rhs_type == value_t::number_integer) + { + return approx(lhs.m_value.number_float, + static_cast(rhs.m_value.number_integer)); + } return false; } @@ -1959,9 +1937,9 @@ class basic_json { case (value_t::array): { - return *lhs.m_value_array < *rhs.m_value.array; + return *lhs.m_value.array < *rhs.m_value.array; } - case (value_t::onject): + case (value_t::object): { return *lhs.m_value.object < *rhs.m_value.object; } diff --git a/src/json.hpp.re2c b/src/json.hpp.re2c index a66f109d..16139cae 100644 --- a/src/json.hpp.re2c +++ b/src/json.hpp.re2c @@ -1868,74 +1868,52 @@ class basic_json */ friend bool operator==(const_reference lhs, const_reference rhs) noexcept { - switch (lhs.type()) + const auto lhs_type = lhs.type(); + const auto rhs_type = rhs.type(); + if (lhs_type == rhs_type) { - case (value_t::array): + switch (lhs_type) { - if (rhs.type() == value_t::array) + case (value_t::array): { return *lhs.m_value.array == *rhs.m_value.array; } - break; - } - case (value_t::object): - { - if (rhs.type() == value_t::object) + case (value_t::object): { return *lhs.m_value.object == *rhs.m_value.object; } - break; - } - case (value_t::null): - { - if (rhs.type() == value_t::null) + case (value_t::null): { return true; } - break; - } - case (value_t::string): - { - if (rhs.type() == value_t::string) + case (value_t::string): { return *lhs.m_value.string == *rhs.m_value.string; } - break; - } - case (value_t::boolean): - { - if (rhs.type() == value_t::boolean) + case (value_t::boolean): { return lhs.m_value.boolean == rhs.m_value.boolean; } - break; - } - case (value_t::number_integer): - { - if (rhs.type() == value_t::number_integer) + case (value_t::number_integer): { return lhs.m_value.number_integer == rhs.m_value.number_integer; } - if (rhs.type() == value_t::number_float) - { - return lhs.m_value.number_integer == static_cast(rhs.m_value.number_float); - } - break; - } - case (value_t::number_float): - { - if (rhs.type() == value_t::number_integer) - { - return approx(lhs.m_value.number_float, static_cast(rhs.m_value.number_integer)); - } - if (rhs.type() == value_t::number_float) + case (value_t::number_float): { return approx(lhs.m_value.number_float, rhs.m_value.number_float); } - break; } } - + else if (lhs_type == value_t::number_integer and rhs_type == value_t::number_float) + { + return lhs.m_value.number_integer == + static_cast(rhs.m_value.number_float); + } + else if (lhs_type == value_t::number_float and rhs_type == value_t::number_integer) + { + return approx(lhs.m_value.number_float, + static_cast(rhs.m_value.number_integer)); + } return false; } @@ -1959,9 +1937,9 @@ class basic_json { case (value_t::array): { - return *lhs.m_value_array < *rhs.m_value.array; + return *lhs.m_value.array < *rhs.m_value.array; } - case (value_t::onject): + case (value_t::object): { return *lhs.m_value.object < *rhs.m_value.object; }