1#ifndef SIMDJSON_GENERIC_ONDEMAND_DOCUMENT_H
3#ifndef SIMDJSON_CONDITIONAL_INCLUDE
4#define SIMDJSON_GENERIC_ONDEMAND_DOCUMENT_H
5#include "simdjson/generic/ondemand/base.h"
6#include "simdjson/generic/ondemand/json_iterator.h"
7#include "simdjson/generic/ondemand/deserialize.h"
8#include "simdjson/generic/ondemand/value.h"
14namespace SIMDJSON_IMPLEMENTATION {
34 simdjson_inline
document &operator=(const
document &other) noexcept = delete;
140 template <typename string_type>
141 simdjson_warn_unused simdjson_inline
error_code get_string(string_type& receiver,
bool allow_replacement = false) noexcept;
205 template <typename T>
207#if SIMDJSON_SUPPORTS_CONCEPTS
208 noexcept(custom_deserializable<T, document> ? nothrow_custom_deserializable<T, document> :
true)
213 static_assert(std::is_default_constructible<T>::value,
"Cannot initialize the specified type.");
215 SIMDJSON_TRY(get<T>(out));
230#if SIMDJSON_SUPPORTS_CONCEPTS
231 noexcept(custom_deserializable<T, document> ? nothrow_custom_deserializable<T, document> :
true)
236 static_assert(!std::is_same<T, array>::value && !std::is_same<T, object>::value,
"You should never hold either an ondemand::array or ondemand::object without a corresponding ondemand::document being alive; that would be Undefined Behaviour.");
253#if SIMDJSON_SUPPORTS_CONCEPTS
254 noexcept(custom_deserializable<T, document> ? nothrow_custom_deserializable<T, document> :
true)
259#if SIMDJSON_SUPPORTS_CONCEPTS
260 if constexpr (custom_deserializable<T, document>) {
261 return deserialize(*
this, out);
263 static_assert(!
sizeof(T),
"The get<T> method with type T is not implemented by the simdjson library. "
264 "And you do not seem to have added support for it. Indeed, we have that "
265 "simdjson::custom_deserializable<T> is false and the type T is not a default type "
266 "such as ondemand::object, ondemand::array, raw_json_string, std::string_view, uint64_t, "
267 "int64_t, double, or bool.");
268 static_cast<void>(out);
274 static_assert(!
sizeof(T),
"The get method with given type is not implemented by the simdjson library. "
275 "The supported types are ondemand::object, ondemand::array, raw_json_string, std::string_view, uint64_t, "
276 "int64_t, double, and bool. We recommend you use get_double(), get_bool(), get_uint64(), get_int64(), "
277 " get_object(), get_array(), get_raw_json_string(), or get_string() instead of the get template."
278 " You may also add support for custom types, see our documentation.");
279 static_cast<void>(out);
285 template<
typename T> simdjson_deprecated simdjson_inline
error_code get(T &out) &&
noexcept;
287#if SIMDJSON_EXCEPTIONS
298 explicit simdjson_inline
operator T() &
noexcept(
false);
300 explicit simdjson_deprecated simdjson_inline
operator T() &&
noexcept(
false);
308 simdjson_inline
operator array() &
noexcept(
false);
315 simdjson_inline
operator object() &
noexcept(
false);
322 simdjson_inline
operator uint64_t() noexcept(false);
329 simdjson_inline operator int64_t() noexcept(false);
336 simdjson_inline operator
double() noexcept(false);
346 simdjson_inline operator std::
string_view() noexcept(false) simdjson_lifetime_bound;
355 simdjson_inline operator
raw_json_string() noexcept(false) simdjson_lifetime_bound;
362 simdjson_inline operator
bool() noexcept(false);
374 simdjson_inline operator
value() noexcept(false);
648 inline
void rewind() noexcept;
669 inline
bool at_end() const noexcept;
758#if SIMDJSON_SUPPORTS_CONCEPTS
759 template <
typename Func>
760 requires std::invocable<Func, value>
762 template <
typename Func>
773#if SIMDJSON_STATIC_REFLECTION
798 template<constevalutil::fixed_string... FieldNames,
typename T>
799 requires(std::is_class_v<T> && (
sizeof...(FieldNames) > 0))
800 simdjson_warn_unused simdjson_inline
error_code extract_into(T& out) &
noexcept;
808 simdjson_inline
document(ondemand::json_iterator &&
iter) noexcept;
809 simdjson_inline const uint8_t *text(uint32_t idx) const noexcept;
811 simdjson_inline value_iterator resume_value_iterator() noexcept;
812 simdjson_inline value_iterator get_root_value_iterator() noexcept;
813 simdjson_inline
simdjson_result<
object> start_or_resume_object() noexcept;
814 static simdjson_inline
document start(ondemand::json_iterator &&
iter) noexcept;
824 friend class ondemand::parser;
848 simdjson_inline
void rewind()
noexcept;
860 template <
typename string_type>
861 simdjson_warn_unused simdjson_inline
error_code get_string(string_type& receiver,
bool allow_replacement =
false)
noexcept;
868 template <
typename T>
870#if SIMDJSON_SUPPORTS_CONCEPTS
871 noexcept(custom_deserializable<T, document> ? nothrow_custom_deserializable<T, document> :
true)
876 static_assert(std::is_default_constructible<T>::value,
"Cannot initialize the specified type.");
878 SIMDJSON_TRY(get<T>(out));
883#if SIMDJSON_SUPPORTS_CONCEPTS
884 noexcept(custom_deserializable<T, document> ? nothrow_custom_deserializable<T, document> :
true)
889 static_assert(!std::is_same<T, array>::value && !std::is_same<T, object>::value,
"You should never hold either an ondemand::array or ondemand::object without a corresponding ondemand::document_reference being alive; that would be Undefined Behaviour.");
906#if SIMDJSON_SUPPORTS_CONCEPTS
907 noexcept(custom_deserializable<T, document> ? nothrow_custom_deserializable<T, document_reference> :
true)
912#if SIMDJSON_SUPPORTS_CONCEPTS
913 if constexpr (custom_deserializable<T, document_reference>) {
914 return deserialize(*
this, out);
916 static_assert(!
sizeof(T),
"The get<T> method with type T is not implemented by the simdjson library. "
917 "And you do not seem to have added support for it. Indeed, we have that "
918 "simdjson::custom_deserializable<T> is false and the type T is not a default type "
919 "such as ondemand::object, ondemand::array, raw_json_string, std::string_view, uint64_t, "
920 "int64_t, double, or bool.");
921 static_cast<void>(out);
927 static_assert(!
sizeof(T),
"The get method with given type is not implemented by the simdjson library. "
928 "The supported types are ondemand::object, ondemand::array, raw_json_string, std::string_view, uint64_t, "
929 "int64_t, double, and bool. We recommend you use get_double(), get_bool(), get_uint64(), get_int64(), "
930 " get_object(), get_array(), get_raw_json_string(), or get_string() instead of the get template."
931 " You may also add support for custom types, see our documentation.");
932 static_cast<void>(out);
938 template<
typename T> simdjson_inline
error_code get(T &out) &&
noexcept;
940#if SIMDJSON_STATIC_REFLECTION
941 template<constevalutil::fixed_string... FieldNames,
typename T>
942 requires(std::is_class_v<T> && (
sizeof...(FieldNames) > 0))
943 simdjson_warn_unused simdjson_inline
error_code extract_into(T& out) &
noexcept;
945 simdjson_inline
operator document&()
const noexcept;
946#if SIMDJSON_EXCEPTIONS
948 explicit simdjson_inline
operator T() noexcept(false);
949 simdjson_inline operator
array() & noexcept(false);
950 simdjson_inline operator
object() & noexcept(false);
951 simdjson_inline operator uint64_t() noexcept(false);
952 simdjson_inline operator int64_t() noexcept(false);
953 simdjson_inline operator
double() noexcept(false);
954 simdjson_inline operator std::string_view() noexcept(false);
956 simdjson_inline operator
bool() noexcept(false);
957 simdjson_inline operator
value() noexcept(false);
976 simdjson_inline
simdjson_result<const
char *> current_location() noexcept;
977 simdjson_inline int32_t current_depth() const noexcept;
978 simdjson_inline
bool is_negative() noexcept;
980 simdjson_inline
simdjson_result<number_type> get_number_type() noexcept;
982 simdjson_inline
simdjson_result<std::string_view> raw_json_token() noexcept;
985#if SIMDJSON_SUPPORTS_CONCEPTS
986 template <
typename Func>
987 requires std::invocable<Func, value>
989 template <
typename Func>
991 simdjson_inline
error_code for_each_at_path_with_wildcard(std::string_view json_path, Func&& callback)
noexcept;
1003struct simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::document> :
public SIMDJSON_IMPLEMENTATION::implementation_simdjson_result_base<SIMDJSON_IMPLEMENTATION::ondemand::document> {
1005 simdjson_inline simdjson_result(SIMDJSON_IMPLEMENTATION::ondemand::document &&value)
noexcept;
1007 simdjson_inline simdjson_result() noexcept = default;
1008 simdjson_inline
error_code rewind() noexcept;
1010 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::array> get_array() & noexcept;
1011 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::
object> get_object() & noexcept;
1012 simdjson_inline simdjson_result<uint64_t> get_uint64() noexcept;
1013 simdjson_inline simdjson_result<uint64_t> get_uint64_in_string() noexcept;
1014 simdjson_inline simdjson_result<int64_t> get_int64() noexcept;
1015 simdjson_inline simdjson_result<int64_t> get_int64_in_string() noexcept;
1016 simdjson_inline simdjson_result<uint32_t> get_uint32() noexcept;
1017 simdjson_inline simdjson_result<int32_t> get_int32() noexcept;
1018 simdjson_inline simdjson_result<
double> get_double() noexcept;
1019 simdjson_inline simdjson_result<
double> get_double_in_string() noexcept;
1020 simdjson_inline simdjson_result<std::string_view> get_string(
bool allow_replacement = false) noexcept;
1021 template <typename string_type>
1022 simdjson_warn_unused simdjson_inline
error_code get_string(string_type& receiver,
bool allow_replacement = false) noexcept;
1023 simdjson_inline simdjson_result<std::string_view> get_wobbly_string() noexcept;
1024 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::raw_json_string> get_raw_json_string() noexcept;
1025 simdjson_inline simdjson_result<
bool> get_bool() noexcept;
1026 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::value> get_value() noexcept;
1027 simdjson_inline simdjson_result<
bool> is_null() noexcept;
1029 template<typename T> simdjson_inline simdjson_result<T>
get() & noexcept;
1030 template<typename T> simdjson_deprecated simdjson_inline simdjson_result<T>
get() && noexcept;
1032 template<typename T> simdjson_inline
error_code get(T &out) & noexcept;
1033 template<typename T> simdjson_inline
error_code get(T &out) && noexcept;
1034#if SIMDJSON_EXCEPTIONS
1036 using SIMDJSON_IMPLEMENTATION::implementation_simdjson_result_base<SIMDJSON_IMPLEMENTATION::ondemand::document>::operator*;
1037 using SIMDJSON_IMPLEMENTATION::implementation_simdjson_result_base<SIMDJSON_IMPLEMENTATION::ondemand::document>::operator->;
1038 template <class T, typename std::enable_if<std::is_same<T, SIMDJSON_IMPLEMENTATION::ondemand::document>::value ==
false>::type>
1039 explicit simdjson_inline
operator T() noexcept(false);
1040 simdjson_inline operator SIMDJSON_IMPLEMENTATION::ondemand::array() & noexcept(false);
1041 simdjson_inline operator SIMDJSON_IMPLEMENTATION::ondemand::
object() & noexcept(false);
1042 simdjson_inline operator uint64_t() noexcept(false);
1043 simdjson_inline operator int64_t() noexcept(false);
1044 simdjson_inline operator
double() noexcept(false);
1045 simdjson_inline operator std::string_view() noexcept(false);
1046 simdjson_inline operator SIMDJSON_IMPLEMENTATION::ondemand::raw_json_string() noexcept(false);
1047 simdjson_inline operator
bool() noexcept(false);
1048 simdjson_inline operator SIMDJSON_IMPLEMENTATION::ondemand::value() noexcept(false);
1050 simdjson_inline simdjson_result<size_t> count_elements() &
noexcept;
1051 simdjson_inline simdjson_result<size_t> count_fields() &
noexcept;
1052 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::value> at(
size_t index) &
noexcept;
1053 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::array_iterator> begin() &
noexcept;
1054 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::array_iterator> end() &
noexcept;
1055 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::value> find_field(std::string_view key) &
noexcept;
1056 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::value> find_field(
const char *key) &
noexcept;
1057 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::value> operator[](std::string_view key) &
noexcept;
1058 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::value> operator[](
const char *key) &
noexcept;
1059 simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::value> operator[](
int) &
noexcept =
delete;
1060 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::value> find_field_unordered(std::string_view key) &
noexcept;
1061 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::value> find_field_unordered(
const char *key) &
noexcept;
1062 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::json_type> type() noexcept;
1063 simdjson_inline simdjson_result<
bool> is_scalar() noexcept;
1064 simdjson_inline simdjson_result<
bool> is_string() noexcept;
1065 simdjson_inline simdjson_result<const
char *> current_location() noexcept;
1066 simdjson_inline int32_t current_depth() const noexcept;
1067 simdjson_inline
bool at_end() const noexcept;
1068 simdjson_inline
bool is_negative() noexcept;
1069 simdjson_inline simdjson_result<
bool> is_integer() noexcept;
1070 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::number_type> get_number_type() noexcept;
1071 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::number> get_number() noexcept;
1073 simdjson_inline simdjson_result<std::string_view> raw_json_token() noexcept;
1075 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::value> at_pointer(std::string_view json_pointer) noexcept;
1076 simdjson_inline simdjson_result<SIMDJSON_IMPLEMENTATION::ondemand::value> at_path(std::string_view json_path) noexcept;
1077#if SIMDJSON_SUPPORTS_CONCEPTS
1078 template <
typename Func>
1079 requires std::invocable<Func, SIMDJSON_IMPLEMENTATION::ondemand::value>
1081 template <
typename Func>
1083 simdjson_inline
error_code for_each_at_path_with_wildcard(std::string_view json_path, Func&& callback)
noexcept;
1084#if SIMDJSON_STATIC_REFLECTION
1085 template<constevalutil::fixed_string... FieldNames,
typename T>
1086 requires(std::is_class_v<T> && (
sizeof...(FieldNames) > 0))
1087 simdjson_warn_unused simdjson_inline
error_code extract_into(T& out) &
noexcept;
1103 simdjson_inline
error_code rewind()
noexcept;
1116 template <
typename string_type>
1117 simdjson_warn_unused simdjson_inline
error_code get_string(string_type& receiver,
bool allow_replacement =
false)
noexcept;
1127 template<
typename T> simdjson_inline
error_code get(T &out) &
noexcept;
1128 template<
typename T> simdjson_inline
error_code get(T &out) &&
noexcept;
1129#if SIMDJSON_EXCEPTIONS
1131 explicit simdjson_inline
operator T()
noexcept(
false);
1134 simdjson_inline
operator uint64_t()
noexcept(
false);
1135 simdjson_inline
operator int64_t()
noexcept(
false);
1136 simdjson_inline
operator double()
noexcept(
false);
1137 simdjson_inline
operator std::string_view()
noexcept(
false);
1139 simdjson_inline
operator bool()
noexcept(
false);
1168#if SIMDJSON_SUPPORTS_CONCEPTS
1169 template <
typename Func>
1170 requires std::invocable<Func, SIMDJSON_IMPLEMENTATION::ondemand::value>
1172 template <
typename Func>
1174 simdjson_inline
error_code for_each_at_path_with_wildcard(std::string_view json_path, Func&& callback)
noexcept;
1175#if SIMDJSON_STATIC_REFLECTION
1176 template<constevalutil::fixed_string... FieldNames,
typename T>
1177 requires(std::is_class_v<T> && (
sizeof...(FieldNames) > 0))
1178 simdjson_warn_unused simdjson_inline
error_code extract_into(T& out) &
noexcept;
A forward-only JSON array.
A forward-only JSON array.
A document_reference is a thin wrapper around a document reference instance.
simdjson_warn_unused simdjson_inline error_code get(T &out) &noexcept
Get this value as the given type.
simdjson_inline simdjson_result< uint64_t > get_uint64() noexcept
The document_reference instances are used primarily/solely for streams of JSON documents.
A forward-only stream of documents.
simdjson_inline simdjson_result< value > at(size_t index) &noexcept
Get the value at the given index in the array.
simdjson_warn_unused simdjson_inline error_code consume() noexcept
Consumes the document.
static constexpr depth_t DOCUMENT_DEPTH
document depth is always 0
simdjson_inline int32_t current_depth() const noexcept
Returns the current depth in the document if in bounds.
simdjson_inline simdjson_result< array_iterator > begin() &noexcept
Begin array iteration.
simdjson_inline simdjson_result< size_t > count_fields() &noexcept
This method scans the object and counts the number of key-value pairs.
simdjson_inline simdjson_result< std::string_view > get_string(bool allow_replacement=false) noexcept
Cast this JSON value to a string.
simdjson_warn_unused simdjson_inline simdjson_result< number > get_number() noexcept
Attempt to parse an ondemand::number.
simdjson_warn_unused simdjson_inline error_code get(T &out) &noexcept
Get this value as the given type.
bool is_alive() noexcept
Some unrecoverable error conditions may render the document instance unusable.
simdjson_inline error_code for_each_at_path_with_wildcard(std::string_view json_path, Func &&callback) noexcept
Call the provided callback for each value matching the given JSONPath expression with wildcard suppor...
simdjson_inline simdjson_result< bool > get_bool() noexcept
Cast this JSON value to a bool.
simdjson_inline simdjson_result< object > get_object() &noexcept
Cast this JSON value to an object.
simdjson_inline simdjson_result< bool > is_string() noexcept
Checks whether the document is a string.
simdjson_inline simdjson_result< uint64_t > get_uint64() noexcept
Cast this JSON value to an unsigned integer.
simdjson_inline bool is_negative() noexcept
Checks whether the document is a negative number.
simdjson_inline document() noexcept=default
Create a new invalid document.
simdjson_inline simdjson_result< std::string_view > raw_json_token() noexcept
Get the raw JSON for this token.
simdjson_inline simdjson_result< uint64_t > get_uint64_in_string() noexcept
Cast this JSON value (inside string) to an unsigned integer.
simdjson_inline simdjson_result< bool > is_null() noexcept
Checks if this JSON value is null.
simdjson_inline simdjson_result< int64_t > get_int64() noexcept
Cast this JSON value to a signed integer.
simdjson_inline simdjson_result< int32_t > get_int32() noexcept
Cast this JSON value to a 32-bit signed integer.
simdjson_inline simdjson_result< value > at_pointer(std::string_view json_pointer) noexcept
Get the value associated with the given JSON pointer.
simdjson_inline simdjson_result< json_type > type() noexcept
Get the type of this JSON value.
simdjson_inline simdjson_result< array_iterator > end() &noexcept
Sentinel representing the end of the array.
simdjson_inline operator std::string_view() noexcept(false) simdjson_lifetime_bound
Cast this JSON value to a string.
simdjson_inline simdjson_result< double > get_double_in_string() noexcept
Cast this JSON value (inside string) to a double.
simdjson_inline simdjson_result< value > at_path(std::string_view json_path) noexcept
Get the value associated with the given JSONPath expression.
json_iterator iter
Current position in the document.
simdjson_inline simdjson_result< double > get_double() noexcept
Cast this JSON value to a double.
std::string to_debug_string() noexcept
Returns debugging information.
void rewind() noexcept
Reset the iterator inside the document instance so we are pointing back at the beginning of the docum...
simdjson_inline simdjson_result< std::string_view > raw_json() noexcept
Consumes the document and returns a string_view instance corresponding to the document as represented...
simdjson_inline simdjson_result< value > find_field_unordered(std::string_view key) &noexcept
Look up a field by name on an object, without regard to key order.
simdjson_inline simdjson_result< int64_t > get_int64_in_string() noexcept
Cast this JSON value (inside string) to a signed integer.
simdjson_inline simdjson_result< size_t > count_elements() &noexcept
This method scans the array and counts the number of elements.
simdjson_inline simdjson_result< value > get_value() noexcept
Cast this JSON value to a value when the document is an object or an array.
simdjson_inline simdjson_result< value > find_field(std::string_view key) &noexcept
Look up a field by name on an object (order-sensitive).
simdjson_inline simdjson_result< number_type > get_number_type() noexcept
Determine the number type (integer or floating-point number) as quickly as possible.
simdjson_inline simdjson_result< uint32_t > get_uint32() noexcept
Cast this JSON value to a 32-bit unsigned integer.
simdjson_inline simdjson_result< bool > is_scalar() noexcept
Checks whether the document is a scalar (string, number, null, Boolean).
simdjson_inline simdjson_result< std::string_view > get_wobbly_string() noexcept
Cast this JSON value to a string.
bool at_end() const noexcept
Returns true if this document has been fully parsed.
simdjson_inline simdjson_result< array > get_array() &noexcept
Cast this JSON value to an array.
simdjson_inline simdjson_result< bool > is_integer() noexcept
Checks whether the document is an integer number.
simdjson_result< const char * > current_location() const noexcept
Returns the current location in the document if in bounds.
simdjson_inline simdjson_result< T > get() &noexcept
Get this value as the given type.
simdjson_inline simdjson_result< raw_json_string > get_raw_json_string() noexcept
Cast this JSON value to a raw_json_string.
A JSON field (key/value pair) in an object.
A forward-only JSON object field iterator.
A string escaped per JSON rules, terminated with quote (").
An ephemeral JSON value returned during iteration.
int32_t depth_t
Represents the depth of a JSON value (number of nested arrays/objects).
The top level simdjson namespace, containing everything the library provides.
error_code
All possible errors returned by simdjson.
@ UNINITIALIZED
unknown error, or uninitialized document
The result of a simdjson operation that could fail.
A type representing a JSON number.
The result of a simdjson operation that could fail.
simdjson_inline error_code error() const noexcept
The error.
simdjson_warn_unused simdjson_inline error_code get(T &value) &&noexcept
Move the value to the provided variable.