IN2OSM  1.0.1
rapidjson.h
Go to the documentation of this file.
1 // Tencent is pleased to support the open source community by making RapidJSON available.
2 //
3 // Copyright (C) 2015 THL A29 Limited, a Tencent company, and Milo Yip. All rights reserved.
4 //
5 // Licensed under the MIT License (the "License"); you may not use this file except
6 // in compliance with the License. You may obtain a copy of the License at
7 //
8 // http://opensource.org/licenses/MIT
9 //
10 // Unless required by applicable law or agreed to in writing, software distributed
11 // under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
12 // CONDITIONS OF ANY KIND, either express or implied. See the License for the
13 // specific language governing permissions and limitations under the License.
14 
15 #ifndef RAPIDJSON_RAPIDJSON_H_
16 #define RAPIDJSON_RAPIDJSON_H_
17 
39 #include <cstdlib> // malloc(), realloc(), free(), size_t
40 #include <cstring> // memset(), memcpy(), memmove(), memcmp()
41 
43 // RAPIDJSON_VERSION_STRING
44 //
45 // ALWAYS synchronize the following 3 macros with corresponding variables in /CMakeLists.txt.
46 //
47 
49 // token stringification
50 #define RAPIDJSON_STRINGIFY(x) RAPIDJSON_DO_STRINGIFY(x)
51 #define RAPIDJSON_DO_STRINGIFY(x) #x
52 
53 // token concatenation
54 #define RAPIDJSON_JOIN(X, Y) RAPIDJSON_DO_JOIN(X, Y)
55 #define RAPIDJSON_DO_JOIN(X, Y) RAPIDJSON_DO_JOIN2(X, Y)
56 #define RAPIDJSON_DO_JOIN2(X, Y) X##Y
57 
75 #define RAPIDJSON_MAJOR_VERSION 1
76 #define RAPIDJSON_MINOR_VERSION 1
77 #define RAPIDJSON_PATCH_VERSION 0
78 #define RAPIDJSON_VERSION_STRING \
79  RAPIDJSON_STRINGIFY(RAPIDJSON_MAJOR_VERSION.RAPIDJSON_MINOR_VERSION.RAPIDJSON_PATCH_VERSION)
80 
82 // RAPIDJSON_NAMESPACE_(BEGIN|END)
117 #ifndef RAPIDJSON_NAMESPACE
118 #define RAPIDJSON_NAMESPACE rapidjson
119 #endif
120 #ifndef RAPIDJSON_NAMESPACE_BEGIN
121 #define RAPIDJSON_NAMESPACE_BEGIN namespace RAPIDJSON_NAMESPACE {
122 #endif
123 #ifndef RAPIDJSON_NAMESPACE_END
124 #define RAPIDJSON_NAMESPACE_END }
125 #endif
126 
128 // RAPIDJSON_HAS_STDSTRING
129 
130 #ifndef RAPIDJSON_HAS_STDSTRING
131 #ifdef RAPIDJSON_DOXYGEN_RUNNING
132 #define RAPIDJSON_HAS_STDSTRING 1 // force generation of documentation
133 #else
134 #define RAPIDJSON_HAS_STDSTRING 0 // no std::string support by default
135 #endif
136 
146 #endif // !defined(RAPIDJSON_HAS_STDSTRING)
147 
148 #if RAPIDJSON_HAS_STDSTRING
149 #include <string>
150 #endif // RAPIDJSON_HAS_STDSTRING
151 
153 // RAPIDJSON_NO_INT64DEFINE
154 
165 #ifndef RAPIDJSON_NO_INT64DEFINE
166 #if defined(_MSC_VER) && (_MSC_VER < 1800) // Visual Studio 2013
168 #include "msinttypes/stdint.h"
169 #include "msinttypes/inttypes.h"
170 #else
171 // Other compilers should have this.
172 #include <stdint.h>
173 #include <inttypes.h>
174 #endif
175 #ifdef RAPIDJSON_DOXYGEN_RUNNING
177 #define RAPIDJSON_NO_INT64DEFINE
178 #endif
179 #endif // RAPIDJSON_NO_INT64TYPEDEF
180 
182 // RAPIDJSON_FORCEINLINE
183 
184 #ifndef RAPIDJSON_FORCEINLINE
185 #if defined(_MSC_VER) && defined(NDEBUG)
187 #define RAPIDJSON_FORCEINLINE __forceinline
188 #elif defined(__GNUC__) && __GNUC__ >= 4 && defined(NDEBUG)
189 #define RAPIDJSON_FORCEINLINE __attribute__((always_inline))
190 #else
191 #define RAPIDJSON_FORCEINLINE
192 #endif
193 #endif // RAPIDJSON_FORCEINLINE
195 
197 // RAPIDJSON_ENDIAN
198 #define RAPIDJSON_LITTLEENDIAN 0
199 #define RAPIDJSON_BIGENDIAN 1
200 
201 
214 #ifndef RAPIDJSON_ENDIAN
215 // Detect with GCC 4.6's macro
216 # ifdef __BYTE_ORDER__
217 # if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
218 # define RAPIDJSON_ENDIAN RAPIDJSON_LITTLEENDIAN
219 # elif __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
220 # define RAPIDJSON_ENDIAN RAPIDJSON_BIGENDIAN
221 # else
222 # error Unknown machine endianness detected. User needs to define RAPIDJSON_ENDIAN.
223 # endif // __BYTE_ORDER__
224 // Detect with GLIBC's endian.h
225 # elif defined(__GLIBC__)
226 # include <endian.h>
227 # if (__BYTE_ORDER == __LITTLE_ENDIAN)
228 # define RAPIDJSON_ENDIAN RAPIDJSON_LITTLEENDIAN
229 # elif (__BYTE_ORDER == __BIG_ENDIAN)
230 # define RAPIDJSON_ENDIAN RAPIDJSON_BIGENDIAN
231 # else
232 # error Unknown machine endianness detected. User needs to define RAPIDJSON_ENDIAN.
233 # endif // __GLIBC__
234 // Detect with _LITTLE_ENDIAN and _BIG_ENDIAN macro
235 # elif defined(_LITTLE_ENDIAN) && !defined(_BIG_ENDIAN)
236 # define RAPIDJSON_ENDIAN RAPIDJSON_LITTLEENDIAN
237 # elif defined(_BIG_ENDIAN) && !defined(_LITTLE_ENDIAN)
238 # define RAPIDJSON_ENDIAN RAPIDJSON_BIGENDIAN
239 // Detect with architecture macros
240 # elif defined(__sparc) || defined(__sparc__) || defined(_POWER) || defined(__powerpc__) || defined(__ppc__) || defined(__hpux) || defined(__hppa) || defined(_MIPSEB) || defined(_POWER) || defined(__s390__)
241 # define RAPIDJSON_ENDIAN RAPIDJSON_BIGENDIAN
242 # elif defined(__i386__) || defined(__alpha__) || defined(__ia64) || defined(__ia64__) || defined(_M_IX86) || defined(_M_IA64) || defined(_M_ALPHA) || defined(__amd64) || defined(__amd64__) || defined(_M_AMD64) || defined(__x86_64) || defined(__x86_64__) || defined(_M_X64) || defined(__bfin__)
243 # define RAPIDJSON_ENDIAN RAPIDJSON_LITTLEENDIAN
244 # elif defined(_MSC_VER) && (defined(_M_ARM) || defined(_M_ARM64))
245 # define RAPIDJSON_ENDIAN RAPIDJSON_LITTLEENDIAN
246 # elif defined(RAPIDJSON_DOXYGEN_RUNNING)
247 # define RAPIDJSON_ENDIAN
248 # else
249 # error Unknown machine endianness detected. User needs to define RAPIDJSON_ENDIAN.
250 # endif
251 #endif // RAPIDJSON_ENDIAN
252 
254 // RAPIDJSON_64BIT
255 
257 #ifndef RAPIDJSON_64BIT
258 #if defined(__LP64__) || (defined(__x86_64__) && defined(__ILP32__)) || defined(_WIN64) || defined(__EMSCRIPTEN__)
259 #define RAPIDJSON_64BIT 1
260 #else
261 #define RAPIDJSON_64BIT 0
262 #endif
263 #endif // RAPIDJSON_64BIT
264 
266 // RAPIDJSON_ALIGN
267 
269 
275 #ifndef RAPIDJSON_ALIGN
276 #define RAPIDJSON_ALIGN(x) (((x) + static_cast<size_t>(7u)) & ~static_cast<size_t>(7u))
277 #endif
278 
280 // RAPIDJSON_UINT64_C2
281 
283 
288 #ifndef RAPIDJSON_UINT64_C2
289 #define RAPIDJSON_UINT64_C2(high32, low32) ((static_cast<uint64_t>(high32) << 32) | static_cast<uint64_t>(low32))
290 #endif
291 
293 // RAPIDJSON_48BITPOINTER_OPTIMIZATION
294 
296 
303 #ifndef RAPIDJSON_48BITPOINTER_OPTIMIZATION
304 #if defined(__amd64__) || defined(__amd64) || defined(__x86_64__) || defined(__x86_64) || defined(_M_X64) || defined(_M_AMD64)
305 #define RAPIDJSON_48BITPOINTER_OPTIMIZATION 1
306 #else
307 #define RAPIDJSON_48BITPOINTER_OPTIMIZATION 0
308 #endif
309 #endif // RAPIDJSON_48BITPOINTER_OPTIMIZATION
310 
311 #if RAPIDJSON_48BITPOINTER_OPTIMIZATION == 1
312 #if RAPIDJSON_64BIT != 1
313 #error RAPIDJSON_48BITPOINTER_OPTIMIZATION can only be set to 1 when RAPIDJSON_64BIT=1
314 #endif
315 #define RAPIDJSON_SETPOINTER(type, p, x) (p = reinterpret_cast<type *>((reinterpret_cast<uintptr_t>(p) & static_cast<uintptr_t>(RAPIDJSON_UINT64_C2(0xFFFF0000, 0x00000000))) | reinterpret_cast<uintptr_t>(reinterpret_cast<const void*>(x))))
316 #define RAPIDJSON_GETPOINTER(type, p) (reinterpret_cast<type *>(reinterpret_cast<uintptr_t>(p) & static_cast<uintptr_t>(RAPIDJSON_UINT64_C2(0x0000FFFF, 0xFFFFFFFF))))
317 #else
318 #define RAPIDJSON_SETPOINTER(type, p, x) (p = (x))
319 #define RAPIDJSON_GETPOINTER(type, p) (p)
320 #endif
321 
323 // RAPIDJSON_SSE2/RAPIDJSON_SSE42/RAPIDJSON_NEON/RAPIDJSON_SIMD
324 
351 #if defined(RAPIDJSON_SSE2) || defined(RAPIDJSON_SSE42) \
352  || defined(RAPIDJSON_NEON) || defined(RAPIDJSON_DOXYGEN_RUNNING)
353 #define RAPIDJSON_SIMD
354 #endif
355 
357 // RAPIDJSON_NO_SIZETYPEDEFINE
358 
359 #ifndef RAPIDJSON_NO_SIZETYPEDEFINE
360 
375 #ifdef RAPIDJSON_DOXYGEN_RUNNING
376 #define RAPIDJSON_NO_SIZETYPEDEFINE
377 #endif
380 
384 typedef unsigned SizeType;
386 #endif
387 
388 // always import std::size_t to rapidjson namespace
390 using std::size_t;
392 
394 // RAPIDJSON_ASSERT
395 
397 
404 #ifndef RAPIDJSON_ASSERT
405 #include <cassert>
406 #define RAPIDJSON_ASSERT(x) assert(x)
407 #endif // RAPIDJSON_ASSERT
408 
410 // RAPIDJSON_STATIC_ASSERT
411 
412 // Prefer C++11 static_assert, if available
413 #ifndef RAPIDJSON_STATIC_ASSERT
414 #if __cplusplus >= 201103L || ( defined(_MSC_VER) && _MSC_VER >= 1800 )
415 #define RAPIDJSON_STATIC_ASSERT(x) \
416  static_assert(x, RAPIDJSON_STRINGIFY(x))
417 #endif // C++11
418 #endif // RAPIDJSON_STATIC_ASSERT
419 
420 // Adopt C++03 implementation from boost
421 #ifndef RAPIDJSON_STATIC_ASSERT
422 #ifndef __clang__
423 #endif
426 template <bool x> struct STATIC_ASSERTION_FAILURE;
427 template <> struct STATIC_ASSERTION_FAILURE<true> { enum { value = 1 }; };
428 template <size_t x> struct StaticAssertTest {};
430 
431 #if defined(__GNUC__) || defined(__clang__)
432 #define RAPIDJSON_STATIC_ASSERT_UNUSED_ATTRIBUTE __attribute__((unused))
433 #else
434 #define RAPIDJSON_STATIC_ASSERT_UNUSED_ATTRIBUTE
435 #endif
436 #ifndef __clang__
437 #endif
439 
445 #define RAPIDJSON_STATIC_ASSERT(x) \
446  typedef ::RAPIDJSON_NAMESPACE::StaticAssertTest< \
447  sizeof(::RAPIDJSON_NAMESPACE::STATIC_ASSERTION_FAILURE<bool(x) >)> \
448  RAPIDJSON_JOIN(StaticAssertTypedef, __LINE__) RAPIDJSON_STATIC_ASSERT_UNUSED_ATTRIBUTE
449 #endif // RAPIDJSON_STATIC_ASSERT
450 
452 // RAPIDJSON_LIKELY, RAPIDJSON_UNLIKELY
453 
455 
459 #ifndef RAPIDJSON_LIKELY
460 #if defined(__GNUC__) || defined(__clang__)
461 #define RAPIDJSON_LIKELY(x) __builtin_expect(!!(x), 1)
462 #else
463 #define RAPIDJSON_LIKELY(x) (x)
464 #endif
465 #endif
466 
468 
472 #ifndef RAPIDJSON_UNLIKELY
473 #if defined(__GNUC__) || defined(__clang__)
474 #define RAPIDJSON_UNLIKELY(x) __builtin_expect(!!(x), 0)
475 #else
476 #define RAPIDJSON_UNLIKELY(x) (x)
477 #endif
478 #endif
479 
481 // Helpers
482 
484 
485 #define RAPIDJSON_MULTILINEMACRO_BEGIN do {
486 #define RAPIDJSON_MULTILINEMACRO_END \
487 } while((void)0, 0)
488 
489 // adopted from Boost
490 #define RAPIDJSON_VERSION_CODE(x,y,z) \
491  (((x)*100000) + ((y)*100) + (z))
492 
494 // RAPIDJSON_DIAG_PUSH/POP, RAPIDJSON_DIAG_OFF
495 
496 #if defined(__GNUC__)
497 #define RAPIDJSON_GNUC \
498  RAPIDJSON_VERSION_CODE(__GNUC__,__GNUC_MINOR__,__GNUC_PATCHLEVEL__)
499 #endif
500 
501 #if defined(__clang__) || (defined(RAPIDJSON_GNUC) && RAPIDJSON_GNUC >= RAPIDJSON_VERSION_CODE(4,2,0))
502 
503 #define RAPIDJSON_PRAGMA(x) _Pragma(RAPIDJSON_STRINGIFY(x))
504 #define RAPIDJSON_DIAG_PRAGMA(x) RAPIDJSON_PRAGMA(GCC diagnostic x)
505 #define RAPIDJSON_DIAG_OFF(x) \
506  RAPIDJSON_DIAG_PRAGMA(ignored RAPIDJSON_STRINGIFY(RAPIDJSON_JOIN(-W,x)))
507 
508 // push/pop support in Clang and GCC>=4.6
509 #if defined(__clang__) || (defined(RAPIDJSON_GNUC) && RAPIDJSON_GNUC >= RAPIDJSON_VERSION_CODE(4,6,0))
510 #define RAPIDJSON_DIAG_PUSH RAPIDJSON_DIAG_PRAGMA(push)
511 #define RAPIDJSON_DIAG_POP RAPIDJSON_DIAG_PRAGMA(pop)
512 #else // GCC >= 4.2, < 4.6
513 #define RAPIDJSON_DIAG_PUSH /* ignored */
514 #define RAPIDJSON_DIAG_POP /* ignored */
515 #endif
516 
517 #elif defined(_MSC_VER)
518 
519 // pragma (MSVC specific)
520 #define RAPIDJSON_PRAGMA(x) __pragma(x)
521 #define RAPIDJSON_DIAG_PRAGMA(x) RAPIDJSON_PRAGMA(warning(x))
522 
523 #define RAPIDJSON_DIAG_OFF(x) RAPIDJSON_DIAG_PRAGMA(disable: x)
524 #define RAPIDJSON_DIAG_PUSH RAPIDJSON_DIAG_PRAGMA(push)
525 #define RAPIDJSON_DIAG_POP RAPIDJSON_DIAG_PRAGMA(pop)
526 
527 #else
528 
529 #define RAPIDJSON_DIAG_OFF(x) /* ignored */
530 #define RAPIDJSON_DIAG_PUSH /* ignored */
531 #define RAPIDJSON_DIAG_POP /* ignored */
532 
533 #endif // RAPIDJSON_DIAG_*
534 
536 // C++11 features
537 
538 #ifndef RAPIDJSON_HAS_CXX11_RVALUE_REFS
539 #if defined(__clang__)
540 #if __has_feature(cxx_rvalue_references) && \
541  (defined(_MSC_VER) || defined(_LIBCPP_VERSION) || defined(__GLIBCXX__) && __GLIBCXX__ >= 20080306)
542 #define RAPIDJSON_HAS_CXX11_RVALUE_REFS 1
543 #else
544 #define RAPIDJSON_HAS_CXX11_RVALUE_REFS 0
545 #endif
546 #elif (defined(RAPIDJSON_GNUC) && (RAPIDJSON_GNUC >= RAPIDJSON_VERSION_CODE(4,3,0)) && defined(__GXX_EXPERIMENTAL_CXX0X__)) || \
547  (defined(_MSC_VER) && _MSC_VER >= 1600) || \
548  (defined(__SUNPRO_CC) && __SUNPRO_CC >= 0x5140 && defined(__GXX_EXPERIMENTAL_CXX0X__))
549 
550 #define RAPIDJSON_HAS_CXX11_RVALUE_REFS 1
551 #else
552 #define RAPIDJSON_HAS_CXX11_RVALUE_REFS 0
553 #endif
554 #endif // RAPIDJSON_HAS_CXX11_RVALUE_REFS
555 
556 #ifndef RAPIDJSON_HAS_CXX11_NOEXCEPT
557 #if defined(__clang__)
558 #define RAPIDJSON_HAS_CXX11_NOEXCEPT __has_feature(cxx_noexcept)
559 #elif (defined(RAPIDJSON_GNUC) && (RAPIDJSON_GNUC >= RAPIDJSON_VERSION_CODE(4,6,0)) && defined(__GXX_EXPERIMENTAL_CXX0X__)) || \
560  (defined(_MSC_VER) && _MSC_VER >= 1900) || \
561  (defined(__SUNPRO_CC) && __SUNPRO_CC >= 0x5140 && defined(__GXX_EXPERIMENTAL_CXX0X__))
562 #define RAPIDJSON_HAS_CXX11_NOEXCEPT 1
563 #else
564 #define RAPIDJSON_HAS_CXX11_NOEXCEPT 0
565 #endif
566 #endif
567 #if RAPIDJSON_HAS_CXX11_NOEXCEPT
568 #define RAPIDJSON_NOEXCEPT noexcept
569 #else
570 #define RAPIDJSON_NOEXCEPT /* noexcept */
571 #endif // RAPIDJSON_HAS_CXX11_NOEXCEPT
572 
573 // no automatic detection, yet
574 #ifndef RAPIDJSON_HAS_CXX11_TYPETRAITS
575 #if (defined(_MSC_VER) && _MSC_VER >= 1700)
576 #define RAPIDJSON_HAS_CXX11_TYPETRAITS 1
577 #else
578 #define RAPIDJSON_HAS_CXX11_TYPETRAITS 0
579 #endif
580 #endif
581 
582 #ifndef RAPIDJSON_HAS_CXX11_RANGE_FOR
583 #if defined(__clang__)
584 #define RAPIDJSON_HAS_CXX11_RANGE_FOR __has_feature(cxx_range_for)
585 #elif (defined(RAPIDJSON_GNUC) && (RAPIDJSON_GNUC >= RAPIDJSON_VERSION_CODE(4,6,0)) && defined(__GXX_EXPERIMENTAL_CXX0X__)) || \
586  (defined(_MSC_VER) && _MSC_VER >= 1700) || \
587  (defined(__SUNPRO_CC) && __SUNPRO_CC >= 0x5140 && defined(__GXX_EXPERIMENTAL_CXX0X__))
588 #define RAPIDJSON_HAS_CXX11_RANGE_FOR 1
589 #else
590 #define RAPIDJSON_HAS_CXX11_RANGE_FOR 0
591 #endif
592 #endif // RAPIDJSON_HAS_CXX11_RANGE_FOR
593 
595 
597 
607 // RAPIDJSON_NOEXCEPT_ASSERT
609 
610 #ifdef RAPIDJSON_ASSERT_THROWS
611 #if RAPIDJSON_HAS_CXX11_NOEXCEPT
612 #define RAPIDJSON_NOEXCEPT_ASSERT(x)
613 #else
614 #define RAPIDJSON_NOEXCEPT_ASSERT(x) RAPIDJSON_ASSERT(x)
615 #endif // RAPIDJSON_HAS_CXX11_NOEXCEPT
616 #else
617 #define RAPIDJSON_NOEXCEPT_ASSERT(x) RAPIDJSON_ASSERT(x)
618 #endif // RAPIDJSON_ASSERT_THROWS
619 
621 // new/delete
622 
623 #ifndef RAPIDJSON_NEW
624 #define RAPIDJSON_NEW(TypeName) new TypeName
626 #endif
627 #ifndef RAPIDJSON_DELETE
628 #define RAPIDJSON_DELETE(x) delete x
630 #endif
631 
633 // Type
634 
640 
642 enum Type {
643  kNullType = 0,
645  kTrueType = 2,
650 };
651 
653 
654 #endif // RAPIDJSON_RAPIDJSON_H_
RAPIDJSON_NAMESPACE_BEGIN typedef unsigned SizeType
Size type (for string lengths, array sizes, etc.)
Definition: rapidjson.h:384
object
Definition: rapidjson.h:646
array
Definition: rapidjson.h:647
false
Definition: rapidjson.h:644
#define RAPIDJSON_NAMESPACE_BEGIN
provide custom rapidjson namespace (opening expression)
Definition: rapidjson.h:121
string
Definition: rapidjson.h:648
number
Definition: rapidjson.h:649
#define RAPIDJSON_NAMESPACE_END
provide custom rapidjson namespace (closing expression)
Definition: rapidjson.h:124
const GenericPointer< typename T::ValueType > T2 value
Definition: pointer.h:1282
true
Definition: rapidjson.h:645
Type
Type of JSON value.
Definition: rapidjson.h:642
null
Definition: rapidjson.h:643