1 // Copyright 2007-2010 Baptiste Lepilleur
2 // Distributed under MIT license, or public domain if desired and
3 // recognized in your jurisdiction.
4 // See file LICENSE for detail or copy at http://jsoncpp.sourceforge.net/LICENSE
5 
6 #ifndef JSON_CONFIG_H_INCLUDED
7 # define JSON_CONFIG_H_INCLUDED
8 
9 /// If defined, indicates that json library is embedded in CppTL library.
10 //# define JSON_IN_CPPTL 1
11 
12 /// If defined, indicates that json may leverage CppTL library
13 //#  define JSON_USE_CPPTL 1
14 /// If defined, indicates that cpptl vector based map should be used instead of std::map
15 /// as Value container.
16 //#  define JSON_USE_CPPTL_SMALLMAP 1
17 /// If defined, indicates that Json specific container should be used
18 /// (hash table & simple deque container with customizable allocator).
19 /// THIS FEATURE IS STILL EXPERIMENTAL! There is know bugs: See #3177332
20 //#  define JSON_VALUE_USE_INTERNAL_MAP 1
21 /// Force usage of standard new/malloc based allocator instead of memory pool based allocator.
22 /// The memory pools allocator used optimization (initializing Value and ValueInternalLink
23 /// as if it was a POD) that may cause some validation tool to report errors.
24 /// Only has effects if JSON_VALUE_USE_INTERNAL_MAP is defined.
25 //#  define JSON_USE_SIMPLE_INTERNAL_ALLOCATOR 1
26 
27 // If non-zero, the library uses exceptions to report bad input instead of C
28 // assertion macros. The default is to use exceptions.
29 # ifndef JSON_USE_EXCEPTION
30 # define JSON_USE_EXCEPTION 1
31 # endif
32 
33 /// If defined, indicates that the source file is amalgated
34 /// to prevent private header inclusion.
35 /// Remarks: it is automatically defined in the generated amalgated header.
36 // #define JSON_IS_AMALGAMATION
37 
38 
39 # ifdef JSON_IN_CPPTL
40 #  include <cpptl/config.h>
41 #  ifndef JSON_USE_CPPTL
42 #   define JSON_USE_CPPTL 1
43 #  endif
44 # endif
45 
46 # ifdef JSON_IN_CPPTL
47 #  define JSON_API CPPTL_API
48 # elif defined(JSON_DLL_BUILD)
49 #  define JSON_API __declspec(dllexport)
50 # elif defined(JSON_DLL)
51 #  define JSON_API __declspec(dllimport)
52 # else
53 #  define JSON_API
54 # endif
55 
56 // If JSON_NO_INT64 is defined, then Json only support C++ "int" type for integer
57 // Storages, and 64 bits integer support is disabled.
58 // #define JSON_NO_INT64 1
59 
60 #if defined(_MSC_VER)  &&  _MSC_VER <= 1200 // MSVC 6
61 // Microsoft Visual Studio 6 only support conversion from __int64 to double
62 // (no conversion from unsigned __int64).
63 #define JSON_USE_INT64_DOUBLE_CONVERSION 1
64 #endif // if defined(_MSC_VER)  &&  _MSC_VER < 1200 // MSVC 6
65 
66 #if defined(_MSC_VER)  &&  _MSC_VER >= 1500 // MSVC 2008
67 /// Indicates that the following function is deprecated.
68 # define JSONCPP_DEPRECATED(message) __declspec(deprecated(message))
69 #endif
70 
71 #if !defined(JSONCPP_DEPRECATED)
72 # define JSONCPP_DEPRECATED(message)
73 #endif // if !defined(JSONCPP_DEPRECATED)
74 
75 namespace Json {
76    typedef int Int;
77    typedef unsigned int UInt;
78 # if defined(JSON_NO_INT64)
79    typedef int LargestInt;
80    typedef unsigned int LargestUInt;
81 #  undef JSON_HAS_INT64
82 # else // if defined(JSON_NO_INT64)
83    // For Microsoft Visual use specific types as long long is not supported
84 #  if defined(_MSC_VER) // Microsoft Visual Studio
85    typedef __int64 Int64;
86    typedef unsigned __int64 UInt64;
87 #  else // if defined(_MSC_VER) // Other platforms, use long long
88    typedef long long int Int64;
89    typedef unsigned long long int UInt64;
90 #  endif // if defined(_MSC_VER)
91    typedef Int64 LargestInt;
92    typedef UInt64 LargestUInt;
93 #  define JSON_HAS_INT64
94 # endif // if defined(JSON_NO_INT64)
95 } // end namespace Json
96 
97 
98 #endif // JSON_CONFIG_H_INCLUDED
99