1#ifndef SIMDJSON_ERROR_INL_H
2#define SIMDJSON_ERROR_INL_H
4#include "simdjson/error.h"
16 struct error_code_info {
21 extern SIMDJSON_DLLIMPORTEXPORT
const error_code_info error_codes[];
27 return internal::error_codes[int(error)].message;
31#ifndef SIMDJSON_DISABLE_DEPRECATED_API
36 return internal::error_codes[error].message;
40inline std::ostream& operator<<(std::ostream& out,
error_code error)
noexcept {
51simdjson_inline
void simdjson_result_base<T>::tie(T &value,
error_code &error) &&
noexcept {
54 value = std::forward<simdjson_result_base<T>>(*this).first;
59simdjson_warn_unused simdjson_inline
error_code simdjson_result_base<T>::get(T &value) &&
noexcept {
61 std::forward<simdjson_result_base<T>>(*this).tie(value, error);
66simdjson_inline
error_code simdjson_result_base<T>::error() const noexcept {
72simdjson_inline
bool simdjson_result_base<T>::has_value() const noexcept {
73 return this->error() ==
SUCCESS;
76#if SIMDJSON_EXCEPTIONS
80simdjson_inline T& simdjson_result_base<T>::operator*() &
noexcept(
false) {
85simdjson_inline T&& simdjson_result_base<T>::operator*() &&
noexcept(
false) {
86 return std::forward<internal::simdjson_result_base<T>>(*this).value();
90simdjson_inline T* simdjson_result_base<T>::operator->() noexcept(false) {
91 if (this->error()) {
throw simdjson_error(this->error()); }
97simdjson_inline
const T* simdjson_result_base<T>::operator->() const noexcept(false) {
98 if (this->error()) {
throw simdjson_error(this->error()); }
103simdjson_inline T& simdjson_result_base<T>::value() &
noexcept(
false) {
104 if (error()) {
throw simdjson_error(error()); }
109simdjson_inline T&& simdjson_result_base<T>::value() &&
noexcept(
false) {
110 return std::forward<simdjson_result_base<T>>(*this).take_value();
114simdjson_inline T&& simdjson_result_base<T>::take_value() &&
noexcept(
false) {
115 if (error()) {
throw simdjson_error(error()); }
116 return std::forward<T>(this->first);
120simdjson_inline simdjson_result_base<T>::operator T&&() &&
noexcept(
false) {
121 return std::forward<simdjson_result_base<T>>(*this).take_value();
128simdjson_inline
const T& simdjson_result_base<T>::value_unsafe() const& noexcept {
133simdjson_inline T&& simdjson_result_base<T>::value_unsafe() &&
noexcept {
134 return std::forward<T>(this->first);
138simdjson_inline simdjson_result_base<T>::simdjson_result_base(T &&value,
error_code error) noexcept
139 : std::pair<T, error_code>(std::forward<T>(value), error) {}
141simdjson_inline simdjson_result_base<T>::simdjson_result_base(
error_code error) noexcept
142 : simdjson_result_base(T{}, error) {}
144simdjson_inline simdjson_result_base<T>::simdjson_result_base(T &&value) noexcept
145 : simdjson_result_base(std::forward<T>(value),
SUCCESS) {}
147simdjson_inline simdjson_result_base<T>::simdjson_result_base() noexcept
158 std::forward<internal::simdjson_result_base<T>>(*this).tie(value, error);
162simdjson_warn_unused simdjson_inline
error_code
164 return std::forward<internal::simdjson_result_base<T>>(*this).get(value);
169 return internal::simdjson_result_base<T>::error();
172#if SIMDJSON_EXCEPTIONS
176 return internal::simdjson_result_base<T>::value();
181 return std::forward<internal::simdjson_result_base<T>>(*this).value();
186 return std::forward<internal::simdjson_result_base<T>>(*this).take_value();
191 return std::forward<internal::simdjson_result_base<T>>(*this).
take_value();
198 return internal::simdjson_result_base<T>::value_unsafe();
203 return std::forward<internal::simdjson_result_base<T>>(*this).value_unsafe();
208 : internal::simdjson_result_base<T>(std::forward<T>(value), error) {}
210simdjson_inline simdjson_result<T>::simdjson_result(
error_code error) noexcept
211 : internal::simdjson_result_base<T>(error) {}
213simdjson_inline simdjson_result<T>::simdjson_result(T &&value) noexcept
214 : internal::simdjson_result_base<T>(std::forward<T>(value)) {}
216simdjson_inline simdjson_result<T>::simdjson_result() noexcept
217 : internal::simdjson_result_base<T>() {}
The top level simdjson namespace, containing everything the library provides.
const char * error_message(error_code error) noexcept
It is the convention throughout the code that the macro SIMDJSON_DEVELOPMENT_CHECKS determines whethe...
error_code
All possible errors returned by simdjson.
@ TAPE_ERROR
Something went wrong, this is a generic error. Fatal/unrecoverable error.
@ NUM_ERROR_CODES
Placeholder for end of error code list.
@ INCOMPLETE_ARRAY_OR_OBJECT
The document ends early. Fatal/unrecoverable error.
@ UNEXPECTED_ERROR
indicative of a bug in simdjson
@ UNINITIALIZED
unknown error, or uninitialized document
bool is_fatal(error_code error) noexcept
Some errors are fatal and invalidate the document.
The result of a simdjson operation that could fail.
simdjson_inline error_code error() const noexcept
The error.
simdjson_inline T & value() &noexcept(false)
Get the result value.
simdjson_inline T && take_value() &&noexcept(false)
Take the result value (move it).
simdjson_inline void tie(T &value, error_code &error) &&noexcept
Move the value and the error to the provided variables.
simdjson_warn_unused simdjson_inline error_code get(T &value) &&noexcept
Move the value to the provided variable.
simdjson_inline const T & value_unsafe() const &noexcept
Get the result value.