1 #ifndef SIMDJSON_GENERIC_ONDEMAND_PARSER_H
3 #ifndef SIMDJSON_CONDITIONAL_INCLUDE
4 #define SIMDJSON_GENERIC_ONDEMAND_PARSER_H
5 #include "simdjson/generic/ondemand/base.h"
6 #include "simdjson/generic/implementation_simdjson_result_base.h"
12 namespace SIMDJSON_IMPLEMENTATION {
20 static constexpr
size_t DEFAULT_BATCH_SIZE = 1000000;
29 static constexpr
size_t MINIMAL_BATCH_SIZE = 32;
47 simdjson_inline
parser &operator=(
const parser &other) =
delete;
48 simdjson_inline
parser &operator=(
parser &&other) noexcept =
default;
117 #ifdef SIMDJSON_EXPERIMENTAL_ALLOW_INCOMPLETE_JSON
121 simdjson_warn_unused simdjson_result<document> iterate(const char *json, size_t len, size_t capacity) & noexcept;
264 simdjson_pure simdjson_inline
size_t capacity() const noexcept;
266 simdjson_pure simdjson_inline
size_t max_capacity() const noexcept;
267 simdjson_inline
void set_max_capacity(
size_t max_capacity) noexcept;
274 simdjson_pure simdjson_inline
size_t max_depth() const noexcept;
290 #ifdef SIMDJSON_THREADS_ENABLED
350 #if SIMDJSON_DEVELOPMENT_CHECKS
358 bool string_buffer_overflow(
const uint8_t *string_buf_loc)
const noexcept;
363 std::unique_ptr<simdjson::internal::dom_parser_implementation>
implementation{};
365 size_t _max_capacity;
367 std::unique_ptr<uint8_t[]> string_buf{};
368 #if SIMDJSON_DEVELOPMENT_CHECKS
369 std::unique_ptr<token_position[]> start_positions{};
372 friend class json_iterator;
373 friend class document_stream;
A forward-only stream of documents.
A JSON fragment iterator.
simdjson_warn_unused simdjson_result< document > iterate(padded_string_view json) &noexcept
Start iterating an on-demand JSON document.
simdjson_pure simdjson_inline size_t max_capacity() const noexcept
The maximum capacity of this parser (the largest document it is allowed to process).
simdjson_inline simdjson_result< std::string_view > unescape(raw_json_string in, uint8_t *&dst, bool allow_replacement=false) const noexcept
Unescape this JSON string, replacing \ with \, with newline, etc.
~parser() noexcept=default
Deallocate the JSON parser.
simdjson_pure simdjson_inline size_t max_depth() const noexcept
The maximum depth of this parser (the most deeply nested objects and arrays it can process).
simdjson_pure simdjson_inline size_t capacity() const noexcept
The capacity of this parser (the largest document it can process).
parser(size_t max_capacity=SIMDJSON_MAXSIZE_BYTES) noexcept
Create a JSON parser.
simdjson_inline simdjson_result< std::string_view > unescape_wobbly(raw_json_string in, uint8_t *&dst) const noexcept
Unescape this JSON string, replacing \ with \, with newline, etc.
bool threaded
When SIMDJSON_THREADS_ENABLED is not defined, the parser instance cannot use threads.
simdjson_warn_unused error_code allocate(size_t capacity, size_t max_depth=DEFAULT_MAX_DEPTH) noexcept
Ensure this parser has enough memory to process JSON documents up to capacity bytes in length and max...
simdjson_result< document_stream > iterate_many(const uint8_t *buf, size_t len, size_t batch_size=DEFAULT_BATCH_SIZE, bool allow_comma_separated=false) noexcept
Parse a buffer containing many JSON documents.
A string escaped per JSON rules, terminated with quote (").
An implementation of simdjson for a particular CPU architecture.
User-provided string that promises it has extra padded bytes at the end for use with parser::parse().
The top level simdjson namespace, containing everything the library provides.
constexpr SIMDJSON_PUSH_DISABLE_UNUSED_WARNINGS size_t SIMDJSON_MAXSIZE_BYTES
The maximum document size supported by simdjson.
constexpr size_t DEFAULT_MAX_DEPTH
By default, simdjson supports this many nested objects and arrays.
error_code
All possible errors returned by simdjson.
The result of a simdjson operation that could fail.
String with extra allocation for ease of use with parser::parse()
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.