Migration Guide¶
This page collects some guidelines on how to future-proof your code for future versions of this library.
Replace deprecated functions¶
The following functions have been deprecated and will be removed in the next major version (i.e., 4.0.0). All deprecations are annotated with HEDLEY_DEPRECATED_FOR
to report which function to use instead.
Parsing¶
-
Function
friend std::istream& operator<<(basic_json&, std::istream&)
is deprecated since 3.0.0. Please usefriend std::istream& operator>>(std::istream&, basic_json&)
instead.nlohmann::json j; std::stringstream ss("[1,2,3]"); j << ss;
nlohmann::json j; std::stringstream ss("[1,2,3]"); ss >> j;
-
Passing iterator pairs or pointer/length pairs to parsing functions (
parse
,accept
,sax_parse
,from_cbor
,from_msgpack
,from_ubjson
, andfrom_bson
via initializer lists is deprecated since 3.8.0. Instead, pass two iterators; for instance, callfrom_cbor(ptr, ptr+len)
instead offrom_cbor({ptr, len})
.const char* s = "[1,2,3]"; bool ok = nlohmann::json::accept({s, s + std::strlen(s)});
const char* s = "[1,2,3]"; bool ok = nlohmann::json::accept(s, s + std::strlen(s));
JSON Pointers¶
-
Comparing JSON Pointers with strings via
operator==
andoperator!=
is deprecated since 3.11.2. To compare ajson_pointer
p
with a strings
, converts
to ajson_pointer
first and usejson_pointer::operator==
orjson_pointer::operator!=
.nlohmann::json::json_pointer lhs("/foo/bar/1"); assert(lhs == "/foo/bar/1");
nlohmann::json::json_pointer lhs("/foo/bar/1"); assert(lhs == nlohmann::json::json_pointer("/foo/bar/1"));
-
The implicit conversion from JSON Pointers to string (
json_pointer::operator string_t
) is deprecated since 3.11.0. Usejson_pointer::to_string
instead.nlohmann::json::json_pointer ptr("/foo/bar/1"); std::string s = ptr;
nlohmann::json::json_pointer ptr("/foo/bar/1"); std::string s = ptr.to_string();
-
Passing a
basic_json
specialization as template parameterRefStringType
tojson_pointer
is deprecated since 3.11.0. The string type can now be directly provided.using my_json = nlohmann::basic_json<std::map, std::vector, my_string_type>; nlohmann::json_pointer<my_json> ptr("/foo/bar/1");
nlohmann::json_pointer<my_string_type> ptr("/foo/bar/1");
Thereby,
nlohmann::my_json::json_pointer
is an alias fornlohmann::json_pointer<my_string_type>
and is always an alias to thejson_pointer
with the appropriate string type for all specializations ofbasic_json
.
Miscellaneous functions¶
-
The function
iterator_wrapper
is deprecated since 3.1.0. Please use the member functionitems
instead.for (auto &x : nlohmann::json::iterator_wrapper(j)) { std::cout << x.key() << ":" << x.value() << std::endl; }
for (auto &x : j.items()) { std::cout << x.key() << ":" << x.value() << std::endl; }
-
Function
friend std::ostream& operator>>(const basic_json&, std::ostream&)
is deprecated since 3.0.0. Please usefriend operator<<(std::ostream&, const basic_json&)
instead.j >> std::cout;
std::cout << j;
-
The legacy comparison behavior for discarded values is deprecated since 3.11.0. It is already disabled by default and can still be enabled by defining
JSON_USE_LEGACY_DISCARDED_VALUE_COMPARISON
to1
.#define JSON_USE_LEGACY_DISCARDED_VALUE_COMPARISON 1 #include <nlohmann/json.hpp>
#include <nlohmann/json.hpp>
Replace implicit conversions¶
Implicit conversions via operator ValueType
will be switched off by default in the next major release of the library.
You can prepare existing code by already defining JSON_USE_IMPLICIT_CONVERSIONS
to 0
and replace any implicit conversions with calls to get
, get_to
, get_ref
, or get_ptr
.
nlohmann::json j = "Hello, world!";
std::string s = j;
nlohmann::json j = "Hello, world!";
auto s = j.template get<std::string>();
nlohmann::json j = "Hello, world!";
std::string s;
j.get_to(s);
You can prepare existing code by already defining JSON_USE_IMPLICIT_CONVERSIONS
to 0
and replace any implicit conversions with calls to get
.
Import namespace literals
for UDLs¶
The user-defined string literals operator""_json
and operator""_json_pointer
will be removed from the global namespace in the next major release of the library.
nlohmann::json j = "[1,2,3]"_json;
using namespace nlohmann::literals;
nlohmann::json j = "[1,2,3]"_json;
To prepare existing code, define JSON_USE_GLOBAL_UDLS
to 0
and bring the string literals into scope where needed.
Do not hard-code the complete library namespace¶
The nlohmann
namespace contains a sub-namespace to avoid problems when different versions or configurations of the library are used in the same project. Always use nlohmann
as namespace or, when the exact version and configuration is relevant, use macro NLOHMANN_JSON_NAMESPACE
to denote the namespace.
void to_json(nlohmann::json_abi_v3_11_2::json& j, const person& p)
{
j["age"] = p.age;
}
void to_json(nlohmann::json& j, const person& p)
{
j["age"] = p.age;
}
void to_json(NLOHMANN_JSON_NAMESPACE::json& j, const person& p)
{
j["age"] = p.age;
}
Do not use the details
namespace¶
The details
namespace is not part of the public API of the library and can change in any version without announcement. Do not rely on any function or type in the details
namespace.