mirror of
https://github.com/nlohmann/json
synced 2024-11-15 00:31:05 +00:00
Improve json_ref implementation
This commit is contained in:
parent
fd7a9f6007
commit
42a9dc0bc3
@ -17,19 +17,14 @@ class json_ref
|
|||||||
|
|
||||||
json_ref(value_type&& value)
|
json_ref(value_type&& value)
|
||||||
: owned_value(std::move(value))
|
: owned_value(std::move(value))
|
||||||
, value_ref(&owned_value)
|
|
||||||
, is_rvalue(true)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
json_ref(const value_type& value)
|
json_ref(const value_type& value)
|
||||||
: value_ref(const_cast<value_type*>(&value))
|
: value_ref(&value)
|
||||||
, is_rvalue(false)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
json_ref(std::initializer_list<json_ref> init)
|
json_ref(std::initializer_list<json_ref> init)
|
||||||
: owned_value(init)
|
: owned_value(init)
|
||||||
, value_ref(&owned_value)
|
|
||||||
, is_rvalue(true)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
template <
|
template <
|
||||||
@ -37,8 +32,6 @@ class json_ref
|
|||||||
enable_if_t<std::is_constructible<value_type, Args...>::value, int> = 0 >
|
enable_if_t<std::is_constructible<value_type, Args...>::value, int> = 0 >
|
||||||
json_ref(Args && ... args)
|
json_ref(Args && ... args)
|
||||||
: owned_value(std::forward<Args>(args)...)
|
: owned_value(std::forward<Args>(args)...)
|
||||||
, value_ref(&owned_value)
|
|
||||||
, is_rvalue(true)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
// class should be movable only
|
// class should be movable only
|
||||||
@ -50,27 +43,26 @@ class json_ref
|
|||||||
|
|
||||||
value_type moved_or_copied() const
|
value_type moved_or_copied() const
|
||||||
{
|
{
|
||||||
if (is_rvalue)
|
if (value_ref == nullptr)
|
||||||
{
|
{
|
||||||
return std::move(*value_ref);
|
return std::move(owned_value);
|
||||||
}
|
}
|
||||||
return *value_ref;
|
return *value_ref;
|
||||||
}
|
}
|
||||||
|
|
||||||
value_type const& operator*() const
|
value_type const& operator*() const
|
||||||
{
|
{
|
||||||
return *static_cast<value_type const*>(value_ref);
|
return value_ref ? *value_ref : owned_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
value_type const* operator->() const
|
value_type const* operator->() const
|
||||||
{
|
{
|
||||||
return static_cast<value_type const*>(value_ref);
|
return &**this;
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
mutable value_type owned_value = nullptr;
|
mutable value_type owned_value = nullptr;
|
||||||
value_type* value_ref = nullptr;
|
value_type const* value_ref = nullptr;
|
||||||
const bool is_rvalue = true;
|
|
||||||
};
|
};
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
} // namespace nlohmann
|
} // namespace nlohmann
|
||||||
|
@ -12605,19 +12605,14 @@ class json_ref
|
|||||||
|
|
||||||
json_ref(value_type&& value)
|
json_ref(value_type&& value)
|
||||||
: owned_value(std::move(value))
|
: owned_value(std::move(value))
|
||||||
, value_ref(&owned_value)
|
|
||||||
, is_rvalue(true)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
json_ref(const value_type& value)
|
json_ref(const value_type& value)
|
||||||
: value_ref(const_cast<value_type*>(&value))
|
: value_ref(&value)
|
||||||
, is_rvalue(false)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
json_ref(std::initializer_list<json_ref> init)
|
json_ref(std::initializer_list<json_ref> init)
|
||||||
: owned_value(init)
|
: owned_value(init)
|
||||||
, value_ref(&owned_value)
|
|
||||||
, is_rvalue(true)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
template <
|
template <
|
||||||
@ -12625,8 +12620,6 @@ class json_ref
|
|||||||
enable_if_t<std::is_constructible<value_type, Args...>::value, int> = 0 >
|
enable_if_t<std::is_constructible<value_type, Args...>::value, int> = 0 >
|
||||||
json_ref(Args && ... args)
|
json_ref(Args && ... args)
|
||||||
: owned_value(std::forward<Args>(args)...)
|
: owned_value(std::forward<Args>(args)...)
|
||||||
, value_ref(&owned_value)
|
|
||||||
, is_rvalue(true)
|
|
||||||
{}
|
{}
|
||||||
|
|
||||||
// class should be movable only
|
// class should be movable only
|
||||||
@ -12638,27 +12631,26 @@ class json_ref
|
|||||||
|
|
||||||
value_type moved_or_copied() const
|
value_type moved_or_copied() const
|
||||||
{
|
{
|
||||||
if (is_rvalue)
|
if (value_ref == nullptr)
|
||||||
{
|
{
|
||||||
return std::move(*value_ref);
|
return std::move(owned_value);
|
||||||
}
|
}
|
||||||
return *value_ref;
|
return *value_ref;
|
||||||
}
|
}
|
||||||
|
|
||||||
value_type const& operator*() const
|
value_type const& operator*() const
|
||||||
{
|
{
|
||||||
return *static_cast<value_type const*>(value_ref);
|
return value_ref ? *value_ref : owned_value;
|
||||||
}
|
}
|
||||||
|
|
||||||
value_type const* operator->() const
|
value_type const* operator->() const
|
||||||
{
|
{
|
||||||
return static_cast<value_type const*>(value_ref);
|
return &**this;
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
mutable value_type owned_value = nullptr;
|
mutable value_type owned_value = nullptr;
|
||||||
value_type* value_ref = nullptr;
|
value_type const* value_ref = nullptr;
|
||||||
const bool is_rvalue = true;
|
|
||||||
};
|
};
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
} // namespace nlohmann
|
} // namespace nlohmann
|
||||||
|
Loading…
Reference in New Issue
Block a user