1
0

config.h 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194
  1. // Copyright 2007-2010 Baptiste Lepilleur and The JsonCpp Authors
  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. #ifndef JSON_CONFIG_H_INCLUDED
  6. #define JSON_CONFIG_H_INCLUDED
  7. // Include KWSys Large File Support configuration.
  8. #include <cmsys/Configure.h>
  9. #include <stddef.h>
  10. #include <string> //typedef String
  11. #include <stdint.h> //typedef int64_t, uint64_t
  12. #if defined(_MSC_VER)
  13. # pragma warning(push,1)
  14. #endif
  15. /// If defined, indicates that json library is embedded in CppTL library.
  16. //# define JSON_IN_CPPTL 1
  17. /// If defined, indicates that json may leverage CppTL library
  18. //# define JSON_USE_CPPTL 1
  19. /// If defined, indicates that cpptl vector based map should be used instead of
  20. /// std::map
  21. /// as Value container.
  22. //# define JSON_USE_CPPTL_SMALLMAP 1
  23. // If non-zero, the library uses exceptions to report bad input instead of C
  24. // assertion macros. The default is to use exceptions.
  25. #ifndef JSON_USE_EXCEPTION
  26. #define JSON_USE_EXCEPTION 1
  27. #endif
  28. /// If defined, indicates that the source file is amalgated
  29. /// to prevent private header inclusion.
  30. /// Remarks: it is automatically defined in the generated amalgated header.
  31. // #define JSON_IS_AMALGAMATION
  32. #ifdef JSON_IN_CPPTL
  33. #include <cpptl/config.h>
  34. #ifndef JSON_USE_CPPTL
  35. #define JSON_USE_CPPTL 1
  36. #endif
  37. #endif
  38. #ifdef JSON_IN_CPPTL
  39. #define JSON_API CPPTL_API
  40. #elif defined(JSON_DLL_BUILD)
  41. #if defined(_MSC_VER) || defined(__MINGW32__)
  42. #define JSON_API __declspec(dllexport)
  43. #define JSONCPP_DISABLE_DLL_INTERFACE_WARNING
  44. #endif // if defined(_MSC_VER)
  45. #elif defined(JSON_DLL)
  46. #if defined(_MSC_VER) || defined(__MINGW32__)
  47. #define JSON_API __declspec(dllimport)
  48. #define JSONCPP_DISABLE_DLL_INTERFACE_WARNING
  49. #endif // if defined(_MSC_VER)
  50. #endif // ifdef JSON_IN_CPPTL
  51. #if !defined(JSON_API)
  52. #define JSON_API
  53. #endif
  54. // If JSON_NO_INT64 is defined, then Json only support C++ "int" type for
  55. // integer
  56. // Storages, and 64 bits integer support is disabled.
  57. // #define JSON_NO_INT64 1
  58. #if defined(_MSC_VER) // MSVC
  59. # if _MSC_VER <= 1200 // MSVC 6
  60. // Microsoft Visual Studio 6 only support conversion from __int64 to double
  61. // (no conversion from unsigned __int64).
  62. # define JSON_USE_INT64_DOUBLE_CONVERSION 1
  63. // Disable warning 4786 for VS6 caused by STL (identifier was truncated to '255'
  64. // characters in the debug information)
  65. // All projects I've ever seen with VS6 were using this globally (not bothering
  66. // with pragma push/pop).
  67. # pragma warning(disable : 4786)
  68. # endif // MSVC 6
  69. #endif // defined(_MSC_VER)
  70. // In c++11 the override keyword allows you to explicity define that a function
  71. // is intended to override the base-class version. This makes the code more
  72. // managable and fixes a set of common hard-to-find bugs.
  73. #if __cplusplus >= 201103L
  74. # define JSONCPP_OVERRIDE override
  75. # define JSONCPP_NOEXCEPT noexcept
  76. #elif defined(_MSC_VER) && _MSC_VER > 1600 && _MSC_VER < 1900
  77. # define JSONCPP_OVERRIDE override
  78. # define JSONCPP_NOEXCEPT throw()
  79. #elif defined(_MSC_VER) && _MSC_VER >= 1900
  80. # define JSONCPP_OVERRIDE override
  81. # define JSONCPP_NOEXCEPT noexcept
  82. #else
  83. # define JSONCPP_OVERRIDE
  84. # define JSONCPP_NOEXCEPT throw()
  85. #endif
  86. #ifndef JSON_HAS_RVALUE_REFERENCES
  87. #if defined(_MSC_VER) && _MSC_VER >= 1600 // MSVC >= 2010
  88. #define JSON_HAS_RVALUE_REFERENCES 1
  89. #endif // MSVC >= 2010
  90. #ifdef __clang__
  91. #if __has_feature(cxx_rvalue_references)
  92. #define JSON_HAS_RVALUE_REFERENCES 1
  93. #endif // has_feature
  94. #elif defined __GNUC__ // not clang (gcc comes later since clang emulates gcc)
  95. #if defined(__GXX_EXPERIMENTAL_CXX0X__) || (__cplusplus >= 201103L)
  96. #define JSON_HAS_RVALUE_REFERENCES 1
  97. #endif // GXX_EXPERIMENTAL
  98. #endif // __clang__ || __GNUC__
  99. #endif // not defined JSON_HAS_RVALUE_REFERENCES
  100. #ifndef JSON_HAS_RVALUE_REFERENCES
  101. #define JSON_HAS_RVALUE_REFERENCES 0
  102. #endif
  103. #ifdef __clang__
  104. # if __has_extension(attribute_deprecated_with_message)
  105. # define JSONCPP_DEPRECATED(message) __attribute__ ((deprecated(message)))
  106. # endif
  107. #elif defined __GNUC__ // not clang (gcc comes later since clang emulates gcc)
  108. # if (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 5))
  109. # define JSONCPP_DEPRECATED(message) __attribute__ ((deprecated(message)))
  110. # elif (__GNUC__ > 3 || (__GNUC__ == 3 && __GNUC_MINOR__ >= 1))
  111. # define JSONCPP_DEPRECATED(message) __attribute__((__deprecated__))
  112. # endif // GNUC version
  113. #elif defined(_MSC_VER) && _MSC_VER >= 1500 // MSVC 2008
  114. /// Indicates that the following function is deprecated.
  115. # define JSONCPP_DEPRECATED(message) __declspec(deprecated(message))
  116. #endif // __clang__ || __GNUC__ || _MSC_VER
  117. #undef JSONCPP_DEPRECATED // no deprecations in CMake copy
  118. #if !defined(JSONCPP_DEPRECATED)
  119. #define JSONCPP_DEPRECATED(message)
  120. #endif // if !defined(JSONCPP_DEPRECATED)
  121. #if __GNUC__ >= 6
  122. # define JSON_USE_INT64_DOUBLE_CONVERSION 1
  123. #endif
  124. #if !defined(JSON_IS_AMALGAMATION)
  125. # include "version.h"
  126. # if JSONCPP_USING_SECURE_MEMORY
  127. # include "allocator.h" //typedef Allocator
  128. # endif
  129. #endif // if !defined(JSON_IS_AMALGAMATION)
  130. namespace Json {
  131. typedef int Int;
  132. typedef unsigned int UInt;
  133. #if defined(JSON_NO_INT64)
  134. typedef int LargestInt;
  135. typedef unsigned int LargestUInt;
  136. #undef JSON_HAS_INT64
  137. #else // if defined(JSON_NO_INT64)
  138. // For Microsoft Visual use specific types as long long is not supported
  139. #if defined(_MSC_VER) // Microsoft Visual Studio
  140. typedef __int64 Int64;
  141. typedef unsigned __int64 UInt64;
  142. #else // if defined(_MSC_VER) // Other platforms, use long long
  143. typedef int64_t Int64;
  144. typedef uint64_t UInt64;
  145. #endif // if defined(_MSC_VER)
  146. typedef Int64 LargestInt;
  147. typedef UInt64 LargestUInt;
  148. #define JSON_HAS_INT64
  149. #endif // if defined(JSON_NO_INT64)
  150. #if JSONCPP_USING_SECURE_MEMORY
  151. #define JSONCPP_STRING std::basic_string<char, std::char_traits<char>, Json::SecureAllocator<char> >
  152. #define JSONCPP_OSTRINGSTREAM std::basic_ostringstream<char, std::char_traits<char>, Json::SecureAllocator<char> >
  153. #define JSONCPP_OSTREAM std::basic_ostream<char, std::char_traits<char>>
  154. #define JSONCPP_ISTRINGSTREAM std::basic_istringstream<char, std::char_traits<char>, Json::SecureAllocator<char> >
  155. #define JSONCPP_ISTREAM std::istream
  156. #else
  157. #define JSONCPP_STRING std::string
  158. #define JSONCPP_OSTRINGSTREAM std::ostringstream
  159. #define JSONCPP_OSTREAM std::ostream
  160. #define JSONCPP_ISTRINGSTREAM std::istringstream
  161. #define JSONCPP_ISTREAM std::istream
  162. #endif // if JSONCPP_USING_SECURE_MEMORY
  163. } // end namespace Json
  164. #endif // JSON_CONFIG_H_INCLUDED