2018-01-10 17:18:31 +08:00
|
|
|
#pragma once
|
2017-08-15 00:22:49 +08:00
|
|
|
|
2021-01-09 07:08:27 +08:00
|
|
|
#include <type_traits>
|
2017-08-15 00:22:49 +08:00
|
|
|
#include <utility>
|
|
|
|
|
2018-01-29 18:21:11 +08:00
|
|
|
#include <nlohmann/detail/conversions/from_json.hpp>
|
|
|
|
#include <nlohmann/detail/conversions/to_json.hpp>
|
2021-01-11 02:23:32 +08:00
|
|
|
#include <nlohmann/detail/meta/identity_tag.hpp>
|
2021-01-09 07:08:27 +08:00
|
|
|
#include <nlohmann/detail/meta/type_traits.hpp>
|
2017-08-15 00:22:49 +08:00
|
|
|
|
|
|
|
namespace nlohmann
|
|
|
|
{
|
2018-10-28 16:15:41 +08:00
|
|
|
|
2021-01-09 07:08:27 +08:00
|
|
|
template<typename ValueType, typename>
|
2017-08-15 00:22:49 +08:00
|
|
|
struct adl_serializer
|
|
|
|
{
|
|
|
|
/*!
|
|
|
|
@brief convert a JSON value to any value type
|
|
|
|
|
|
|
|
This function is usually called by the `get()` function of the
|
|
|
|
@ref basic_json class (either explicit or via conversion operators).
|
|
|
|
|
2021-01-24 01:24:47 +08:00
|
|
|
@note This function is chosen for default-constructible value types.
|
2021-01-10 00:45:56 +08:00
|
|
|
|
2018-10-28 16:15:41 +08:00
|
|
|
@param[in] j JSON value to read from
|
2017-08-15 00:22:49 +08:00
|
|
|
@param[in,out] val value to write to
|
|
|
|
*/
|
2021-01-10 00:45:56 +08:00
|
|
|
template<typename BasicJsonType, typename TargetType = ValueType>
|
|
|
|
static auto from_json(BasicJsonType && j, TargetType& val) noexcept(
|
2018-10-28 16:15:41 +08:00
|
|
|
noexcept(::nlohmann::from_json(std::forward<BasicJsonType>(j), val)))
|
|
|
|
-> decltype(::nlohmann::from_json(std::forward<BasicJsonType>(j), val), void())
|
2017-08-15 00:22:49 +08:00
|
|
|
{
|
|
|
|
::nlohmann::from_json(std::forward<BasicJsonType>(j), val);
|
|
|
|
}
|
|
|
|
|
2021-01-10 00:45:56 +08:00
|
|
|
/*!
|
|
|
|
@brief convert a JSON value to any value type
|
|
|
|
|
|
|
|
This function is usually called by the `get()` function of the
|
|
|
|
@ref basic_json class (either explicit or via conversion operators).
|
|
|
|
|
2021-01-24 01:24:47 +08:00
|
|
|
@note This function is chosen for value types which are not default-constructible.
|
2021-01-10 00:45:56 +08:00
|
|
|
|
|
|
|
@param[in] j JSON value to read from
|
|
|
|
|
|
|
|
@return copy of the JSON value, converted to @a ValueType
|
|
|
|
*/
|
|
|
|
template<typename BasicJsonType, typename TargetType = ValueType>
|
2021-01-09 07:08:27 +08:00
|
|
|
static auto from_json(BasicJsonType && j) noexcept(
|
2021-01-11 02:23:32 +08:00
|
|
|
noexcept(::nlohmann::from_json(std::forward<BasicJsonType>(j), detail::identity_tag<TargetType> {})))
|
|
|
|
-> decltype(::nlohmann::from_json(std::forward<BasicJsonType>(j), detail::identity_tag<TargetType> {}))
|
2021-01-09 07:08:27 +08:00
|
|
|
{
|
2021-01-11 02:23:32 +08:00
|
|
|
return ::nlohmann::from_json(std::forward<BasicJsonType>(j), detail::identity_tag<TargetType> {});
|
2021-01-09 07:08:27 +08:00
|
|
|
}
|
|
|
|
|
2017-08-15 00:22:49 +08:00
|
|
|
/*!
|
|
|
|
@brief convert any value type to a JSON value
|
|
|
|
|
|
|
|
This function is usually called by the constructors of the @ref basic_json
|
|
|
|
class.
|
|
|
|
|
|
|
|
@param[in,out] j JSON value to write to
|
2018-10-28 16:15:41 +08:00
|
|
|
@param[in] val value to read from
|
2017-08-15 00:22:49 +08:00
|
|
|
*/
|
2021-01-10 00:45:56 +08:00
|
|
|
template<typename BasicJsonType, typename TargetType = ValueType>
|
|
|
|
static auto to_json(BasicJsonType& j, TargetType && val) noexcept(
|
|
|
|
noexcept(::nlohmann::to_json(j, std::forward<TargetType>(val))))
|
|
|
|
-> decltype(::nlohmann::to_json(j, std::forward<TargetType>(val)), void())
|
2017-08-15 00:22:49 +08:00
|
|
|
{
|
2021-01-10 00:45:56 +08:00
|
|
|
::nlohmann::to_json(j, std::forward<TargetType>(val));
|
2017-08-15 00:22:49 +08:00
|
|
|
}
|
|
|
|
};
|
2018-10-08 00:39:18 +08:00
|
|
|
} // namespace nlohmann
|