mirror of
https://github.com/open-source-parsers/jsoncpp.git
synced 2024-12-29 12:41:38 +08:00
842e9ac54b
This eases porting portable code and does not break compatibility with the previous release. Json::Value::asLargestInt() has also be added to ease writing portable code independent of 64 bits integer support. It is typically used to implement writers.
83 lines
2.9 KiB
C++
83 lines
2.9 KiB
C++
// Copyright 2007-2010 Baptiste Lepilleur
|
|
// 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 JSON_CONFIG_H_INCLUDED
|
|
# define JSON_CONFIG_H_INCLUDED
|
|
|
|
/// If defined, indicates that json library is embedded in CppTL library.
|
|
//# define JSON_IN_CPPTL 1
|
|
|
|
/// If defined, indicates that json may leverage CppTL library
|
|
//# define JSON_USE_CPPTL 1
|
|
/// If defined, indicates that cpptl vector based map should be used instead of std::map
|
|
/// as Value container.
|
|
//# define JSON_USE_CPPTL_SMALLMAP 1
|
|
/// If defined, indicates that Json specific container should be used
|
|
/// (hash table & simple deque container with customizable allocator).
|
|
/// THIS FEATURE IS STILL EXPERIMENTAL!
|
|
//# define JSON_VALUE_USE_INTERNAL_MAP 1
|
|
/// Force usage of standard new/malloc based allocator instead of memory pool based allocator.
|
|
/// The memory pools allocator used optimization (initializing Value and ValueInternalLink
|
|
/// as if it was a POD) that may cause some validation tool to report errors.
|
|
/// Only has effects if JSON_VALUE_USE_INTERNAL_MAP is defined.
|
|
//# define JSON_USE_SIMPLE_INTERNAL_ALLOCATOR 1
|
|
|
|
/// If defined, indicates that Json use exception to report invalid type manipulation
|
|
/// instead of C assert macro.
|
|
# define JSON_USE_EXCEPTION 1
|
|
|
|
# ifdef JSON_IN_CPPTL
|
|
# include <cpptl/config.h>
|
|
# ifndef JSON_USE_CPPTL
|
|
# define JSON_USE_CPPTL 1
|
|
# endif
|
|
# endif
|
|
|
|
# ifdef JSON_IN_CPPTL
|
|
# define JSON_API CPPTL_API
|
|
# elif defined(JSON_DLL_BUILD)
|
|
# define JSON_API __declspec(dllexport)
|
|
# elif defined(JSON_DLL)
|
|
# define JSON_API __declspec(dllimport)
|
|
# else
|
|
# define JSON_API
|
|
# endif
|
|
|
|
// If JSON_NO_INT64 is defined, then Json only support C++ "int" type for integer
|
|
// Storages, and 64 bits integer support is disabled.
|
|
// #define JSON_NO_INT64 1
|
|
|
|
#if defined(_MSC_VER) && _MSC_VER <= 1200 // MSVC 6
|
|
// Microsoft Visual Studio 6 only support conversion from __int64 to double
|
|
// (no conversion from unsigned __int64).
|
|
#define JSON_USE_INT64_DOUBLE_CONVERSION 1
|
|
#endif // if defined(_MSC_VER) && _MSC_VER < 1200 // MSVC 6
|
|
|
|
|
|
namespace Json {
|
|
typedef int Int;
|
|
typedef unsigned int UInt;
|
|
# if defined(JSON_NO_INT64)
|
|
typedef int LargestInt;
|
|
typedef unsigned int LargestUInt;
|
|
# undef JSON_HAS_INT64
|
|
# else // if defined(JSON_NO_INT64)
|
|
// For Microsoft Visual use specific types as long long is not supported
|
|
# if defined(_MSC_VER) // Microsoft Visual Studio
|
|
typedef __int64 Int64;
|
|
typedef unsigned __int64 UInt64;
|
|
# else // if defined(_MSC_VER) // Other platforms, use long long
|
|
typedef long long int Int64;
|
|
typedef unsigned long long int UInt64;
|
|
# endif // if defined(_MSC_VER)
|
|
typedef Int64 LargestInt;
|
|
typedef UInt64 LargestUInt;
|
|
# define JSON_HAS_INT64
|
|
# endif // if defined(JSON_NO_INT64)
|
|
} // end namespace Json
|
|
|
|
|
|
#endif // JSON_CONFIG_H_INCLUDED
|