2019-03-15 21:55:13 +08:00
|
|
|
#ifndef INCLUDE_NLOHMANN_JSON_FWD_HPP_
|
|
|
|
#define INCLUDE_NLOHMANN_JSON_FWD_HPP_
|
2017-08-14 20:41:01 +08:00
|
|
|
|
|
|
|
#include <cstdint> // int64_t, uint64_t
|
|
|
|
#include <map> // map
|
2017-08-15 01:28:01 +08:00
|
|
|
#include <memory> // allocator
|
|
|
|
#include <string> // string
|
2017-08-14 20:41:01 +08:00
|
|
|
#include <vector> // vector
|
|
|
|
|
|
|
|
/*!
|
|
|
|
@brief namespace for Niels Lohmann
|
|
|
|
@see https://github.com/nlohmann
|
|
|
|
@since version 1.0.0
|
|
|
|
*/
|
|
|
|
namespace nlohmann
|
|
|
|
{
|
|
|
|
/*!
|
|
|
|
@brief default JSONSerializer template argument
|
|
|
|
|
|
|
|
This serializer ignores the template arguments and uses ADL
|
2018-06-25 04:29:33 +08:00
|
|
|
([argument-dependent lookup](https://en.cppreference.com/w/cpp/language/adl))
|
2017-08-14 20:41:01 +08:00
|
|
|
for serialization.
|
|
|
|
*/
|
2018-05-26 20:10:13 +08:00
|
|
|
template<typename T = void, typename SFINAE = void>
|
2017-08-14 20:41:01 +08:00
|
|
|
struct adl_serializer;
|
|
|
|
|
|
|
|
template<template<typename U, typename V, typename... Args> class ObjectType =
|
|
|
|
std::map,
|
|
|
|
template<typename U, typename... Args> class ArrayType = std::vector,
|
|
|
|
class StringType = std::string, class BooleanType = bool,
|
|
|
|
class NumberIntegerType = std::int64_t,
|
|
|
|
class NumberUnsignedType = std::uint64_t,
|
|
|
|
class NumberFloatType = double,
|
|
|
|
template<typename U> class AllocatorType = std::allocator,
|
|
|
|
template<typename T, typename SFINAE = void> class JSONSerializer =
|
2019-07-05 12:13:25 +08:00
|
|
|
adl_serializer,
|
|
|
|
class BinaryType = std::vector<std::uint8_t>>
|
2017-08-14 20:41:01 +08:00
|
|
|
class basic_json;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
@brief JSON Pointer
|
|
|
|
|
|
|
|
A JSON pointer defines a string syntax for identifying a specific value
|
|
|
|
within a JSON document. It can be used with functions `at` and
|
|
|
|
`operator[]`. Furthermore, JSON pointers are the base for JSON patches.
|
|
|
|
|
|
|
|
@sa [RFC 6901](https://tools.ietf.org/html/rfc6901)
|
|
|
|
|
|
|
|
@since version 2.0.0
|
|
|
|
*/
|
2018-01-28 22:36:56 +08:00
|
|
|
template<typename BasicJsonType>
|
2017-08-14 20:41:01 +08:00
|
|
|
class json_pointer;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
@brief default JSON class
|
|
|
|
|
|
|
|
This type is the default specialization of the @ref basic_json class which
|
|
|
|
uses the standard template types.
|
|
|
|
|
|
|
|
@since version 1.0.0
|
|
|
|
*/
|
|
|
|
using json = basic_json<>;
|
2020-06-19 21:27:05 +08:00
|
|
|
|
2020-07-03 08:44:18 +08:00
|
|
|
template<class Key, class T, class IgnoredLess, class Allocator>
|
2020-06-19 21:27:05 +08:00
|
|
|
struct ordered_map;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
@brief ordered JSON class
|
|
|
|
|
|
|
|
This type preserves the insertion order of object keys.
|
|
|
|
|
|
|
|
@since version 3.9.0
|
|
|
|
*/
|
|
|
|
using ordered_json = basic_json<nlohmann::ordered_map>;
|
|
|
|
|
2018-10-08 00:39:18 +08:00
|
|
|
} // namespace nlohmann
|
2017-08-14 20:41:01 +08:00
|
|
|
|
2019-03-15 21:55:13 +08:00
|
|
|
#endif // INCLUDE_NLOHMANN_JSON_FWD_HPP_
|