Merge pull request #2034 from ArtemSarmini/gh-1920-gcc-10-incomplete-types

Templatize basic_json constructor from json_ref
This commit is contained in:
Niels Lohmann 2020-04-13 13:19:28 +02:00 committed by GitHub
commit 84f19d6333
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 34 additions and 8 deletions

View file

@ -41,6 +41,19 @@ template<typename> struct is_basic_json : std::false_type {};
NLOHMANN_BASIC_JSON_TPL_DECLARATION NLOHMANN_BASIC_JSON_TPL_DECLARATION
struct is_basic_json<NLOHMANN_BASIC_JSON_TPL> : std::true_type {}; struct is_basic_json<NLOHMANN_BASIC_JSON_TPL> : std::true_type {};
//////////////////////
// json_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 // // aliases for detected //
////////////////////////// //////////////////////////

View file

@ -1773,10 +1773,10 @@ class basic_json
// other constructors and destructor // // other constructors and destructor //
/////////////////////////////////////// ///////////////////////////////////////
/// @private template <typename JsonRef,
basic_json(const detail::json_ref<basic_json>& ref) detail::enable_if_t<detail::conjunction<detail::is_json_ref<JsonRef>,
: basic_json(ref.moved_or_copied()) 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 @brief copy constructor

View file

@ -2794,6 +2794,19 @@ template<typename> struct is_basic_json : std::false_type {};
NLOHMANN_BASIC_JSON_TPL_DECLARATION NLOHMANN_BASIC_JSON_TPL_DECLARATION
struct is_basic_json<NLOHMANN_BASIC_JSON_TPL> : std::true_type {}; struct is_basic_json<NLOHMANN_BASIC_JSON_TPL> : std::true_type {};
//////////////////////
// json_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 // // aliases for detected //
////////////////////////// //////////////////////////
@ -16632,10 +16645,10 @@ class basic_json
// other constructors and destructor // // other constructors and destructor //
/////////////////////////////////////// ///////////////////////////////////////
/// @private template <typename JsonRef,
basic_json(const detail::json_ref<basic_json>& ref) detail::enable_if_t<detail::conjunction<detail::is_json_ref<JsonRef>,
: basic_json(ref.moved_or_copied()) 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 @brief copy constructor