Replace default_callback
function with nullptr
and check for null callback function before calling it. This is cleaner and better performing.
This commit is contained in:
parent
76d3433e6c
commit
ef54ace4d2
1 changed files with 12 additions and 18 deletions
|
@ -291,12 +291,6 @@ class basic_json
|
||||||
using parser_callback_t = std::function<bool(int depth, parse_event_t event,
|
using parser_callback_t = std::function<bool(int depth, parse_event_t event,
|
||||||
const basic_json& parsed)>;
|
const basic_json& parsed)>;
|
||||||
|
|
||||||
/// default parser callback returns true to keep all elements
|
|
||||||
static bool default_callback(int, parse_event_t, const basic_json&)
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
@brief comparison operator for JSON value types
|
@brief comparison operator for JSON value types
|
||||||
|
|
||||||
|
@ -2002,13 +1996,13 @@ class basic_json
|
||||||
/////////////////////
|
/////////////////////
|
||||||
|
|
||||||
/// deserialize from string
|
/// deserialize from string
|
||||||
static basic_json parse(const string_t& s, parser_callback_t cb = default_callback)
|
static basic_json parse(const string_t& s, parser_callback_t cb = nullptr)
|
||||||
{
|
{
|
||||||
return parser(s, cb).parse();
|
return parser(s, cb).parse();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// deserialize from stream
|
/// deserialize from stream
|
||||||
static basic_json parse(std::istream& i, parser_callback_t cb = default_callback)
|
static basic_json parse(std::istream& i, parser_callback_t cb = nullptr)
|
||||||
{
|
{
|
||||||
return parser(i, cb).parse();
|
return parser(i, cb).parse();
|
||||||
}
|
}
|
||||||
|
@ -3893,14 +3887,14 @@ class basic_json
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/// constructor for strings
|
/// constructor for strings
|
||||||
inline parser(const string_t& s, parser_callback_t cb = default_callback) : callback(cb), m_lexer(s)
|
inline parser(const string_t& s, parser_callback_t cb = nullptr) : callback(cb), m_lexer(s)
|
||||||
{
|
{
|
||||||
// read first token
|
// read first token
|
||||||
get_token();
|
get_token();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// a parser reading from an input stream
|
/// a parser reading from an input stream
|
||||||
inline parser(std::istream& _is, parser_callback_t cb = default_callback) : callback(cb),
|
inline parser(std::istream& _is, parser_callback_t cb = nullptr) : callback(cb),
|
||||||
m_lexer(&_is)
|
m_lexer(&_is)
|
||||||
{
|
{
|
||||||
// read first token
|
// read first token
|
||||||
|
@ -3927,7 +3921,7 @@ class basic_json
|
||||||
{
|
{
|
||||||
case (lexer::token_type::begin_object):
|
case (lexer::token_type::begin_object):
|
||||||
{
|
{
|
||||||
if (keep and (keep = callback(depth++, parse_event_t::object_start, result)))
|
if (keep and (not callback or (keep = callback(depth++, parse_event_t::object_start, result))))
|
||||||
{
|
{
|
||||||
// explicitly set result to object to cope with {}
|
// explicitly set result to object to cope with {}
|
||||||
result.m_type = value_t::object;
|
result.m_type = value_t::object;
|
||||||
|
@ -3941,7 +3935,7 @@ class basic_json
|
||||||
if (last_token == lexer::token_type::end_object)
|
if (last_token == lexer::token_type::end_object)
|
||||||
{
|
{
|
||||||
get_token();
|
get_token();
|
||||||
if (keep and not (keep = callback(--depth, parse_event_t::object_end, result)))
|
if (keep and callback and not callback(--depth, parse_event_t::object_end, result))
|
||||||
{
|
{
|
||||||
result = basic_json(value_t::discarded);
|
result = basic_json(value_t::discarded);
|
||||||
}
|
}
|
||||||
|
@ -3967,7 +3961,7 @@ class basic_json
|
||||||
bool keep_tag = false;
|
bool keep_tag = false;
|
||||||
if (keep)
|
if (keep)
|
||||||
{
|
{
|
||||||
keep_tag = callback(depth, parse_event_t::key, basic_json(key));
|
keep_tag = callback ? callback(depth, parse_event_t::key, basic_json(key)) : true;
|
||||||
}
|
}
|
||||||
|
|
||||||
// parse separator (:)
|
// parse separator (:)
|
||||||
|
@ -3987,7 +3981,7 @@ class basic_json
|
||||||
// closing }
|
// closing }
|
||||||
expect(lexer::token_type::end_object);
|
expect(lexer::token_type::end_object);
|
||||||
get_token();
|
get_token();
|
||||||
if (keep and not callback(--depth, parse_event_t::object_end, result))
|
if (keep and callback and not callback(--depth, parse_event_t::object_end, result))
|
||||||
{
|
{
|
||||||
result = basic_json(value_t::discarded);
|
result = basic_json(value_t::discarded);
|
||||||
}
|
}
|
||||||
|
@ -3997,7 +3991,7 @@ class basic_json
|
||||||
|
|
||||||
case (lexer::token_type::begin_array):
|
case (lexer::token_type::begin_array):
|
||||||
{
|
{
|
||||||
if (keep and (keep = callback(depth++, parse_event_t::array_start, result)))
|
if (keep and (not callback or (keep = callback(depth++, parse_event_t::array_start, result))))
|
||||||
{
|
{
|
||||||
// explicitly set result to object to cope with []
|
// explicitly set result to object to cope with []
|
||||||
result.m_type = value_t::array;
|
result.m_type = value_t::array;
|
||||||
|
@ -4011,7 +4005,7 @@ class basic_json
|
||||||
if (last_token == lexer::token_type::end_array)
|
if (last_token == lexer::token_type::end_array)
|
||||||
{
|
{
|
||||||
get_token();
|
get_token();
|
||||||
if (not callback(--depth, parse_event_t::array_end, result))
|
if (callback and not callback(--depth, parse_event_t::array_end, result))
|
||||||
{
|
{
|
||||||
result = basic_json(value_t::discarded);
|
result = basic_json(value_t::discarded);
|
||||||
}
|
}
|
||||||
|
@ -4042,7 +4036,7 @@ class basic_json
|
||||||
// closing ]
|
// closing ]
|
||||||
expect(lexer::token_type::end_array);
|
expect(lexer::token_type::end_array);
|
||||||
get_token();
|
get_token();
|
||||||
if (keep and not callback(--depth, parse_event_t::array_end, result))
|
if (keep and callback and not callback(--depth, parse_event_t::array_end, result))
|
||||||
{
|
{
|
||||||
result = basic_json(value_t::discarded);
|
result = basic_json(value_t::discarded);
|
||||||
}
|
}
|
||||||
|
@ -4119,7 +4113,7 @@ class basic_json
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (keep and not callback(depth, parse_event_t::value, result))
|
if (keep and callback and not callback(depth, parse_event_t::value, result))
|
||||||
{
|
{
|
||||||
result = basic_json(value_t::discarded);
|
result = basic_json(value_t::discarded);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue