2017-07-21 03:44:36 -07:00
|
|
|
// Copyright 2007-2010 Baptiste Lepilleur and The JsonCpp Authors
|
2010-04-20 21:35:19 +00:00
|
|
|
// Distributed under MIT license, or public domain if desired and
|
|
|
|
// recognized in your jurisdiction.
|
|
|
|
// See file LICENSE for detail or copy at http://jsoncpp.sourceforge.net/LICENSE
|
|
|
|
|
|
|
|
#ifndef CPPTL_JSON_FEATURES_H_INCLUDED
|
2014-07-01 08:48:54 +10:00
|
|
|
#define CPPTL_JSON_FEATURES_H_INCLUDED
|
2010-04-20 21:35:19 +00:00
|
|
|
|
2011-05-02 21:09:30 +00:00
|
|
|
#if !defined(JSON_IS_AMALGAMATION)
|
2014-07-01 08:48:54 +10:00
|
|
|
#include "forwards.h"
|
2011-05-02 21:09:30 +00:00
|
|
|
#endif // if !defined(JSON_IS_AMALGAMATION)
|
2010-04-20 21:35:19 +00:00
|
|
|
|
2016-12-03 22:29:14 +02:00
|
|
|
#pragma pack(push, 8)
|
|
|
|
|
2010-04-20 21:35:19 +00:00
|
|
|
namespace Json {
|
|
|
|
|
2014-07-01 08:48:54 +10:00
|
|
|
/** \brief Configuration passed to reader and writer.
|
|
|
|
* This configuration object can be used to force the Reader or Writer
|
|
|
|
* to behave in a standard conforming way.
|
|
|
|
*/
|
|
|
|
class JSON_API Features {
|
|
|
|
public:
|
|
|
|
/** \brief A configuration that allows all features and assumes all strings
|
|
|
|
* are UTF-8.
|
|
|
|
* - C & C++ comments are allowed
|
|
|
|
* - Root object can be any JSON value
|
|
|
|
* - Assumes Value strings are encoded in UTF-8
|
|
|
|
*/
|
|
|
|
static Features all();
|
|
|
|
|
|
|
|
/** \brief A configuration that is strictly compatible with the JSON
|
|
|
|
* specification.
|
|
|
|
* - Comments are forbidden.
|
|
|
|
* - Root object must be either an array or an object value.
|
|
|
|
* - Assumes Value strings are encoded in UTF-8
|
|
|
|
*/
|
|
|
|
static Features strictMode();
|
|
|
|
|
|
|
|
/** \brief Initialize the configuration like JsonConfig::allFeatures;
|
|
|
|
*/
|
|
|
|
Features();
|
|
|
|
|
|
|
|
/// \c true if comments are allowed. Default: \c true.
|
2019-01-17 11:07:53 -05:00
|
|
|
bool allowComments_{ true };
|
2014-07-01 08:48:54 +10:00
|
|
|
|
|
|
|
/// \c true if root must be either an array or an object value. Default: \c
|
|
|
|
/// false.
|
2019-01-17 11:07:53 -05:00
|
|
|
bool strictRoot_{ false };
|
2014-07-01 08:48:54 +10:00
|
|
|
|
|
|
|
/// \c true if dropped null placeholders are allowed. Default: \c false.
|
2019-01-17 11:07:53 -05:00
|
|
|
bool allowDroppedNullPlaceholders_{ false };
|
2014-07-01 08:48:54 +10:00
|
|
|
|
|
|
|
/// \c true if numeric object key are allowed. Default: \c false.
|
2019-01-17 11:07:53 -05:00
|
|
|
bool allowNumericKeys_{ false };
|
2014-07-01 08:48:54 +10:00
|
|
|
};
|
2010-04-20 21:35:19 +00:00
|
|
|
|
|
|
|
} // namespace Json
|
|
|
|
|
2016-12-03 22:29:14 +02:00
|
|
|
#pragma pack(pop)
|
|
|
|
|
2010-04-20 21:35:19 +00:00
|
|
|
#endif // CPPTL_JSON_FEATURES_H_INCLUDED
|