sq_detailed_metrics 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (69) hide show
  1. checksums.yaml +7 -0
  2. data/extconf.rb +26 -0
  3. data/include/half.hpp +4575 -0
  4. data/include/msgpack.h +24 -0
  5. data/include/msgpack/fbuffer.h +42 -0
  6. data/include/msgpack/gcc_atomic.h +25 -0
  7. data/include/msgpack/object.h +118 -0
  8. data/include/msgpack/pack.h +174 -0
  9. data/include/msgpack/pack_define.h +18 -0
  10. data/include/msgpack/pack_template.h +952 -0
  11. data/include/msgpack/sbuffer.h +115 -0
  12. data/include/msgpack/sysdep.h +221 -0
  13. data/include/msgpack/timestamp.h +58 -0
  14. data/include/msgpack/unpack.h +281 -0
  15. data/include/msgpack/unpack_define.h +89 -0
  16. data/include/msgpack/unpack_template.h +471 -0
  17. data/include/msgpack/util.h +15 -0
  18. data/include/msgpack/version.h +38 -0
  19. data/include/msgpack/version_master.h +3 -0
  20. data/include/msgpack/vrefbuffer.h +144 -0
  21. data/include/msgpack/zbuffer.h +205 -0
  22. data/include/msgpack/zone.h +163 -0
  23. data/include/rapidjson/allocators.h +271 -0
  24. data/include/rapidjson/document.h +2575 -0
  25. data/include/rapidjson/encodedstream.h +299 -0
  26. data/include/rapidjson/encodings.h +716 -0
  27. data/include/rapidjson/error/en.h +74 -0
  28. data/include/rapidjson/error/error.h +155 -0
  29. data/include/rapidjson/filereadstream.h +99 -0
  30. data/include/rapidjson/filewritestream.h +104 -0
  31. data/include/rapidjson/fwd.h +151 -0
  32. data/include/rapidjson/internal/biginteger.h +290 -0
  33. data/include/rapidjson/internal/diyfp.h +258 -0
  34. data/include/rapidjson/internal/dtoa.h +245 -0
  35. data/include/rapidjson/internal/ieee754.h +78 -0
  36. data/include/rapidjson/internal/itoa.h +304 -0
  37. data/include/rapidjson/internal/meta.h +181 -0
  38. data/include/rapidjson/internal/pow10.h +55 -0
  39. data/include/rapidjson/internal/regex.h +701 -0
  40. data/include/rapidjson/internal/stack.h +230 -0
  41. data/include/rapidjson/internal/strfunc.h +55 -0
  42. data/include/rapidjson/internal/strtod.h +269 -0
  43. data/include/rapidjson/internal/swap.h +46 -0
  44. data/include/rapidjson/istreamwrapper.h +115 -0
  45. data/include/rapidjson/memorybuffer.h +70 -0
  46. data/include/rapidjson/memorystream.h +71 -0
  47. data/include/rapidjson/msinttypes/inttypes.h +316 -0
  48. data/include/rapidjson/msinttypes/stdint.h +300 -0
  49. data/include/rapidjson/ostreamwrapper.h +81 -0
  50. data/include/rapidjson/pointer.h +1358 -0
  51. data/include/rapidjson/prettywriter.h +255 -0
  52. data/include/rapidjson/rapidjson.h +615 -0
  53. data/include/rapidjson/reader.h +1879 -0
  54. data/include/rapidjson/schema.h +2006 -0
  55. data/include/rapidjson/stream.h +179 -0
  56. data/include/rapidjson/stringbuffer.h +117 -0
  57. data/include/rapidjson/writer.h +610 -0
  58. data/include/xxhash.h +328 -0
  59. data/json_conv.cpp +284 -0
  60. data/json_conv.hpp +17 -0
  61. data/metrics.cpp +239 -0
  62. data/metrics.hpp +84 -0
  63. data/msgpack/objectc.c +482 -0
  64. data/msgpack/unpack.c +703 -0
  65. data/msgpack/version.c +22 -0
  66. data/msgpack/vrefbuffer.c +250 -0
  67. data/msgpack/zone.c +222 -0
  68. data/sq_detailed_metrics.cpp +248 -0
  69. metadata +199 -0
@@ -0,0 +1,255 @@
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_PRETTYWRITER_H_
16
+ #define RAPIDJSON_PRETTYWRITER_H_
17
+
18
+ #include "writer.h"
19
+
20
+ #ifdef __GNUC__
21
+ RAPIDJSON_DIAG_PUSH
22
+ RAPIDJSON_DIAG_OFF(effc++)
23
+ #endif
24
+
25
+ RAPIDJSON_NAMESPACE_BEGIN
26
+
27
+ //! Combination of PrettyWriter format flags.
28
+ /*! \see PrettyWriter::SetFormatOptions
29
+ */
30
+ enum PrettyFormatOptions {
31
+ kFormatDefault = 0, //!< Default pretty formatting.
32
+ kFormatSingleLineArray = 1 //!< Format arrays on a single line.
33
+ };
34
+
35
+ //! Writer with indentation and spacing.
36
+ /*!
37
+ \tparam OutputStream Type of ouptut os.
38
+ \tparam SourceEncoding Encoding of source string.
39
+ \tparam TargetEncoding Encoding of output stream.
40
+ \tparam StackAllocator Type of allocator for allocating memory of stack.
41
+ */
42
+ template<typename OutputStream, typename SourceEncoding = UTF8<>, typename TargetEncoding = UTF8<>, typename StackAllocator = CrtAllocator, unsigned writeFlags = kWriteDefaultFlags>
43
+ class PrettyWriter : public Writer<OutputStream, SourceEncoding, TargetEncoding, StackAllocator, writeFlags> {
44
+ public:
45
+ typedef Writer<OutputStream, SourceEncoding, TargetEncoding, StackAllocator> Base;
46
+ typedef typename Base::Ch Ch;
47
+
48
+ //! Constructor
49
+ /*! \param os Output stream.
50
+ \param allocator User supplied allocator. If it is null, it will create a private one.
51
+ \param levelDepth Initial capacity of stack.
52
+ */
53
+ explicit PrettyWriter(OutputStream& os, StackAllocator* allocator = 0, size_t levelDepth = Base::kDefaultLevelDepth) :
54
+ Base(os, allocator, levelDepth), indentChar_(' '), indentCharCount_(4), formatOptions_(kFormatDefault) {}
55
+
56
+
57
+ explicit PrettyWriter(StackAllocator* allocator = 0, size_t levelDepth = Base::kDefaultLevelDepth) :
58
+ Base(allocator, levelDepth), indentChar_(' '), indentCharCount_(4) {}
59
+
60
+ //! Set custom indentation.
61
+ /*! \param indentChar Character for indentation. Must be whitespace character (' ', '\\t', '\\n', '\\r').
62
+ \param indentCharCount Number of indent characters for each indentation level.
63
+ \note The default indentation is 4 spaces.
64
+ */
65
+ PrettyWriter& SetIndent(Ch indentChar, unsigned indentCharCount) {
66
+ RAPIDJSON_ASSERT(indentChar == ' ' || indentChar == '\t' || indentChar == '\n' || indentChar == '\r');
67
+ indentChar_ = indentChar;
68
+ indentCharCount_ = indentCharCount;
69
+ return *this;
70
+ }
71
+
72
+ //! Set pretty writer formatting options.
73
+ /*! \param options Formatting options.
74
+ */
75
+ PrettyWriter& SetFormatOptions(PrettyFormatOptions options) {
76
+ formatOptions_ = options;
77
+ return *this;
78
+ }
79
+
80
+ /*! @name Implementation of Handler
81
+ \see Handler
82
+ */
83
+ //@{
84
+
85
+ bool Null() { PrettyPrefix(kNullType); return Base::WriteNull(); }
86
+ bool Bool(bool b) { PrettyPrefix(b ? kTrueType : kFalseType); return Base::WriteBool(b); }
87
+ bool Int(int i) { PrettyPrefix(kNumberType); return Base::WriteInt(i); }
88
+ bool Uint(unsigned u) { PrettyPrefix(kNumberType); return Base::WriteUint(u); }
89
+ bool Int64(int64_t i64) { PrettyPrefix(kNumberType); return Base::WriteInt64(i64); }
90
+ bool Uint64(uint64_t u64) { PrettyPrefix(kNumberType); return Base::WriteUint64(u64); }
91
+ bool Double(double d) { PrettyPrefix(kNumberType); return Base::WriteDouble(d); }
92
+
93
+ bool RawNumber(const Ch* str, SizeType length, bool copy = false) {
94
+ (void)copy;
95
+ PrettyPrefix(kNumberType);
96
+ return Base::WriteString(str, length);
97
+ }
98
+
99
+ bool String(const Ch* str, SizeType length, bool copy = false) {
100
+ (void)copy;
101
+ PrettyPrefix(kStringType);
102
+ return Base::WriteString(str, length);
103
+ }
104
+
105
+ #if RAPIDJSON_HAS_STDSTRING
106
+ bool String(const std::basic_string<Ch>& str) {
107
+ return String(str.data(), SizeType(str.size()));
108
+ }
109
+ #endif
110
+
111
+ bool StartObject() {
112
+ PrettyPrefix(kObjectType);
113
+ new (Base::level_stack_.template Push<typename Base::Level>()) typename Base::Level(false);
114
+ return Base::WriteStartObject();
115
+ }
116
+
117
+ bool Key(const Ch* str, SizeType length, bool copy = false) { return String(str, length, copy); }
118
+
119
+ #if RAPIDJSON_HAS_STDSTRING
120
+ bool Key(const std::basic_string<Ch>& str) {
121
+ return Key(str.data(), SizeType(str.size()));
122
+ }
123
+ #endif
124
+
125
+ bool EndObject(SizeType memberCount = 0) {
126
+ (void)memberCount;
127
+ RAPIDJSON_ASSERT(Base::level_stack_.GetSize() >= sizeof(typename Base::Level));
128
+ RAPIDJSON_ASSERT(!Base::level_stack_.template Top<typename Base::Level>()->inArray);
129
+ bool empty = Base::level_stack_.template Pop<typename Base::Level>(1)->valueCount == 0;
130
+
131
+ if (!empty) {
132
+ Base::os_->Put('\n');
133
+ WriteIndent();
134
+ }
135
+ bool ret = Base::WriteEndObject();
136
+ (void)ret;
137
+ RAPIDJSON_ASSERT(ret == true);
138
+ if (Base::level_stack_.Empty()) // end of json text
139
+ Base::os_->Flush();
140
+ return true;
141
+ }
142
+
143
+ bool StartArray() {
144
+ PrettyPrefix(kArrayType);
145
+ new (Base::level_stack_.template Push<typename Base::Level>()) typename Base::Level(true);
146
+ return Base::WriteStartArray();
147
+ }
148
+
149
+ bool EndArray(SizeType memberCount = 0) {
150
+ (void)memberCount;
151
+ RAPIDJSON_ASSERT(Base::level_stack_.GetSize() >= sizeof(typename Base::Level));
152
+ RAPIDJSON_ASSERT(Base::level_stack_.template Top<typename Base::Level>()->inArray);
153
+ bool empty = Base::level_stack_.template Pop<typename Base::Level>(1)->valueCount == 0;
154
+
155
+ if (!empty && !(formatOptions_ & kFormatSingleLineArray)) {
156
+ Base::os_->Put('\n');
157
+ WriteIndent();
158
+ }
159
+ bool ret = Base::WriteEndArray();
160
+ (void)ret;
161
+ RAPIDJSON_ASSERT(ret == true);
162
+ if (Base::level_stack_.Empty()) // end of json text
163
+ Base::os_->Flush();
164
+ return true;
165
+ }
166
+
167
+ //@}
168
+
169
+ /*! @name Convenience extensions */
170
+ //@{
171
+
172
+ //! Simpler but slower overload.
173
+ bool String(const Ch* str) { return String(str, internal::StrLen(str)); }
174
+ bool Key(const Ch* str) { return Key(str, internal::StrLen(str)); }
175
+
176
+ //@}
177
+
178
+ //! Write a raw JSON value.
179
+ /*!
180
+ For user to write a stringified JSON as a value.
181
+
182
+ \param json A well-formed JSON value. It should not contain null character within [0, length - 1] range.
183
+ \param length Length of the json.
184
+ \param type Type of the root of json.
185
+ \note When using PrettyWriter::RawValue(), the result json may not be indented correctly.
186
+ */
187
+ bool RawValue(const Ch* json, size_t length, Type type) { PrettyPrefix(type); return Base::WriteRawValue(json, length); }
188
+
189
+ protected:
190
+ void PrettyPrefix(Type type) {
191
+ (void)type;
192
+ if (Base::level_stack_.GetSize() != 0) { // this value is not at root
193
+ typename Base::Level* level = Base::level_stack_.template Top<typename Base::Level>();
194
+
195
+ if (level->inArray) {
196
+ if (level->valueCount > 0) {
197
+ Base::os_->Put(','); // add comma if it is not the first element in array
198
+ if (formatOptions_ & kFormatSingleLineArray)
199
+ Base::os_->Put(' ');
200
+ }
201
+
202
+ if (!(formatOptions_ & kFormatSingleLineArray)) {
203
+ Base::os_->Put('\n');
204
+ WriteIndent();
205
+ }
206
+ }
207
+ else { // in object
208
+ if (level->valueCount > 0) {
209
+ if (level->valueCount % 2 == 0) {
210
+ Base::os_->Put(',');
211
+ Base::os_->Put('\n');
212
+ }
213
+ else {
214
+ Base::os_->Put(':');
215
+ Base::os_->Put(' ');
216
+ }
217
+ }
218
+ else
219
+ Base::os_->Put('\n');
220
+
221
+ if (level->valueCount % 2 == 0)
222
+ WriteIndent();
223
+ }
224
+ if (!level->inArray && level->valueCount % 2 == 0)
225
+ RAPIDJSON_ASSERT(type == kStringType); // if it's in object, then even number should be a name
226
+ level->valueCount++;
227
+ }
228
+ else {
229
+ RAPIDJSON_ASSERT(!Base::hasRoot_); // Should only has one and only one root.
230
+ Base::hasRoot_ = true;
231
+ }
232
+ }
233
+
234
+ void WriteIndent() {
235
+ size_t count = (Base::level_stack_.GetSize() / sizeof(typename Base::Level)) * indentCharCount_;
236
+ PutN(*Base::os_, static_cast<typename TargetEncoding::Ch>(indentChar_), count);
237
+ }
238
+
239
+ Ch indentChar_;
240
+ unsigned indentCharCount_;
241
+ PrettyFormatOptions formatOptions_;
242
+
243
+ private:
244
+ // Prohibit copy constructor & assignment operator.
245
+ PrettyWriter(const PrettyWriter&);
246
+ PrettyWriter& operator=(const PrettyWriter&);
247
+ };
248
+
249
+ RAPIDJSON_NAMESPACE_END
250
+
251
+ #ifdef __GNUC__
252
+ RAPIDJSON_DIAG_POP
253
+ #endif
254
+
255
+ #endif // RAPIDJSON_RAPIDJSON_H_
@@ -0,0 +1,615 @@
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
+
18
+ /*!\file rapidjson.h
19
+ \brief common definitions and configuration
20
+
21
+ \see RAPIDJSON_CONFIG
22
+ */
23
+
24
+ /*! \defgroup RAPIDJSON_CONFIG RapidJSON configuration
25
+ \brief Configuration macros for library features
26
+
27
+ Some RapidJSON features are configurable to adapt the library to a wide
28
+ variety of platforms, environments and usage scenarios. Most of the
29
+ features can be configured in terms of overriden or predefined
30
+ preprocessor macros at compile-time.
31
+
32
+ Some additional customization is available in the \ref RAPIDJSON_ERRORS APIs.
33
+
34
+ \note These macros should be given on the compiler command-line
35
+ (where applicable) to avoid inconsistent values when compiling
36
+ different translation units of a single application.
37
+ */
38
+
39
+ #include <cstdlib> // malloc(), realloc(), free(), size_t
40
+ #include <cstring> // memset(), memcpy(), memmove(), memcmp()
41
+
42
+ ///////////////////////////////////////////////////////////////////////////////
43
+ // RAPIDJSON_VERSION_STRING
44
+ //
45
+ // ALWAYS synchronize the following 3 macros with corresponding variables in /CMakeLists.txt.
46
+ //
47
+
48
+ //!@cond RAPIDJSON_HIDDEN_FROM_DOXYGEN
49
+ // token stringification
50
+ #define RAPIDJSON_STRINGIFY(x) RAPIDJSON_DO_STRINGIFY(x)
51
+ #define RAPIDJSON_DO_STRINGIFY(x) #x
52
+ //!@endcond
53
+
54
+ /*! \def RAPIDJSON_MAJOR_VERSION
55
+ \ingroup RAPIDJSON_CONFIG
56
+ \brief Major version of RapidJSON in integer.
57
+ */
58
+ /*! \def RAPIDJSON_MINOR_VERSION
59
+ \ingroup RAPIDJSON_CONFIG
60
+ \brief Minor version of RapidJSON in integer.
61
+ */
62
+ /*! \def RAPIDJSON_PATCH_VERSION
63
+ \ingroup RAPIDJSON_CONFIG
64
+ \brief Patch version of RapidJSON in integer.
65
+ */
66
+ /*! \def RAPIDJSON_VERSION_STRING
67
+ \ingroup RAPIDJSON_CONFIG
68
+ \brief Version of RapidJSON in "<major>.<minor>.<patch>" string format.
69
+ */
70
+ #define RAPIDJSON_MAJOR_VERSION 1
71
+ #define RAPIDJSON_MINOR_VERSION 1
72
+ #define RAPIDJSON_PATCH_VERSION 0
73
+ #define RAPIDJSON_VERSION_STRING \
74
+ RAPIDJSON_STRINGIFY(RAPIDJSON_MAJOR_VERSION.RAPIDJSON_MINOR_VERSION.RAPIDJSON_PATCH_VERSION)
75
+
76
+ ///////////////////////////////////////////////////////////////////////////////
77
+ // RAPIDJSON_NAMESPACE_(BEGIN|END)
78
+ /*! \def RAPIDJSON_NAMESPACE
79
+ \ingroup RAPIDJSON_CONFIG
80
+ \brief provide custom rapidjson namespace
81
+
82
+ In order to avoid symbol clashes and/or "One Definition Rule" errors
83
+ between multiple inclusions of (different versions of) RapidJSON in
84
+ a single binary, users can customize the name of the main RapidJSON
85
+ namespace.
86
+
87
+ In case of a single nesting level, defining \c RAPIDJSON_NAMESPACE
88
+ to a custom name (e.g. \c MyRapidJSON) is sufficient. If multiple
89
+ levels are needed, both \ref RAPIDJSON_NAMESPACE_BEGIN and \ref
90
+ RAPIDJSON_NAMESPACE_END need to be defined as well:
91
+
92
+ \code
93
+ // in some .cpp file
94
+ #define RAPIDJSON_NAMESPACE my::rapidjson
95
+ #define RAPIDJSON_NAMESPACE_BEGIN namespace my { namespace rapidjson {
96
+ #define RAPIDJSON_NAMESPACE_END } }
97
+ #include "rapidjson/..."
98
+ \endcode
99
+
100
+ \see rapidjson
101
+ */
102
+ /*! \def RAPIDJSON_NAMESPACE_BEGIN
103
+ \ingroup RAPIDJSON_CONFIG
104
+ \brief provide custom rapidjson namespace (opening expression)
105
+ \see RAPIDJSON_NAMESPACE
106
+ */
107
+ /*! \def RAPIDJSON_NAMESPACE_END
108
+ \ingroup RAPIDJSON_CONFIG
109
+ \brief provide custom rapidjson namespace (closing expression)
110
+ \see RAPIDJSON_NAMESPACE
111
+ */
112
+ #ifndef RAPIDJSON_NAMESPACE
113
+ #define RAPIDJSON_NAMESPACE rapidjson
114
+ #endif
115
+ #ifndef RAPIDJSON_NAMESPACE_BEGIN
116
+ #define RAPIDJSON_NAMESPACE_BEGIN namespace RAPIDJSON_NAMESPACE {
117
+ #endif
118
+ #ifndef RAPIDJSON_NAMESPACE_END
119
+ #define RAPIDJSON_NAMESPACE_END }
120
+ #endif
121
+
122
+ ///////////////////////////////////////////////////////////////////////////////
123
+ // RAPIDJSON_HAS_STDSTRING
124
+
125
+ #ifndef RAPIDJSON_HAS_STDSTRING
126
+ #ifdef RAPIDJSON_DOXYGEN_RUNNING
127
+ #define RAPIDJSON_HAS_STDSTRING 1 // force generation of documentation
128
+ #else
129
+ #define RAPIDJSON_HAS_STDSTRING 0 // no std::string support by default
130
+ #endif
131
+ /*! \def RAPIDJSON_HAS_STDSTRING
132
+ \ingroup RAPIDJSON_CONFIG
133
+ \brief Enable RapidJSON support for \c std::string
134
+
135
+ By defining this preprocessor symbol to \c 1, several convenience functions for using
136
+ \ref rapidjson::GenericValue with \c std::string are enabled, especially
137
+ for construction and comparison.
138
+
139
+ \hideinitializer
140
+ */
141
+ #endif // !defined(RAPIDJSON_HAS_STDSTRING)
142
+
143
+ #if RAPIDJSON_HAS_STDSTRING
144
+ #include <string>
145
+ #endif // RAPIDJSON_HAS_STDSTRING
146
+
147
+ ///////////////////////////////////////////////////////////////////////////////
148
+ // RAPIDJSON_NO_INT64DEFINE
149
+
150
+ /*! \def RAPIDJSON_NO_INT64DEFINE
151
+ \ingroup RAPIDJSON_CONFIG
152
+ \brief Use external 64-bit integer types.
153
+
154
+ RapidJSON requires the 64-bit integer types \c int64_t and \c uint64_t types
155
+ to be available at global scope.
156
+
157
+ If users have their own definition, define RAPIDJSON_NO_INT64DEFINE to
158
+ prevent RapidJSON from defining its own types.
159
+ */
160
+ #ifndef RAPIDJSON_NO_INT64DEFINE
161
+ //!@cond RAPIDJSON_HIDDEN_FROM_DOXYGEN
162
+ #if defined(_MSC_VER) && (_MSC_VER < 1800) // Visual Studio 2013
163
+ #include "msinttypes/stdint.h"
164
+ #include "msinttypes/inttypes.h"
165
+ #else
166
+ // Other compilers should have this.
167
+ #include <stdint.h>
168
+ #include <inttypes.h>
169
+ #endif
170
+ //!@endcond
171
+ #ifdef RAPIDJSON_DOXYGEN_RUNNING
172
+ #define RAPIDJSON_NO_INT64DEFINE
173
+ #endif
174
+ #endif // RAPIDJSON_NO_INT64TYPEDEF
175
+
176
+ ///////////////////////////////////////////////////////////////////////////////
177
+ // RAPIDJSON_FORCEINLINE
178
+
179
+ #ifndef RAPIDJSON_FORCEINLINE
180
+ //!@cond RAPIDJSON_HIDDEN_FROM_DOXYGEN
181
+ #if defined(_MSC_VER) && defined(NDEBUG)
182
+ #define RAPIDJSON_FORCEINLINE __forceinline
183
+ #elif defined(__GNUC__) && __GNUC__ >= 4 && defined(NDEBUG)
184
+ #define RAPIDJSON_FORCEINLINE __attribute__((always_inline))
185
+ #else
186
+ #define RAPIDJSON_FORCEINLINE
187
+ #endif
188
+ //!@endcond
189
+ #endif // RAPIDJSON_FORCEINLINE
190
+
191
+ ///////////////////////////////////////////////////////////////////////////////
192
+ // RAPIDJSON_ENDIAN
193
+ #define RAPIDJSON_LITTLEENDIAN 0 //!< Little endian machine
194
+ #define RAPIDJSON_BIGENDIAN 1 //!< Big endian machine
195
+
196
+ //! Endianness of the machine.
197
+ /*!
198
+ \def RAPIDJSON_ENDIAN
199
+ \ingroup RAPIDJSON_CONFIG
200
+
201
+ GCC 4.6 provided macro for detecting endianness of the target machine. But other
202
+ compilers may not have this. User can define RAPIDJSON_ENDIAN to either
203
+ \ref RAPIDJSON_LITTLEENDIAN or \ref RAPIDJSON_BIGENDIAN.
204
+
205
+ Default detection implemented with reference to
206
+ \li https://gcc.gnu.org/onlinedocs/gcc-4.6.0/cpp/Common-Predefined-Macros.html
207
+ \li http://www.boost.org/doc/libs/1_42_0/boost/detail/endian.hpp
208
+ */
209
+ #ifndef RAPIDJSON_ENDIAN
210
+ // Detect with GCC 4.6's macro
211
+ # ifdef __BYTE_ORDER__
212
+ # if __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__
213
+ # define RAPIDJSON_ENDIAN RAPIDJSON_LITTLEENDIAN
214
+ # elif __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__
215
+ # define RAPIDJSON_ENDIAN RAPIDJSON_BIGENDIAN
216
+ # else
217
+ # error Unknown machine endianess detected. User needs to define RAPIDJSON_ENDIAN.
218
+ # endif // __BYTE_ORDER__
219
+ // Detect with GLIBC's endian.h
220
+ # elif defined(__GLIBC__)
221
+ # include <endian.h>
222
+ # if (__BYTE_ORDER == __LITTLE_ENDIAN)
223
+ # define RAPIDJSON_ENDIAN RAPIDJSON_LITTLEENDIAN
224
+ # elif (__BYTE_ORDER == __BIG_ENDIAN)
225
+ # define RAPIDJSON_ENDIAN RAPIDJSON_BIGENDIAN
226
+ # else
227
+ # error Unknown machine endianess detected. User needs to define RAPIDJSON_ENDIAN.
228
+ # endif // __GLIBC__
229
+ // Detect with _LITTLE_ENDIAN and _BIG_ENDIAN macro
230
+ # elif defined(_LITTLE_ENDIAN) && !defined(_BIG_ENDIAN)
231
+ # define RAPIDJSON_ENDIAN RAPIDJSON_LITTLEENDIAN
232
+ # elif defined(_BIG_ENDIAN) && !defined(_LITTLE_ENDIAN)
233
+ # define RAPIDJSON_ENDIAN RAPIDJSON_BIGENDIAN
234
+ // Detect with architecture macros
235
+ # elif defined(__sparc) || defined(__sparc__) || defined(_POWER) || defined(__powerpc__) || defined(__ppc__) || defined(__hpux) || defined(__hppa) || defined(_MIPSEB) || defined(_POWER) || defined(__s390__)
236
+ # define RAPIDJSON_ENDIAN RAPIDJSON_BIGENDIAN
237
+ # 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__)
238
+ # define RAPIDJSON_ENDIAN RAPIDJSON_LITTLEENDIAN
239
+ # elif defined(_MSC_VER) && defined(_M_ARM)
240
+ # define RAPIDJSON_ENDIAN RAPIDJSON_LITTLEENDIAN
241
+ # elif defined(RAPIDJSON_DOXYGEN_RUNNING)
242
+ # define RAPIDJSON_ENDIAN
243
+ # else
244
+ # error Unknown machine endianess detected. User needs to define RAPIDJSON_ENDIAN.
245
+ # endif
246
+ #endif // RAPIDJSON_ENDIAN
247
+
248
+ ///////////////////////////////////////////////////////////////////////////////
249
+ // RAPIDJSON_64BIT
250
+
251
+ //! Whether using 64-bit architecture
252
+ #ifndef RAPIDJSON_64BIT
253
+ #if defined(__LP64__) || (defined(__x86_64__) && defined(__ILP32__)) || defined(_WIN64) || defined(__EMSCRIPTEN__)
254
+ #define RAPIDJSON_64BIT 1
255
+ #else
256
+ #define RAPIDJSON_64BIT 0
257
+ #endif
258
+ #endif // RAPIDJSON_64BIT
259
+
260
+ ///////////////////////////////////////////////////////////////////////////////
261
+ // RAPIDJSON_ALIGN
262
+
263
+ //! Data alignment of the machine.
264
+ /*! \ingroup RAPIDJSON_CONFIG
265
+ \param x pointer to align
266
+
267
+ Some machines require strict data alignment. Currently the default uses 4 bytes
268
+ alignment on 32-bit platforms and 8 bytes alignment for 64-bit platforms.
269
+ User can customize by defining the RAPIDJSON_ALIGN function macro.
270
+ */
271
+ #ifndef RAPIDJSON_ALIGN
272
+ #if RAPIDJSON_64BIT == 1
273
+ #define RAPIDJSON_ALIGN(x) (((x) + static_cast<uint64_t>(7u)) & ~static_cast<uint64_t>(7u))
274
+ #else
275
+ #define RAPIDJSON_ALIGN(x) (((x) + 3u) & ~3u)
276
+ #endif
277
+ #endif
278
+
279
+ ///////////////////////////////////////////////////////////////////////////////
280
+ // RAPIDJSON_UINT64_C2
281
+
282
+ //! Construct a 64-bit literal by a pair of 32-bit integer.
283
+ /*!
284
+ 64-bit literal with or without ULL suffix is prone to compiler warnings.
285
+ UINT64_C() is C macro which cause compilation problems.
286
+ Use this macro to define 64-bit constants by a pair of 32-bit integer.
287
+ */
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
+
292
+ ///////////////////////////////////////////////////////////////////////////////
293
+ // RAPIDJSON_48BITPOINTER_OPTIMIZATION
294
+
295
+ //! Use only lower 48-bit address for some pointers.
296
+ /*!
297
+ \ingroup RAPIDJSON_CONFIG
298
+
299
+ This optimization uses the fact that current X86-64 architecture only implement lower 48-bit virtual address.
300
+ The higher 16-bit can be used for storing other data.
301
+ \c GenericValue uses this optimization to reduce its size form 24 bytes to 16 bytes in 64-bit architecture.
302
+ */
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
+
322
+ ///////////////////////////////////////////////////////////////////////////////
323
+ // RAPIDJSON_SSE2/RAPIDJSON_SSE42/RAPIDJSON_SIMD
324
+
325
+ /*! \def RAPIDJSON_SIMD
326
+ \ingroup RAPIDJSON_CONFIG
327
+ \brief Enable SSE2/SSE4.2 optimization.
328
+
329
+ RapidJSON supports optimized implementations for some parsing operations
330
+ based on the SSE2 or SSE4.2 SIMD extensions on modern Intel-compatible
331
+ processors.
332
+
333
+ To enable these optimizations, two different symbols can be defined;
334
+ \code
335
+ // Enable SSE2 optimization.
336
+ #define RAPIDJSON_SSE2
337
+
338
+ // Enable SSE4.2 optimization.
339
+ #define RAPIDJSON_SSE42
340
+ \endcode
341
+
342
+ \c RAPIDJSON_SSE42 takes precedence, if both are defined.
343
+
344
+ If any of these symbols is defined, RapidJSON defines the macro
345
+ \c RAPIDJSON_SIMD to indicate the availability of the optimized code.
346
+ */
347
+ #if defined(RAPIDJSON_SSE2) || defined(RAPIDJSON_SSE42) \
348
+ || defined(RAPIDJSON_DOXYGEN_RUNNING)
349
+ #define RAPIDJSON_SIMD
350
+ #endif
351
+
352
+ ///////////////////////////////////////////////////////////////////////////////
353
+ // RAPIDJSON_NO_SIZETYPEDEFINE
354
+
355
+ #ifndef RAPIDJSON_NO_SIZETYPEDEFINE
356
+ /*! \def RAPIDJSON_NO_SIZETYPEDEFINE
357
+ \ingroup RAPIDJSON_CONFIG
358
+ \brief User-provided \c SizeType definition.
359
+
360
+ In order to avoid using 32-bit size types for indexing strings and arrays,
361
+ define this preprocessor symbol and provide the type rapidjson::SizeType
362
+ before including RapidJSON:
363
+ \code
364
+ #define RAPIDJSON_NO_SIZETYPEDEFINE
365
+ namespace rapidjson { typedef ::std::size_t SizeType; }
366
+ #include "rapidjson/..."
367
+ \endcode
368
+
369
+ \see rapidjson::SizeType
370
+ */
371
+ #ifdef RAPIDJSON_DOXYGEN_RUNNING
372
+ #define RAPIDJSON_NO_SIZETYPEDEFINE
373
+ #endif
374
+ RAPIDJSON_NAMESPACE_BEGIN
375
+ //! Size type (for string lengths, array sizes, etc.)
376
+ /*! RapidJSON uses 32-bit array/string indices even on 64-bit platforms,
377
+ instead of using \c size_t. Users may override the SizeType by defining
378
+ \ref RAPIDJSON_NO_SIZETYPEDEFINE.
379
+ */
380
+ typedef unsigned SizeType;
381
+ RAPIDJSON_NAMESPACE_END
382
+ #endif
383
+
384
+ // always import std::size_t to rapidjson namespace
385
+ RAPIDJSON_NAMESPACE_BEGIN
386
+ using std::size_t;
387
+ RAPIDJSON_NAMESPACE_END
388
+
389
+ ///////////////////////////////////////////////////////////////////////////////
390
+ // RAPIDJSON_ASSERT
391
+
392
+ //! Assertion.
393
+ /*! \ingroup RAPIDJSON_CONFIG
394
+ By default, rapidjson uses C \c assert() for internal assertions.
395
+ User can override it by defining RAPIDJSON_ASSERT(x) macro.
396
+
397
+ \note Parsing errors are handled and can be customized by the
398
+ \ref RAPIDJSON_ERRORS APIs.
399
+ */
400
+ #ifndef RAPIDJSON_ASSERT
401
+ #include <cassert>
402
+ #define RAPIDJSON_ASSERT(x) assert(x)
403
+ #endif // RAPIDJSON_ASSERT
404
+
405
+ ///////////////////////////////////////////////////////////////////////////////
406
+ // RAPIDJSON_STATIC_ASSERT
407
+
408
+ // Adopt from boost
409
+ #ifndef RAPIDJSON_STATIC_ASSERT
410
+ #ifndef __clang__
411
+ //!@cond RAPIDJSON_HIDDEN_FROM_DOXYGEN
412
+ #endif
413
+ RAPIDJSON_NAMESPACE_BEGIN
414
+ template <bool x> struct STATIC_ASSERTION_FAILURE;
415
+ template <> struct STATIC_ASSERTION_FAILURE<true> { enum { value = 1 }; };
416
+ template<int x> struct StaticAssertTest {};
417
+ RAPIDJSON_NAMESPACE_END
418
+
419
+ #define RAPIDJSON_JOIN(X, Y) RAPIDJSON_DO_JOIN(X, Y)
420
+ #define RAPIDJSON_DO_JOIN(X, Y) RAPIDJSON_DO_JOIN2(X, Y)
421
+ #define RAPIDJSON_DO_JOIN2(X, Y) X##Y
422
+
423
+ #if defined(__GNUC__)
424
+ #define RAPIDJSON_STATIC_ASSERT_UNUSED_ATTRIBUTE __attribute__((unused))
425
+ #else
426
+ #define RAPIDJSON_STATIC_ASSERT_UNUSED_ATTRIBUTE
427
+ #endif
428
+ #ifndef __clang__
429
+ //!@endcond
430
+ #endif
431
+
432
+ /*! \def RAPIDJSON_STATIC_ASSERT
433
+ \brief (Internal) macro to check for conditions at compile-time
434
+ \param x compile-time condition
435
+ \hideinitializer
436
+ */
437
+ #define RAPIDJSON_STATIC_ASSERT(x) \
438
+ typedef ::RAPIDJSON_NAMESPACE::StaticAssertTest< \
439
+ sizeof(::RAPIDJSON_NAMESPACE::STATIC_ASSERTION_FAILURE<bool(x) >)> \
440
+ RAPIDJSON_JOIN(StaticAssertTypedef, __LINE__) RAPIDJSON_STATIC_ASSERT_UNUSED_ATTRIBUTE
441
+ #endif
442
+
443
+ ///////////////////////////////////////////////////////////////////////////////
444
+ // RAPIDJSON_LIKELY, RAPIDJSON_UNLIKELY
445
+
446
+ //! Compiler branching hint for expression with high probability to be true.
447
+ /*!
448
+ \ingroup RAPIDJSON_CONFIG
449
+ \param x Boolean expression likely to be true.
450
+ */
451
+ #ifndef RAPIDJSON_LIKELY
452
+ #if defined(__GNUC__) || defined(__clang__)
453
+ #define RAPIDJSON_LIKELY(x) __builtin_expect(!!(x), 1)
454
+ #else
455
+ #define RAPIDJSON_LIKELY(x) (x)
456
+ #endif
457
+ #endif
458
+
459
+ //! Compiler branching hint for expression with low probability to be true.
460
+ /*!
461
+ \ingroup RAPIDJSON_CONFIG
462
+ \param x Boolean expression unlikely to be true.
463
+ */
464
+ #ifndef RAPIDJSON_UNLIKELY
465
+ #if defined(__GNUC__) || defined(__clang__)
466
+ #define RAPIDJSON_UNLIKELY(x) __builtin_expect(!!(x), 0)
467
+ #else
468
+ #define RAPIDJSON_UNLIKELY(x) (x)
469
+ #endif
470
+ #endif
471
+
472
+ ///////////////////////////////////////////////////////////////////////////////
473
+ // Helpers
474
+
475
+ //!@cond RAPIDJSON_HIDDEN_FROM_DOXYGEN
476
+
477
+ #define RAPIDJSON_MULTILINEMACRO_BEGIN do {
478
+ #define RAPIDJSON_MULTILINEMACRO_END \
479
+ } while((void)0, 0)
480
+
481
+ // adopted from Boost
482
+ #define RAPIDJSON_VERSION_CODE(x,y,z) \
483
+ (((x)*100000) + ((y)*100) + (z))
484
+
485
+ ///////////////////////////////////////////////////////////////////////////////
486
+ // RAPIDJSON_DIAG_PUSH/POP, RAPIDJSON_DIAG_OFF
487
+
488
+ #if defined(__GNUC__)
489
+ #define RAPIDJSON_GNUC \
490
+ RAPIDJSON_VERSION_CODE(__GNUC__,__GNUC_MINOR__,__GNUC_PATCHLEVEL__)
491
+ #endif
492
+
493
+ #if defined(__clang__) || (defined(RAPIDJSON_GNUC) && RAPIDJSON_GNUC >= RAPIDJSON_VERSION_CODE(4,2,0))
494
+
495
+ #define RAPIDJSON_PRAGMA(x) _Pragma(RAPIDJSON_STRINGIFY(x))
496
+ #define RAPIDJSON_DIAG_PRAGMA(x) RAPIDJSON_PRAGMA(GCC diagnostic x)
497
+ #define RAPIDJSON_DIAG_OFF(x) \
498
+ RAPIDJSON_DIAG_PRAGMA(ignored RAPIDJSON_STRINGIFY(RAPIDJSON_JOIN(-W,x)))
499
+
500
+ // push/pop support in Clang and GCC>=4.6
501
+ #if defined(__clang__) || (defined(RAPIDJSON_GNUC) && RAPIDJSON_GNUC >= RAPIDJSON_VERSION_CODE(4,6,0))
502
+ #define RAPIDJSON_DIAG_PUSH RAPIDJSON_DIAG_PRAGMA(push)
503
+ #define RAPIDJSON_DIAG_POP RAPIDJSON_DIAG_PRAGMA(pop)
504
+ #else // GCC >= 4.2, < 4.6
505
+ #define RAPIDJSON_DIAG_PUSH /* ignored */
506
+ #define RAPIDJSON_DIAG_POP /* ignored */
507
+ #endif
508
+
509
+ #elif defined(_MSC_VER)
510
+
511
+ // pragma (MSVC specific)
512
+ #define RAPIDJSON_PRAGMA(x) __pragma(x)
513
+ #define RAPIDJSON_DIAG_PRAGMA(x) RAPIDJSON_PRAGMA(warning(x))
514
+
515
+ #define RAPIDJSON_DIAG_OFF(x) RAPIDJSON_DIAG_PRAGMA(disable: x)
516
+ #define RAPIDJSON_DIAG_PUSH RAPIDJSON_DIAG_PRAGMA(push)
517
+ #define RAPIDJSON_DIAG_POP RAPIDJSON_DIAG_PRAGMA(pop)
518
+
519
+ #else
520
+
521
+ #define RAPIDJSON_DIAG_OFF(x) /* ignored */
522
+ #define RAPIDJSON_DIAG_PUSH /* ignored */
523
+ #define RAPIDJSON_DIAG_POP /* ignored */
524
+
525
+ #endif // RAPIDJSON_DIAG_*
526
+
527
+ ///////////////////////////////////////////////////////////////////////////////
528
+ // C++11 features
529
+
530
+ #ifndef RAPIDJSON_HAS_CXX11_RVALUE_REFS
531
+ #if defined(__clang__)
532
+ #if __has_feature(cxx_rvalue_references) && \
533
+ (defined(_LIBCPP_VERSION) || defined(__GLIBCXX__) && __GLIBCXX__ >= 20080306)
534
+ #define RAPIDJSON_HAS_CXX11_RVALUE_REFS 1
535
+ #else
536
+ #define RAPIDJSON_HAS_CXX11_RVALUE_REFS 0
537
+ #endif
538
+ #elif (defined(RAPIDJSON_GNUC) && (RAPIDJSON_GNUC >= RAPIDJSON_VERSION_CODE(4,3,0)) && defined(__GXX_EXPERIMENTAL_CXX0X__)) || \
539
+ (defined(_MSC_VER) && _MSC_VER >= 1600)
540
+
541
+ #define RAPIDJSON_HAS_CXX11_RVALUE_REFS 1
542
+ #else
543
+ #define RAPIDJSON_HAS_CXX11_RVALUE_REFS 0
544
+ #endif
545
+ #endif // RAPIDJSON_HAS_CXX11_RVALUE_REFS
546
+
547
+ #ifndef RAPIDJSON_HAS_CXX11_NOEXCEPT
548
+ #if defined(__clang__)
549
+ #define RAPIDJSON_HAS_CXX11_NOEXCEPT __has_feature(cxx_noexcept)
550
+ #elif (defined(RAPIDJSON_GNUC) && (RAPIDJSON_GNUC >= RAPIDJSON_VERSION_CODE(4,6,0)) && defined(__GXX_EXPERIMENTAL_CXX0X__))
551
+ // (defined(_MSC_VER) && _MSC_VER >= ????) // not yet supported
552
+ #define RAPIDJSON_HAS_CXX11_NOEXCEPT 1
553
+ #else
554
+ #define RAPIDJSON_HAS_CXX11_NOEXCEPT 0
555
+ #endif
556
+ #endif
557
+ #if RAPIDJSON_HAS_CXX11_NOEXCEPT
558
+ #define RAPIDJSON_NOEXCEPT noexcept
559
+ #else
560
+ #define RAPIDJSON_NOEXCEPT /* noexcept */
561
+ #endif // RAPIDJSON_HAS_CXX11_NOEXCEPT
562
+
563
+ // no automatic detection, yet
564
+ #ifndef RAPIDJSON_HAS_CXX11_TYPETRAITS
565
+ #define RAPIDJSON_HAS_CXX11_TYPETRAITS 0
566
+ #endif
567
+
568
+ #ifndef RAPIDJSON_HAS_CXX11_RANGE_FOR
569
+ #if defined(__clang__)
570
+ #define RAPIDJSON_HAS_CXX11_RANGE_FOR __has_feature(cxx_range_for)
571
+ #elif (defined(RAPIDJSON_GNUC) && (RAPIDJSON_GNUC >= RAPIDJSON_VERSION_CODE(4,3,0)) && defined(__GXX_EXPERIMENTAL_CXX0X__)) || \
572
+ (defined(_MSC_VER) && _MSC_VER >= 1700)
573
+ #define RAPIDJSON_HAS_CXX11_RANGE_FOR 1
574
+ #else
575
+ #define RAPIDJSON_HAS_CXX11_RANGE_FOR 0
576
+ #endif
577
+ #endif // RAPIDJSON_HAS_CXX11_RANGE_FOR
578
+
579
+ //!@endcond
580
+
581
+ ///////////////////////////////////////////////////////////////////////////////
582
+ // new/delete
583
+
584
+ #ifndef RAPIDJSON_NEW
585
+ ///! customization point for global \c new
586
+ #define RAPIDJSON_NEW(x) new x
587
+ #endif
588
+ #ifndef RAPIDJSON_DELETE
589
+ ///! customization point for global \c delete
590
+ #define RAPIDJSON_DELETE(x) delete x
591
+ #endif
592
+
593
+ ///////////////////////////////////////////////////////////////////////////////
594
+ // Type
595
+
596
+ /*! \namespace rapidjson
597
+ \brief main RapidJSON namespace
598
+ \see RAPIDJSON_NAMESPACE
599
+ */
600
+ RAPIDJSON_NAMESPACE_BEGIN
601
+
602
+ //! Type of JSON value
603
+ enum Type {
604
+ kNullType = 0, //!< null
605
+ kFalseType = 1, //!< false
606
+ kTrueType = 2, //!< true
607
+ kObjectType = 3, //!< object
608
+ kArrayType = 4, //!< array
609
+ kStringType = 5, //!< string
610
+ kNumberType = 6 //!< number
611
+ };
612
+
613
+ RAPIDJSON_NAMESPACE_END
614
+
615
+ #endif // RAPIDJSON_RAPIDJSON_H_