]> git.donarmstrong.com Git - bamtools.git/blob - src/third_party/jsoncpp/json_config.h
Merge branch 'master' of git://github.com/pezmaster31/bamtools
[bamtools.git] / src / third_party / jsoncpp / json_config.h
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!
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 defined, indicates that Json use exception to report invalid type manipulation
28 /// instead of C assert macro.
29 # define JSON_USE_EXCEPTION 1
30
31 # ifdef JSON_IN_CPPTL
32 #  include <cpptl/config.h>
33 #  ifndef JSON_USE_CPPTL
34 #   define JSON_USE_CPPTL 1
35 #  endif
36 # endif
37
38 # ifdef JSON_IN_CPPTL
39 #  define JSON_API CPPTL_API
40 # elif defined(JSON_DLL_BUILD)
41 #  define JSON_API __declspec(dllexport)
42 # elif defined(JSON_DLL)
43 #  define JSON_API __declspec(dllimport)
44 # else
45 #  define JSON_API
46 # endif
47
48 // If JSON_NO_INT64 is defined, then Json only support C++ "int" type for integer
49 // Storages.
50 // #define JSON_NO_INT64 1
51
52 #if defined(_MSC_VER)  &&  _MSC_VER <= 1200 // MSVC 6
53 // Microsoft Visual Studio 6 only support conversion from __int64 to double
54 // (no conversion from unsigned __int64).
55 #define JSON_USE_INT64_DOUBLE_CONVERSION 1
56 #endif // if defined(_MSC_VER)  &&  _MSC_VER < 1200 // MSVC 6
57
58
59 namespace Json {
60 # if defined(JSON_NO_INT64)
61    typedef int Int;
62    typedef unsigned int UInt;
63 # else // if defined(JSON_NO_INT64)
64    // For Microsoft Visual use specific types as long long is not supported
65 #  if defined(_MSC_VER) // Microsoft Visual Studio
66    typedef __int64 Int;
67    typedef unsigned __int64 UInt;
68 #  else // if defined(_MSC_VER) // Other platforms, use long long
69    typedef long long int Int;
70    typedef unsigned long long int UInt;
71 #  endif // if defined(_MSC_VER)
72 # endif // if defined(JSON_NO_INT64)
73 } // end namespace Json
74
75
76 #endif // JSON_CONFIG_H_INCLUDED