simdjson 4.1.0
Ridiculously Fast JSON
Loading...
Searching...
No Matches
element-inl.h
1#ifndef SIMDJSON_ELEMENT_INL_H
2#define SIMDJSON_ELEMENT_INL_H
3
4#include "simdjson/dom/base.h"
5#include "simdjson/dom/element.h"
6#include "simdjson/dom/document.h"
7#include "simdjson/dom/object.h"
8#include "simdjson/internal/tape_type.h"
9
10#include "simdjson/dom/object-inl.h"
11#include "simdjson/error-inl.h"
12#include "simdjson/jsonpathutil.h"
13
14#include <ostream>
15#include <limits>
16
17namespace simdjson {
18
19//
20// simdjson_result<dom::element> inline implementation
21//
22simdjson_inline simdjson_result<dom::element>::simdjson_result() noexcept
23 : internal::simdjson_result_base<dom::element>() {}
24simdjson_inline simdjson_result<dom::element>::simdjson_result(dom::element &&value) noexcept
25 : internal::simdjson_result_base<dom::element>(std::forward<dom::element>(value)) {}
26simdjson_inline simdjson_result<dom::element>::simdjson_result(error_code error) noexcept
27 : internal::simdjson_result_base<dom::element>(error) {}
28inline simdjson_result<dom::element_type> simdjson_result<dom::element>::type() const noexcept {
29 if (error()) { return error(); }
30 return first.type();
31}
32
33template<typename T>
34simdjson_inline bool simdjson_result<dom::element>::is() const noexcept {
35 return !error() && first.is<T>();
36}
37template<typename T>
38simdjson_inline simdjson_result<T> simdjson_result<dom::element>::get() const noexcept {
39 if (error()) { return error(); }
40 return first.get<T>();
41}
42template<typename T>
43simdjson_warn_unused simdjson_inline error_code simdjson_result<dom::element>::get(T &value) const noexcept {
44 if (error()) { return error(); }
45 return first.get<T>(value);
46}
47
48simdjson_inline simdjson_result<dom::array> simdjson_result<dom::element>::get_array() const noexcept {
49 if (error()) { return error(); }
50 return first.get_array();
51}
52simdjson_inline simdjson_result<dom::object> simdjson_result<dom::element>::get_object() const noexcept {
53 if (error()) { return error(); }
54 return first.get_object();
55}
56simdjson_inline simdjson_result<const char *> simdjson_result<dom::element>::get_c_str() const noexcept {
57 if (error()) { return error(); }
58 return first.get_c_str();
59}
60simdjson_inline simdjson_result<size_t> simdjson_result<dom::element>::get_string_length() const noexcept {
61 if (error()) { return error(); }
62 return first.get_string_length();
63}
64simdjson_inline simdjson_result<std::string_view> simdjson_result<dom::element>::get_string() const noexcept {
65 if (error()) { return error(); }
66 return first.get_string();
67}
68simdjson_inline simdjson_result<int64_t> simdjson_result<dom::element>::get_int64() const noexcept {
69 if (error()) { return error(); }
70 return first.get_int64();
71}
72simdjson_inline simdjson_result<uint64_t> simdjson_result<dom::element>::get_uint64() const noexcept {
73 if (error()) { return error(); }
74 return first.get_uint64();
75}
76simdjson_inline simdjson_result<double> simdjson_result<dom::element>::get_double() const noexcept {
77 if (error()) { return error(); }
78 return first.get_double();
79}
80simdjson_inline simdjson_result<bool> simdjson_result<dom::element>::get_bool() const noexcept {
81 if (error()) { return error(); }
82 return first.get_bool();
83}
84
85simdjson_inline bool simdjson_result<dom::element>::is_array() const noexcept {
86 return !error() && first.is_array();
87}
88simdjson_inline bool simdjson_result<dom::element>::is_object() const noexcept {
89 return !error() && first.is_object();
90}
91simdjson_inline bool simdjson_result<dom::element>::is_string() const noexcept {
92 return !error() && first.is_string();
93}
94simdjson_inline bool simdjson_result<dom::element>::is_int64() const noexcept {
95 return !error() && first.is_int64();
96}
97simdjson_inline bool simdjson_result<dom::element>::is_uint64() const noexcept {
98 return !error() && first.is_uint64();
99}
100simdjson_inline bool simdjson_result<dom::element>::is_double() const noexcept {
101 return !error() && first.is_double();
102}
103simdjson_inline bool simdjson_result<dom::element>::is_number() const noexcept {
104 return !error() && first.is_number();
105}
106simdjson_inline bool simdjson_result<dom::element>::is_bool() const noexcept {
107 return !error() && first.is_bool();
108}
109
110simdjson_inline bool simdjson_result<dom::element>::is_null() const noexcept {
111 return !error() && first.is_null();
112}
113
114simdjson_inline simdjson_result<dom::element> simdjson_result<dom::element>::operator[](std::string_view key) const noexcept {
115 if (error()) { return error(); }
116 return first[key];
117}
118simdjson_inline simdjson_result<dom::element> simdjson_result<dom::element>::operator[](const char *key) const noexcept {
119 if (error()) { return error(); }
120 return first[key];
121}
122simdjson_inline simdjson_result<dom::element> simdjson_result<dom::element>::at_pointer(const std::string_view json_pointer) const noexcept {
123 if (error()) { return error(); }
124 return first.at_pointer(json_pointer);
125}
126simdjson_inline simdjson_result<dom::element> simdjson_result<dom::element>::at_path(const std::string_view json_path) const noexcept {
127 auto json_pointer = json_path_to_pointer_conversion(json_path);
128 if (json_pointer == "-1") { return INVALID_JSON_POINTER; }
129 return at_pointer(json_pointer);
130}
131
132simdjson_inline simdjson_result<std::vector<dom::element>> simdjson_result<dom::element>::at_path_with_wildcard(const std::string_view json_path) const noexcept {
133 if (error()) { return error(); }
134 return first.at_path_with_wildcard(json_path);
135}
136
137#ifndef SIMDJSON_DISABLE_DEPRECATED_API
138[[deprecated("For standard compliance, use at_pointer instead, and prefix your pointers with a slash '/', see RFC6901 ")]]
139simdjson_inline simdjson_result<dom::element> simdjson_result<dom::element>::at(const std::string_view json_pointer) const noexcept {
140SIMDJSON_PUSH_DISABLE_WARNINGS
141SIMDJSON_DISABLE_DEPRECATED_WARNING
142 if (error()) { return error(); }
143 return first.at(json_pointer);
144SIMDJSON_POP_DISABLE_WARNINGS
145}
146#endif // SIMDJSON_DISABLE_DEPRECATED_API
147simdjson_inline simdjson_result<dom::element> simdjson_result<dom::element>::at(size_t index) const noexcept {
148 if (error()) { return error(); }
149 return first.at(index);
150}
151simdjson_inline simdjson_result<dom::element> simdjson_result<dom::element>::at_key(std::string_view key) const noexcept {
152 if (error()) { return error(); }
153 return first.at_key(key);
154}
155simdjson_inline simdjson_result<dom::element> simdjson_result<dom::element>::at_key_case_insensitive(std::string_view key) const noexcept {
156 if (error()) { return error(); }
157 return first.at_key_case_insensitive(key);
158}
159
160#if SIMDJSON_EXCEPTIONS
161
162simdjson_inline simdjson_result<dom::element>::operator bool() const noexcept(false) {
163 return get<bool>();
164}
165simdjson_inline simdjson_result<dom::element>::operator const char *() const noexcept(false) {
166 return get<const char *>();
167}
168simdjson_inline simdjson_result<dom::element>::operator std::string_view() const noexcept(false) {
169 return get<std::string_view>();
170}
171simdjson_inline simdjson_result<dom::element>::operator uint64_t() const noexcept(false) {
172 return get<uint64_t>();
173}
174simdjson_inline simdjson_result<dom::element>::operator int64_t() const noexcept(false) {
175 return get<int64_t>();
176}
177simdjson_inline simdjson_result<dom::element>::operator double() const noexcept(false) {
178 return get<double>();
179}
180simdjson_inline simdjson_result<dom::element>::operator dom::array() const noexcept(false) {
181 return get<dom::array>();
182}
183simdjson_inline simdjson_result<dom::element>::operator dom::object() const noexcept(false) {
184 return get<dom::object>();
185}
186
187simdjson_inline dom::array::iterator simdjson_result<dom::element>::begin() const noexcept(false) {
188 if (error()) { throw simdjson_error(error()); }
189 return first.begin();
190}
191simdjson_inline dom::array::iterator simdjson_result<dom::element>::end() const noexcept(false) {
192 if (error()) { throw simdjson_error(error()); }
193 return first.end();
194}
195
196#endif // SIMDJSON_EXCEPTIONS
197
198namespace dom {
199
200//
201// element inline implementation
202//
203simdjson_inline element::element() noexcept : tape{} {}
204simdjson_inline element::element(const internal::tape_ref &_tape) noexcept : tape{_tape} { }
205
206inline element_type element::type() const noexcept {
207 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
208 auto tape_type = tape.tape_ref_type();
209 return tape_type == internal::tape_type::FALSE_VALUE ? element_type::BOOL : static_cast<element_type>(tape_type);
210}
211
213 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
214 if(tape.is_true()) {
215 return true;
216 } else if(tape.is_false()) {
217 return false;
218 }
219 return INCORRECT_TYPE;
220}
222 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
223 switch (tape.tape_ref_type()) {
224 case internal::tape_type::STRING: {
225 return tape.get_c_str();
226 }
227 default:
228 return INCORRECT_TYPE;
229 }
230}
232 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
233 switch (tape.tape_ref_type()) {
234 case internal::tape_type::STRING: {
235 return tape.get_string_length();
236 }
237 default:
238 return INCORRECT_TYPE;
239 }
240}
242 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
243 switch (tape.tape_ref_type()) {
244 case internal::tape_type::STRING:
245 return tape.get_string_view();
246 default:
247 return INCORRECT_TYPE;
248 }
249}
251 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
252 if(simdjson_unlikely(!tape.is_uint64())) { // branch rarely taken
253 if(tape.is_int64()) {
254 int64_t result = tape.next_tape_value<int64_t>();
255 if (result < 0) {
256 return NUMBER_OUT_OF_RANGE;
257 }
258 return uint64_t(result);
259 }
260 return INCORRECT_TYPE;
261 }
262 return tape.next_tape_value<int64_t>();
263}
265 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
266 if(simdjson_unlikely(!tape.is_int64())) { // branch rarely taken
267 if(tape.is_uint64()) {
268 uint64_t result = tape.next_tape_value<uint64_t>();
269 // Wrapping max in parens to handle Windows issue: https://stackoverflow.com/questions/11544073/how-do-i-deal-with-the-max-macro-in-windows-h-colliding-with-max-in-std
270 if (result > uint64_t((std::numeric_limits<int64_t>::max)())) {
271 return NUMBER_OUT_OF_RANGE;
272 }
273 return static_cast<int64_t>(result);
274 }
275 return INCORRECT_TYPE;
276 }
277 return tape.next_tape_value<int64_t>();
278}
280 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
281 // Performance considerations:
282 // 1. Querying tape_ref_type() implies doing a shift, it is fast to just do a straight
283 // comparison.
284 // 2. Using a switch-case relies on the compiler guessing what kind of code generation
285 // we want... But the compiler cannot know that we expect the type to be "double"
286 // most of the time.
287 // We can expect get<double> to refer to a double type almost all the time.
288 // It is important to craft the code accordingly so that the compiler can use this
289 // information. (This could also be solved with profile-guided optimization.)
290 if(simdjson_unlikely(!tape.is_double())) { // branch rarely taken
291 if(tape.is_uint64()) {
292 return double(tape.next_tape_value<uint64_t>());
293 } else if(tape.is_int64()) {
294 return double(tape.next_tape_value<int64_t>());
295 }
296 return INCORRECT_TYPE;
297 }
298 // this is common:
299 return tape.next_tape_value<double>();
300}
302 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
303 switch (tape.tape_ref_type()) {
304 case internal::tape_type::START_ARRAY:
305 return array(tape);
306 default:
307 return INCORRECT_TYPE;
308 }
309}
311 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
312 switch (tape.tape_ref_type()) {
313 case internal::tape_type::START_OBJECT:
314 return object(tape);
315 default:
316 return INCORRECT_TYPE;
317 }
318}
319
320template<typename T>
321simdjson_warn_unused simdjson_inline error_code element::get(T &value) const noexcept {
322 return get<T>().get(value);
323}
324// An element-specific version prevents recursion with simdjson_result::get<element>(value)
325template<>
326simdjson_warn_unused simdjson_inline error_code element::get<element>(element &value) const noexcept {
327 value = element(tape);
328 return SUCCESS;
329}
330template<typename T>
331inline void element::tie(T &value, error_code &error) && noexcept {
332 error = get<T>(value);
333}
334
335template<typename T>
336simdjson_inline bool element::is() const noexcept {
337 auto result = get<T>();
338 return !result.error();
339}
340
341template<> inline simdjson_result<array> element::get<array>() const noexcept { return get_array(); }
342template<> inline simdjson_result<object> element::get<object>() const noexcept { return get_object(); }
343template<> inline simdjson_result<const char *> element::get<const char *>() const noexcept { return get_c_str(); }
344template<> inline simdjson_result<std::string_view> element::get<std::string_view>() const noexcept { return get_string(); }
345template<> inline simdjson_result<int64_t> element::get<int64_t>() const noexcept { return get_int64(); }
346template<> inline simdjson_result<uint64_t> element::get<uint64_t>() const noexcept { return get_uint64(); }
347template<> inline simdjson_result<double> element::get<double>() const noexcept { return get_double(); }
348template<> inline simdjson_result<bool> element::get<bool>() const noexcept { return get_bool(); }
349
350inline bool element::is_array() const noexcept { return is<array>(); }
351inline bool element::is_object() const noexcept { return is<object>(); }
352inline bool element::is_string() const noexcept { return is<std::string_view>(); }
353inline bool element::is_int64() const noexcept { return is<int64_t>(); }
354inline bool element::is_uint64() const noexcept { return is<uint64_t>(); }
355inline bool element::is_double() const noexcept { return is<double>(); }
356inline bool element::is_bool() const noexcept { return is<bool>(); }
357inline bool element::is_number() const noexcept { return is_int64() || is_uint64() || is_double(); }
358
359inline bool element::is_null() const noexcept {
360 return tape.is_null_on_tape();
361}
362
363#if SIMDJSON_EXCEPTIONS
364
365inline element::operator bool() const noexcept(false) { return get<bool>(); }
366inline element::operator const char*() const noexcept(false) { return get<const char *>(); }
367inline element::operator std::string_view() const noexcept(false) { return get<std::string_view>(); }
368inline element::operator uint64_t() const noexcept(false) { return get<uint64_t>(); }
369inline element::operator int64_t() const noexcept(false) { return get<int64_t>(); }
370inline element::operator double() const noexcept(false) { return get<double>(); }
371inline element::operator array() const noexcept(false) { return get<array>(); }
372inline element::operator object() const noexcept(false) { return get<object>(); }
373
374inline array::iterator element::begin() const noexcept(false) {
375 return get<array>().begin();
376}
377inline array::iterator element::end() const noexcept(false) {
378 return get<array>().end();
379}
380
381#endif // SIMDJSON_EXCEPTIONS
382
383inline simdjson_result<element> element::operator[](std::string_view key) const noexcept {
384 return at_key(key);
385}
386inline simdjson_result<element> element::operator[](const char *key) const noexcept {
387 return at_key(key);
388}
389
390inline bool is_pointer_well_formed(std::string_view json_pointer) noexcept {
391 if (simdjson_unlikely(json_pointer[0] != '/')) {
392 return false;
393 }
394 size_t escape = json_pointer.find('~');
395 if (escape == std::string_view::npos) {
396 return true;
397 }
398 if (escape == json_pointer.size() - 1) {
399 return false;
400 }
401 if (json_pointer[escape + 1] != '0' && json_pointer[escape + 1] != '1') {
402 return false;
403 }
404 return true;
405}
406
407inline simdjson_result<element> element::at_pointer(std::string_view json_pointer) const noexcept {
408 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
409 switch (tape.tape_ref_type()) {
410 case internal::tape_type::START_OBJECT:
411 return object(tape).at_pointer(json_pointer);
412 case internal::tape_type::START_ARRAY:
413 return array(tape).at_pointer(json_pointer);
414 default: {
415 if (!json_pointer.empty()) { // a non-empty string can be invalid, or accessing a primitive (issue 2154)
416 if (is_pointer_well_formed(json_pointer)) {
417 return NO_SUCH_FIELD;
418 }
420 }
421 // an empty string means that we return the current node
422 dom::element copy(*this);
423 return simdjson_result<element>(std::move(copy));
424 }
425 }
426}
427
428inline simdjson_result<std::vector<element>> element::at_path_with_wildcard(std::string_view json_path) const noexcept {
429 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
430
431 switch (tape.tape_ref_type()) {
432 case internal::tape_type::START_OBJECT:
433 return object(tape).at_path_with_wildcard(json_path);
434 case internal::tape_type::START_ARRAY:
435 return array(tape).at_path_with_wildcard(json_path);
436 default:
437 return std::vector<element>{};
438 }
439}
440
441inline simdjson_result<element> element::at_path(std::string_view json_path) const noexcept {
442 auto json_pointer = json_path_to_pointer_conversion(json_path);
443 if (json_pointer == "-1") { return INVALID_JSON_POINTER; }
444 return at_pointer(json_pointer);
445}
446#ifndef SIMDJSON_DISABLE_DEPRECATED_API
447[[deprecated("For standard compliance, use at_pointer instead, and prefix your pointers with a slash '/', see RFC6901 ")]]
448inline simdjson_result<element> element::at(std::string_view json_pointer) const noexcept {
449 // version 0.4 of simdjson allowed non-compliant pointers
450 auto std_pointer = (json_pointer.empty() ? "" : "/") + std::string(json_pointer.begin(), json_pointer.end());
451 return at_pointer(std_pointer);
452}
453#endif // SIMDJSON_DISABLE_DEPRECATED_API
454
455inline simdjson_result<element> element::at(size_t index) const noexcept {
456 return get<array>().at(index);
457}
458inline simdjson_result<element> element::at_key(std::string_view key) const noexcept {
459 return get<object>().at_key(key);
460}
461inline simdjson_result<element> element::at_key_case_insensitive(std::string_view key) const noexcept {
462 return get<object>().at_key_case_insensitive(key);
463}
464inline bool element::operator<(const element &other) const noexcept {
465 return tape.json_index < other.tape.json_index;
466}
467inline bool element::operator==(const element &other) const noexcept {
468 return tape.json_index == other.tape.json_index;
469}
470
471inline bool element::dump_raw_tape(std::ostream &out) const noexcept {
472 SIMDJSON_DEVELOPMENT_ASSERT(tape.usable()); // https://github.com/simdjson/simdjson/issues/1914
473 return tape.doc->dump_raw_tape(out);
474}
475
476
477inline std::ostream& operator<<(std::ostream& out, element_type type) {
478 switch (type) {
480 return out << "array";
482 return out << "object";
484 return out << "int64_t";
486 return out << "uint64_t";
488 return out << "double";
490 return out << "string";
492 return out << "bool";
494 return out << "null";
495 default:
496 return out << "unexpected content!!!"; // abort() usage is forbidden in the library
497 }
498}
499
500} // namespace dom
501
502} // namespace simdjson
503
504#endif // SIMDJSON_ELEMENT_INL_H
JSON array.
Definition array.h:15
simdjson_result< std::vector< element > > at_path_with_wildcard(std::string_view json_path) const noexcept
Adds support for JSONPath expression with wildcards '*'.
Definition array-inl.h:162
simdjson_result< element > at_pointer(std::string_view json_pointer) const noexcept
Get the value associated with the given JSON pointer.
Definition array-inl.h:94
A JSON element.
Definition element.h:33
bool is_object() const noexcept
Whether this element is a json object.
bool is_double() const noexcept
Whether this element is a json number that fits in a double.
simdjson_inline element_type type() const noexcept
The type of this element.
bool is_number() const noexcept
Whether this element is a json number.
simdjson_result< T > get() const noexcept
Get the value as the provided type (T).
Definition element.h:213
simdjson_result< const char * > get_c_str() const noexcept
Cast this element to a null-terminated C string.
bool operator<(const element &other) const noexcept
operator< defines a total order for element allowing to use them in ordered C++ STL containers
simdjson_result< element > at_pointer(const std::string_view json_pointer) const noexcept
Get the value associated with the given JSON pointer.
simdjson_result< double > get_double() const noexcept
Cast this element to a double floating-point.
simdjson_inline bool is() const noexcept
Tell whether the value can be cast to provided type (T).
simdjson_result< element > at_key_case_insensitive(std::string_view key) const noexcept
Get the value associated with the given key in a case-insensitive manner.
void tie(T &value, error_code &error) &&noexcept
Get the value as the provided type (T), setting error if it's not the given type.
simdjson_result< bool > get_bool() const noexcept
Cast this element to a bool.
bool is_string() const noexcept
Whether this element is a json string.
simdjson_result< element > at_key(std::string_view key) const noexcept
Get the value associated with the given key.
dom::array::iterator end() const noexcept(false)
Iterate over each element in this array.
simdjson_result< array > get_array() const noexcept
Cast this element to an array.
simdjson_result< size_t > get_string_length() const noexcept
Gives the length in bytes of the string.
simdjson_inline element() noexcept
Create a new, invalid element.
simdjson_result< uint64_t > get_uint64() const noexcept
Cast this element to an unsigned integer.
dom::array::iterator begin() const noexcept(false)
Iterate over each element in this array.
simdjson_result< element > at(const std::string_view json_pointer) const noexcept
Version 0.4 of simdjson used an incorrect interpretation of the JSON Pointer standard and allowed the...
simdjson_result< int64_t > get_int64() const noexcept
Cast this element to a signed integer.
simdjson_result< object > get_object() const noexcept
Cast this element to an object.
bool is_uint64() const noexcept
Whether this element is a json number that fits in an unsigned 64-bit integer.
simdjson_result< element > operator[](std::string_view key) const noexcept
Get the value associated with the given key.
bool is_int64() const noexcept
Whether this element is a json number that fits in a signed 64-bit integer.
bool is_null() const noexcept
Whether this element is a json null.
simdjson_result< element > at_path(std::string_view json_path) const noexcept
Get the value associated with the given JSONPath expression.
simdjson_result< std::string_view > get_string() const noexcept
Cast this element to a string.
bool is_array() const noexcept
Whether this element is a json array.
bool operator==(const element &other) const noexcept
operator== allows to verify if two element values reference the same JSON item
bool is_bool() const noexcept
Whether this element is a json true or false.
JSON object.
Definition object.h:16
simdjson_result< std::vector< element > > at_path_with_wildcard(std::string_view json_path) const noexcept
Adds support for JSONPath expression with wildcards '*'.
Definition object-inl.h:175
simdjson_result< element > at_pointer(std::string_view json_pointer) const noexcept
Get the value associated with the given JSON pointer.
Definition object-inl.h:104
element_type
The actual concrete type of a JSON element This is the type it is most easily cast to with get<>.
Definition element.h:16
@ STRING
std::string_view
@ UINT64
uint64_t: any integer that fits in uint64_t but not int64_t
@ DOUBLE
double: Any number with a "." or "e" that fits in double.
The top level simdjson namespace, containing everything the library provides.
Definition base.h:8
error_code
All possible errors returned by simdjson.
Definition error.h:19
@ INCORRECT_TYPE
JSON element has a different type than user expected.
Definition error.h:37
@ NO_SUCH_FIELD
JSON field not found in object.
Definition error.h:40
@ NUMBER_OUT_OF_RANGE
JSON number does not fit in 64 bits.
Definition error.h:38
@ SUCCESS
No error.
Definition error.h:20
@ INVALID_JSON_POINTER
Invalid JSON pointer syntax.
Definition error.h:42
std::string json_path_to_pointer_conversion(std::string_view json_path)
Converts JSONPath to JSON Pointer.
The result of a simdjson operation that could fail.
Definition error.h:278
simdjson_warn_unused simdjson_inline error_code get(T &value) &&noexcept
Move the value to the provided variable.
Definition error-inl.h:163