Fast Methods for Cosmological Simulations
FastSim serves as a tool for quick N-body simulations in modified gravity.
nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType > Class Template Reference

#include <json.hpp>

Public Types

using number_integer_t = typename BasicJsonType::number_integer_t
 
using number_unsigned_t = typename BasicJsonType::number_unsigned_t
 
using number_float_t = typename BasicJsonType::number_float_t
 
using string_t = typename BasicJsonType::string_t
 
using parser_callback_t = typename BasicJsonType::parser_callback_t
 
using parse_event_t = typename BasicJsonType::parse_event_t
 

Public Member Functions

 json_sax_dom_callback_parser (BasicJsonType &r, const parser_callback_t cb, const bool allow_exceptions_=true)
 
bool null ()
 
bool boolean (bool val)
 
bool number_integer (number_integer_t val)
 
bool number_unsigned (number_unsigned_t val)
 
bool number_float (number_float_t val, const string_t &)
 
bool string (string_t &val)
 
bool start_object (std::size_t len)
 
bool key (string_t &val)
 
bool end_object ()
 
bool start_array (std::size_t len)
 
bool end_array ()
 
bool parse_error (std::size_t, const std::string &, const detail::exception &ex)
 
constexpr bool is_errored () const
 

Private Member Functions

template<typename Value >
std::pair< bool, BasicJsonType * > handle_value (Value &&v, const bool skip_callback=false)
 

Private Attributes

BasicJsonType & root
 the parsed JSON value More...
 
std::vector< BasicJsonType * > ref_stack
 stack to model hierarchy of values More...
 
std::vector< bool > keep_stack
 stack to manage which values to keep More...
 
std::vector< bool > key_keep_stack
 stack to manage which object keys to keep More...
 
BasicJsonType * object_element = nullptr
 helper to hold the reference for the next object element More...
 
bool errored = false
 whether a syntax error occurred More...
 
const parser_callback_t callback = nullptr
 callback function More...
 
const bool allow_exceptions = true
 whether to throw exceptions in case of errors More...
 
BasicJsonType discarded = BasicJsonType::value_t::discarded
 a discarded value for the callback More...
 

Detailed Description

template<typename BasicJsonType>
class nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >

Definition at line 4435 of file json.hpp.

Member Typedef Documentation

template<typename BasicJsonType>
using nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::number_float_t = typename BasicJsonType::number_float_t

Definition at line 4440 of file json.hpp.

template<typename BasicJsonType>
using nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::number_integer_t = typename BasicJsonType::number_integer_t

Definition at line 4438 of file json.hpp.

template<typename BasicJsonType>
using nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::number_unsigned_t = typename BasicJsonType::number_unsigned_t

Definition at line 4439 of file json.hpp.

template<typename BasicJsonType>
using nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::parse_event_t = typename BasicJsonType::parse_event_t

Definition at line 4443 of file json.hpp.

template<typename BasicJsonType>
using nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::parser_callback_t = typename BasicJsonType::parser_callback_t

Definition at line 4442 of file json.hpp.

template<typename BasicJsonType>
using nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::string_t = typename BasicJsonType::string_t

Definition at line 4441 of file json.hpp.

Constructor & Destructor Documentation

template<typename BasicJsonType>
nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::json_sax_dom_callback_parser ( BasicJsonType &  r,
const parser_callback_t  cb,
const bool  allow_exceptions_ = true 
)
inline

Definition at line 4445 of file json.hpp.

4448  : root(r), callback(cb), allow_exceptions(allow_exceptions_)
4449  {
4450  keep_stack.push_back(true);
4451  }
const parser_callback_t callback
callback function
Definition: json.hpp:4740
const bool allow_exceptions
whether to throw exceptions in case of errors
Definition: json.hpp:4742
std::vector< bool > keep_stack
stack to manage which values to keep
Definition: json.hpp:4732
BasicJsonType & root
the parsed JSON value
Definition: json.hpp:4728

Member Function Documentation

template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::boolean ( bool  val)
inline

Definition at line 4459 of file json.hpp.

4460  {
4461  handle_value(val);
4462  return true;
4463  }
std::pair< bool, BasicJsonType * > handle_value(Value &&v, const bool skip_callback=false)
Definition: json.hpp:4665
template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::end_array ( )
inline

Definition at line 4584 of file json.hpp.

References nlohmann::detail::discarded.

4585  {
4586  bool keep = true;
4587 
4588  if (ref_stack.back())
4589  {
4590  keep = callback(static_cast<int>(ref_stack.size()) - 1, parse_event_t::array_end, *ref_stack.back());
4591  if (not keep)
4592  {
4593  // discard array
4594  *ref_stack.back() = discarded;
4595  }
4596  }
4597 
4598  assert(not ref_stack.empty());
4599  assert(not keep_stack.empty());
4600  ref_stack.pop_back();
4601  keep_stack.pop_back();
4602 
4603  // remove discarded value
4604  if (not keep and not ref_stack.empty())
4605  {
4606  if (ref_stack.back()->is_array())
4607  {
4608  ref_stack.back()->m_value.array->pop_back();
4609  }
4610  }
4611 
4612  return true;
4613  }
const parser_callback_t callback
callback function
Definition: json.hpp:4740
BasicJsonType discarded
a discarded value for the callback
Definition: json.hpp:4744
std::vector< BasicJsonType * > ref_stack
stack to model hierarchy of values
Definition: json.hpp:4730
std::vector< bool > keep_stack
stack to manage which values to keep
Definition: json.hpp:4732
template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::end_object ( )
inline

Definition at line 4528 of file json.hpp.

References nlohmann::detail::discarded.

4529  {
4530  if (ref_stack.back())
4531  {
4532  if (not callback(static_cast<int>(ref_stack.size()) - 1, parse_event_t::object_end, *ref_stack.back()))
4533  {
4534  // discard object
4535  *ref_stack.back() = discarded;
4536  }
4537  }
4538 
4539  assert(not ref_stack.empty());
4540  assert(not keep_stack.empty());
4541  ref_stack.pop_back();
4542  keep_stack.pop_back();
4543 
4544  if (not ref_stack.empty() and ref_stack.back())
4545  {
4546  // remove discarded value
4547  if (ref_stack.back()->is_object())
4548  {
4549  for (auto it = ref_stack.back()->begin(); it != ref_stack.back()->end(); ++it)
4550  {
4551  if (it->is_discarded())
4552  {
4553  ref_stack.back()->erase(it);
4554  break;
4555  }
4556  }
4557  }
4558  }
4559 
4560  return true;
4561  }
const parser_callback_t callback
callback function
Definition: json.hpp:4740
BasicJsonType discarded
a discarded value for the callback
Definition: json.hpp:4744
std::vector< BasicJsonType * > ref_stack
stack to model hierarchy of values
Definition: json.hpp:4730
std::vector< bool > keep_stack
stack to manage which values to keep
Definition: json.hpp:4732
template<typename BasicJsonType>
template<typename Value >
std::pair<bool, BasicJsonType*> nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::handle_value ( Value &&  v,
const bool  skip_callback = false 
)
inlineprivate
Parameters
[in]vvalue to add to the JSON value we build during parsing
[in]skip_callbackwhether we should skip calling the callback function; this is required after start_array() and start_object() SAX events, because otherwise we would call the callback function with an empty array or object, respectively.
Invariant
If the ref stack is empty, then the passed value will be the new root.
If the ref stack contains a value, then it is an array or an object to which we can add elements
Returns
pair of boolean (whether value should be kept) and pointer (to the passed value in the ref_stack hierarchy; nullptr if not kept)

Definition at line 4665 of file json.hpp.

References run_pk_param_space::root, and Catch::Generators::value().

4666  {
4667  assert(not keep_stack.empty());
4668 
4669  // do not handle this value if we know it would be added to a discarded
4670  // container
4671  if (not keep_stack.back())
4672  {
4673  return {false, nullptr};
4674  }
4675 
4676  // create value
4677  auto value = BasicJsonType(std::forward<Value>(v));
4678 
4679  // check callback
4680  const bool keep = skip_callback or callback(static_cast<int>(ref_stack.size()), parse_event_t::value, value);
4681 
4682  // do not handle this value if we just learnt it shall be discarded
4683  if (not keep)
4684  {
4685  return {false, nullptr};
4686  }
4687 
4688  if (ref_stack.empty())
4689  {
4690  root = std::move(value);
4691  return {true, &root};
4692  }
4693 
4694  // skip this value if we already decided to skip the parent
4695  // (https://github.com/nlohmann/json/issues/971#issuecomment-413678360)
4696  if (not ref_stack.back())
4697  {
4698  return {false, nullptr};
4699  }
4700 
4701  // we now only expect arrays and objects
4702  assert(ref_stack.back()->is_array() or ref_stack.back()->is_object());
4703 
4704  if (ref_stack.back()->is_array())
4705  {
4706  ref_stack.back()->m_value.array->push_back(std::move(value));
4707  return {true, &(ref_stack.back()->m_value.array->back())};
4708  }
4709  else
4710  {
4711  // check if we should store an element for the current key
4712  assert(not key_keep_stack.empty());
4713  const bool store_element = key_keep_stack.back();
4714  key_keep_stack.pop_back();
4715 
4716  if (not store_element)
4717  {
4718  return {false, nullptr};
4719  }
4720 
4721  assert(object_element);
4722  *object_element = std::move(value);
4723  return {true, object_element};
4724  }
4725  }
const parser_callback_t callback
callback function
Definition: json.hpp:4740
std::vector< BasicJsonType * > ref_stack
stack to model hierarchy of values
Definition: json.hpp:4730
std::vector< bool > key_keep_stack
stack to manage which object keys to keep
Definition: json.hpp:4734
std::vector< bool > keep_stack
stack to manage which values to keep
Definition: json.hpp:4732
BasicJsonType & root
the parsed JSON value
Definition: json.hpp:4728
auto value(T const &val) -> Generator< T >
Definition: catch.hpp:3177
BasicJsonType * object_element
helper to hold the reference for the next object element
Definition: json.hpp:4736
template<typename BasicJsonType>
constexpr bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::is_errored ( ) const
inline

Definition at line 4643 of file json.hpp.

Referenced by nlohmann::detail::parser< BasicJsonType >::parse().

4644  {
4645  return errored;
4646  }
bool errored
whether a syntax error occurred
Definition: json.hpp:4738
template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::key ( string_t val)
inline

Definition at line 4511 of file json.hpp.

References nlohmann::detail::discarded.

4512  {
4513  BasicJsonType k = BasicJsonType(val);
4514 
4515  // check callback for key
4516  const bool keep = callback(static_cast<int>(ref_stack.size()), parse_event_t::key, k);
4517  key_keep_stack.push_back(keep);
4518 
4519  // add discarded value at given key and store the reference for later
4520  if (keep and ref_stack.back())
4521  {
4522  object_element = &(ref_stack.back()->m_value.object->operator[](val) = discarded);
4523  }
4524 
4525  return true;
4526  }
const parser_callback_t callback
callback function
Definition: json.hpp:4740
BasicJsonType discarded
a discarded value for the callback
Definition: json.hpp:4744
std::vector< BasicJsonType * > ref_stack
stack to model hierarchy of values
Definition: json.hpp:4730
std::vector< bool > key_keep_stack
stack to manage which object keys to keep
Definition: json.hpp:4734
BasicJsonType * object_element
helper to hold the reference for the next object element
Definition: json.hpp:4736
template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::null ( )
inline

Definition at line 4453 of file json.hpp.

4454  {
4455  handle_value(nullptr);
4456  return true;
4457  }
std::pair< bool, BasicJsonType * > handle_value(Value &&v, const bool skip_callback=false)
Definition: json.hpp:4665
template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::number_float ( number_float_t  val,
const string_t  
)
inline

Definition at line 4477 of file json.hpp.

4478  {
4479  handle_value(val);
4480  return true;
4481  }
std::pair< bool, BasicJsonType * > handle_value(Value &&v, const bool skip_callback=false)
Definition: json.hpp:4665
template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::number_integer ( number_integer_t  val)
inline

Definition at line 4465 of file json.hpp.

4466  {
4467  handle_value(val);
4468  return true;
4469  }
std::pair< bool, BasicJsonType * > handle_value(Value &&v, const bool skip_callback=false)
Definition: json.hpp:4665
template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::number_unsigned ( number_unsigned_t  val)
inline

Definition at line 4471 of file json.hpp.

4472  {
4473  handle_value(val);
4474  return true;
4475  }
std::pair< bool, BasicJsonType * > handle_value(Value &&v, const bool skip_callback=false)
Definition: json.hpp:4665
template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::parse_error ( std::size_t  ,
const std::string ,
const detail::exception ex 
)
inline

Definition at line 4615 of file json.hpp.

References nlohmann::detail::exception::id, and JSON_THROW.

Referenced by nlohmann::detail::parser< BasicJsonType >::parse().

4617  {
4618  errored = true;
4619  if (allow_exceptions)
4620  {
4621  // determine the proper exception type from the id
4622  switch ((ex.id / 100) % 100)
4623  {
4624  case 1:
4625  JSON_THROW(*reinterpret_cast<const detail::parse_error*>(&ex));
4626  case 4:
4627  JSON_THROW(*reinterpret_cast<const detail::out_of_range*>(&ex));
4628  // LCOV_EXCL_START
4629  case 2:
4630  JSON_THROW(*reinterpret_cast<const detail::invalid_iterator*>(&ex));
4631  case 3:
4632  JSON_THROW(*reinterpret_cast<const detail::type_error*>(&ex));
4633  case 5:
4634  JSON_THROW(*reinterpret_cast<const detail::other_error*>(&ex));
4635  default:
4636  assert(false);
4637  // LCOV_EXCL_STOP
4638  }
4639  }
4640  return false;
4641  }
const bool allow_exceptions
whether to throw exceptions in case of errors
Definition: json.hpp:4742
#define JSON_THROW(exception)
Definition: json.hpp:162
bool errored
whether a syntax error occurred
Definition: json.hpp:4738
template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::start_array ( std::size_t  len)
inline

Definition at line 4563 of file json.hpp.

References nlohmann::detail::out_of_range::create(), nlohmann::detail::discarded, JSON_THROW, and JSON_UNLIKELY.

4564  {
4565  const bool keep = callback(static_cast<int>(ref_stack.size()), parse_event_t::array_start, discarded);
4566  keep_stack.push_back(keep);
4567 
4568  auto val = handle_value(BasicJsonType::value_t::array, true);
4569  ref_stack.push_back(val.second);
4570 
4571  // check array limit
4572  if (ref_stack.back())
4573  {
4574  if (JSON_UNLIKELY(len != std::size_t(-1) and len > ref_stack.back()->max_size()))
4575  {
4577  "excessive array size: " + std::to_string(len)));
4578  }
4579  }
4580 
4581  return true;
4582  }
const parser_callback_t callback
callback function
Definition: json.hpp:4740
BasicJsonType discarded
a discarded value for the callback
Definition: json.hpp:4744
std::vector< BasicJsonType * > ref_stack
stack to model hierarchy of values
Definition: json.hpp:4730
#define JSON_UNLIKELY(x)
Definition: json.hpp:194
#define JSON_THROW(exception)
Definition: json.hpp:162
std::pair< bool, BasicJsonType * > handle_value(Value &&v, const bool skip_callback=false)
Definition: json.hpp:4665
std::vector< bool > keep_stack
stack to manage which values to keep
Definition: json.hpp:4732
static out_of_range create(int id_, const std::string &what_arg)
Definition: json.hpp:1070
template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::start_object ( std::size_t  len)
inline

Definition at line 4489 of file json.hpp.

References nlohmann::detail::out_of_range::create(), nlohmann::detail::discarded, JSON_THROW, and JSON_UNLIKELY.

4490  {
4491  // check callback for object start
4492  const bool keep = callback(static_cast<int>(ref_stack.size()), parse_event_t::object_start, discarded);
4493  keep_stack.push_back(keep);
4494 
4495  auto val = handle_value(BasicJsonType::value_t::object, true);
4496  ref_stack.push_back(val.second);
4497 
4498  // check object limit
4499  if (ref_stack.back())
4500  {
4501  if (JSON_UNLIKELY(len != std::size_t(-1) and len > ref_stack.back()->max_size()))
4502  {
4504  "excessive object size: " + std::to_string(len)));
4505  }
4506  }
4507 
4508  return true;
4509  }
const parser_callback_t callback
callback function
Definition: json.hpp:4740
BasicJsonType discarded
a discarded value for the callback
Definition: json.hpp:4744
std::vector< BasicJsonType * > ref_stack
stack to model hierarchy of values
Definition: json.hpp:4730
#define JSON_UNLIKELY(x)
Definition: json.hpp:194
#define JSON_THROW(exception)
Definition: json.hpp:162
std::pair< bool, BasicJsonType * > handle_value(Value &&v, const bool skip_callback=false)
Definition: json.hpp:4665
std::vector< bool > keep_stack
stack to manage which values to keep
Definition: json.hpp:4732
static out_of_range create(int id_, const std::string &what_arg)
Definition: json.hpp:1070
template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::string ( string_t val)
inline

Definition at line 4483 of file json.hpp.

4484  {
4485  handle_value(val);
4486  return true;
4487  }
std::pair< bool, BasicJsonType * > handle_value(Value &&v, const bool skip_callback=false)
Definition: json.hpp:4665

Member Data Documentation

template<typename BasicJsonType>
const bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::allow_exceptions = true
private

whether to throw exceptions in case of errors

Definition at line 4742 of file json.hpp.

template<typename BasicJsonType>
const parser_callback_t nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::callback = nullptr
private

callback function

Definition at line 4740 of file json.hpp.

template<typename BasicJsonType>
BasicJsonType nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::discarded = BasicJsonType::value_t::discarded
private

a discarded value for the callback

Definition at line 4744 of file json.hpp.

template<typename BasicJsonType>
bool nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::errored = false
private

whether a syntax error occurred

Definition at line 4738 of file json.hpp.

template<typename BasicJsonType>
std::vector<bool> nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::keep_stack
private

stack to manage which values to keep

Definition at line 4732 of file json.hpp.

template<typename BasicJsonType>
std::vector<bool> nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::key_keep_stack
private

stack to manage which object keys to keep

Definition at line 4734 of file json.hpp.

template<typename BasicJsonType>
BasicJsonType* nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::object_element = nullptr
private

helper to hold the reference for the next object element

Definition at line 4736 of file json.hpp.

template<typename BasicJsonType>
std::vector<BasicJsonType*> nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::ref_stack
private

stack to model hierarchy of values

Definition at line 4730 of file json.hpp.

template<typename BasicJsonType>
BasicJsonType& nlohmann::detail::json_sax_dom_callback_parser< BasicJsonType >::root
private

the parsed JSON value

Definition at line 4728 of file json.hpp.


The documentation for this class was generated from the following file: