Skip to content

Commit

Permalink
Templatize basic_json ctor from json_ref
Browse files Browse the repository at this point in the history
  • Loading branch information
ArtemSarmini committed Apr 12, 2020
1 parent 4396a68 commit ec955f0
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 8 deletions.
13 changes: 13 additions & 0 deletions include/nlohmann/detail/meta/type_traits.hpp
Expand Up @@ -41,6 +41,19 @@ template<typename> struct is_basic_json : std::false_type {};
NLOHMANN_BASIC_JSON_TPL_DECLARATION
struct is_basic_json<NLOHMANN_BASIC_JSON_TPL> : std::true_type {};

//////////////////////
// jspn_ref helpers //
//////////////////////

template <typename>
class json_ref;

template<typename>
struct is_json_ref : std::false_type {};

template <typename T>
struct is_json_ref<json_ref<T>> : std::true_type {};

//////////////////////////
// aliases for detected //
//////////////////////////
Expand Down
8 changes: 4 additions & 4 deletions include/nlohmann/json.hpp
Expand Up @@ -1773,10 +1773,10 @@ class basic_json
// other constructors and destructor //
///////////////////////////////////////

/// @private
basic_json(const detail::json_ref<basic_json>& ref)
: basic_json(ref.moved_or_copied())
{}
template <typename JsonRef,
detail::enable_if_t<detail::conjunction<detail::is_json_ref<JsonRef>,
std::is_same<typename JsonRef::value_type, basic_json>>::value, int> = 0 >
basic_json(const JsonRef& ref) : basic_json(ref.moved_or_copied()) {}

/*!
@brief copy constructor
Expand Down
21 changes: 17 additions & 4 deletions single_include/nlohmann/json.hpp
Expand Up @@ -2794,6 +2794,19 @@ template<typename> struct is_basic_json : std::false_type {};
NLOHMANN_BASIC_JSON_TPL_DECLARATION
struct is_basic_json<NLOHMANN_BASIC_JSON_TPL> : std::true_type {};

//////////////////////
// jspn_ref helpers //
//////////////////////

template <typename>
class json_ref;

template<typename>
struct is_json_ref : std::false_type {};

template <typename T>
struct is_json_ref<json_ref<T>> : std::true_type {};

//////////////////////////
// aliases for detected //
//////////////////////////
Expand Down Expand Up @@ -16632,10 +16645,10 @@ class basic_json
// other constructors and destructor //
///////////////////////////////////////

/// @private
basic_json(const detail::json_ref<basic_json>& ref)
: basic_json(ref.moved_or_copied())
{}
template <typename JsonRef,
detail::enable_if_t<detail::conjunction<detail::is_json_ref<JsonRef>,
std::is_same<typename JsonRef::value_type, basic_json>>::value, int> = 0 >
basic_json(const JsonRef& ref) : basic_json(ref.moved_or_copied()) {}

/*!
@brief copy constructor
Expand Down

0 comments on commit ec955f0

Please sign in to comment.