Merge pull request #2233 from nlohmann/issue2175

Add specialization of get_to
This commit is contained in:
Niels Lohmann 2020-07-06 07:58:52 +02:00 committed by GitHub
commit b04dc055b2
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 41 additions and 13 deletions

View file

@ -3020,6 +3020,18 @@ class basic_json
return v; return v;
} }
// specialization to allow to call get_to with a basic_json value
// see https://github.com/nlohmann/json/issues/2175
template<typename ValueType,
detail::enable_if_t <
detail::is_basic_json<ValueType>::value,
int> = 0>
ValueType & get_to(ValueType& v) const
{
v = *this;
return v;
}
template < template <
typename T, std::size_t N, typename T, std::size_t N,
typename Array = T (&)[N], typename Array = T (&)[N],

View file

@ -18950,6 +18950,18 @@ class basic_json
return v; return v;
} }
// specialization to allow to call get_to with a basic_json value
// see https://github.com/nlohmann/json/issues/2175
template<typename ValueType,
detail::enable_if_t <
detail::is_basic_json<ValueType>::value,
int> = 0>
ValueType & get_to(ValueType& v) const
{
v = *this;
return v;
}
template < template <
typename T, std::size_t N, typename T, std::size_t N,
typename Array = T (&)[N], typename Array = T (&)[N],

View file

@ -32,8 +32,6 @@ SOFTWARE.
#include <nlohmann/json.hpp> #include <nlohmann/json.hpp>
using nlohmann::json; using nlohmann::json;
#include <utility>
namespace persons namespace persons
{ {
class person_with_private_data class person_with_private_data
@ -41,20 +39,22 @@ class person_with_private_data
private: private:
std::string name; std::string name;
int age = 0; int age = 0;
json metadata;
public: public:
bool operator==(const person_with_private_data& rhs) const bool operator==(const person_with_private_data& rhs) const
{ {
return std::tie(name, age) == std::tie(rhs.name, rhs.age); return name == rhs.name && age == rhs.age && metadata == rhs.metadata;
} }
person_with_private_data() = default; person_with_private_data() = default;
person_with_private_data(std::string name, int age) person_with_private_data(std::string name, int age, json metadata)
: name(std::move(name)) : name(std::move(name))
, age(age) , age(age)
, metadata(std::move(metadata))
{} {}
NLOHMANN_DEFINE_TYPE_INTRUSIVE(person_with_private_data, age, name); NLOHMANN_DEFINE_TYPE_INTRUSIVE(person_with_private_data, age, name, metadata);
}; };
class person_without_private_data_1 class person_without_private_data_1
@ -62,19 +62,21 @@ class person_without_private_data_1
public: public:
std::string name; std::string name;
int age = 0; int age = 0;
json metadata;
bool operator==(const person_without_private_data_1& rhs) const bool operator==(const person_without_private_data_1& rhs) const
{ {
return std::tie(name, age) == std::tie(rhs.name, rhs.age); return name == rhs.name && age == rhs.age && metadata == rhs.metadata;
} }
person_without_private_data_1() = default; person_without_private_data_1() = default;
person_without_private_data_1(std::string name, int age) person_without_private_data_1(std::string name, int age, json metadata)
: name(std::move(name)) : name(std::move(name))
, age(age) , age(age)
, metadata(std::move(metadata))
{} {}
NLOHMANN_DEFINE_TYPE_INTRUSIVE(person_without_private_data_1, age, name); NLOHMANN_DEFINE_TYPE_INTRUSIVE(person_without_private_data_1, age, name, metadata);
}; };
class person_without_private_data_2 class person_without_private_data_2
@ -82,20 +84,22 @@ class person_without_private_data_2
public: public:
std::string name; std::string name;
int age = 0; int age = 0;
json metadata;
bool operator==(const person_without_private_data_2& rhs) const bool operator==(const person_without_private_data_2& rhs) const
{ {
return std::tie(name, age) == std::tie(rhs.name, rhs.age); return name == rhs.name && age == rhs.age && metadata == rhs.metadata;
} }
person_without_private_data_2() = default; person_without_private_data_2() = default;
person_without_private_data_2(std::string name, int age) person_without_private_data_2(std::string name, int age, json metadata)
: name(std::move(name)) : name(std::move(name))
, age(age) , age(age)
, metadata(std::move(metadata))
{} {}
}; };
NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE(person_without_private_data_2, age, name); NLOHMANN_DEFINE_TYPE_NON_INTRUSIVE(person_without_private_data_2, age, name, metadata);
} // namespace persons } // namespace persons
TEST_CASE_TEMPLATE("Serialization/deserialization via NLOHMANN_DEFINE_TYPE_INTRUSIVE", T, TEST_CASE_TEMPLATE("Serialization/deserialization via NLOHMANN_DEFINE_TYPE_INTRUSIVE", T,
@ -106,8 +110,8 @@ TEST_CASE_TEMPLATE("Serialization/deserialization via NLOHMANN_DEFINE_TYPE_INTRU
SECTION("person") SECTION("person")
{ {
// serialization // serialization
T p1("Erik", 1); T p1("Erik", 1, {{"haircuts", 2}});
CHECK(json(p1).dump() == "{\"age\":1,\"name\":\"Erik\"}"); CHECK(json(p1).dump() == "{\"age\":1,\"metadata\":{\"haircuts\":2},\"name\":\"Erik\"}");
// deserialization // deserialization
T p2 = json(p1); T p2 = json(p1);