mirror of
https://github.com/nlohmann/json.git
synced 2025-01-20 00:03:02 +08:00
Merge branch 'develop' into feature/manual_lexer
This commit is contained in:
commit
8d393b5eff
@ -517,9 +517,9 @@ namespace ns {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void from_json(const json& j, person& p) {
|
void from_json(const json& j, person& p) {
|
||||||
p.name = j["name"].get<std::string>();
|
p.name = j.at("name").get<std::string>();
|
||||||
p.address = j["address"].get<std::string>();
|
p.address = j.at("address").get<std::string>();
|
||||||
p.age = j["age"].get<int>();
|
p.age = j.at("age").get<int>();
|
||||||
}
|
}
|
||||||
} // namespace ns
|
} // namespace ns
|
||||||
```
|
```
|
||||||
@ -531,6 +531,7 @@ Some important things:
|
|||||||
|
|
||||||
* Those methods **MUST** be in your type's namespace (which can be the global namespace), or the library will not be able to locate them (in this example, they are in namespace `ns`, where `person` is defined).
|
* Those methods **MUST** be in your type's namespace (which can be the global namespace), or the library will not be able to locate them (in this example, they are in namespace `ns`, where `person` is defined).
|
||||||
* When using `get<your_type>()`, `your_type` **MUST** be [DefaultConstructible](http://en.cppreference.com/w/cpp/concept/DefaultConstructible). (There is a way to bypass this requirement described later.)
|
* When using `get<your_type>()`, `your_type` **MUST** be [DefaultConstructible](http://en.cppreference.com/w/cpp/concept/DefaultConstructible). (There is a way to bypass this requirement described later.)
|
||||||
|
* In function `from_json`, use function [`at()`](https://nlohmann.github.io/json/classnlohmann_1_1basic__json_a93403e803947b86f4da2d1fb3345cf2c.html#a93403e803947b86f4da2d1fb3345cf2c) to access the object values rather than `operator[]`. In case a key does not exists, `at` throws an exception that you can handle, whereas `operator[]` exhibits undefined behavior.
|
||||||
|
|
||||||
#### How do I convert third-party types?
|
#### How do I convert third-party types?
|
||||||
|
|
||||||
@ -833,6 +834,7 @@ I deeply appreciate the help of the following people.
|
|||||||
- [TedLyngmo](https://github.com/TedLyngmo) noted a typo in the README, removed unnecessary bit arithmetic, and fixed some `-Weffc++` warnings.
|
- [TedLyngmo](https://github.com/TedLyngmo) noted a typo in the README, removed unnecessary bit arithmetic, and fixed some `-Weffc++` warnings.
|
||||||
- [Krzysztof Woś](https://github.com/krzysztofwos) made exceptions more visible.
|
- [Krzysztof Woś](https://github.com/krzysztofwos) made exceptions more visible.
|
||||||
- [ftillier](https://github.com/ftillier) fixed a compiler warning.
|
- [ftillier](https://github.com/ftillier) fixed a compiler warning.
|
||||||
|
- [tinloaf](https://github.com/tinloaf) made sure all pushed warnings are properly popped.
|
||||||
|
|
||||||
Thanks a lot for helping out! Please [let me know](mailto:mail@nlohmann.me) if I forgot someone.
|
Thanks a lot for helping out! Please [let me know](mailto:mail@nlohmann.me) if I forgot someone.
|
||||||
|
|
||||||
|
@ -13795,6 +13795,9 @@ inline nlohmann::json::json_pointer operator "" _json_pointer(const char* s, std
|
|||||||
#if defined(__clang__) || defined(__GNUC__) || defined(__GNUG__)
|
#if defined(__clang__) || defined(__GNUC__) || defined(__GNUG__)
|
||||||
#pragma GCC diagnostic pop
|
#pragma GCC diagnostic pop
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(__clang__)
|
||||||
|
#pragma GCC diagnostic pop
|
||||||
|
#endif
|
||||||
|
|
||||||
// clean up
|
// clean up
|
||||||
#undef JSON_CATCH
|
#undef JSON_CATCH
|
||||||
|
Loading…
Reference in New Issue
Block a user