template <class Source>
static parse(const Source& s,
const basic_json_decode_options<char_type>& options = basic_json_decode_options<CharT>(),
std::function<bool(json_errc,const ser_context&)> err_handler = default_json_parsing()); (1)
template <class Source>
static basic_json parse(const Source& s,
std::function<bool(json_errc,const ser_context&)> err_handler); (2)
static basic_json parse(const char_type* s,
const basic_json_decode_options<char_type>& options = basic_json_decode_options<CharT>(),
std::function<bool(json_errc,const ser_context&)> err_handler = default_json_parsing()); (3)
static basic_json parse(const char_type* s,
std::function<bool(json_errc,const ser_context&)> err_handler); (4)
static basic_json parse(std::basic_istream<char_type>& is,
const basic_json_decode_options<char_type>& options = basic_json_decode_options<CharT>(),
std::function<bool(json_errc,const ser_context&)> err_handler = default_json_parsing()); (5)
static basic_json parse(std::istream& is,
std::function<bool(json_errc,const ser_context&)> err_handler); (6)
template <class InputIt>
static basic_json parse(InputIt first, InputIt last,
const basic_json_decode_options<char_type>& options = basic_json_decode_options<CharT>(),
std::function<bool(json_errc,const ser_context&)> err_handler = default_json_parsing()); (7) (since v0.153.0)
template <class InputIt>
static basic_json parse(InputIt first, InputIt last,
std::function<bool(json_errc,const ser_context&)> err_handler); (8)
(1) - (2) Parses JSON data from a contiguous character sequence provided by s
and returns a basic_json
value.
Throws a ser_error if parsing fails.
(3) - (4) Parses JSON data from a null-terminated string and returns a basic_json
value.
Throws a ser_error if parsing fails.
(4) - (5) Parses JSON data from an input stream and returns a basic_json
value.
Throws a ser_error if parsing fails.
(6) - (7) Parses JSON data from the range [first
,last
) and returns a basic_json
value.
Throws a ser_error if parsing fails.
s
- s string view
is
- an input stream
first
, last
- pair of LegacyInputIterators that specify a character sequence
options
- a basic_json_options
err_handler
- an error handler
try
{
json val = json::parse("[1,2,3,4,]");
}
catch(const jsoncons::ser_error& e)
{
std::cout << e.what() << std::endl;
}
Output:
Extra comma at line 1 and column 10
std::string s = R"({"field1":"NaN","field2":"PositiveInfinity","field3":"NegativeInfinity"})";
json_options options;
options.nan_to_str("NaN")
.inf_to_str("PositiveInfinity")
.neginf_to_str("NegativeInfinity");
json j = json::parse(s,options);
std::cout << "\n(1)\n" << pretty_print(j) << std::endl;
std::cout << "\n(2)\n" << pretty_print(j,options) << std::endl;
Output:
(1)
{
"field1": null,
"field2": null,
"field3": null
}
(2)
{
"field1": "NaN",
"field2": "PositiveInfinity",
"field3": "NegativeInfinity"
}
Input JSON file example.json
:
{"File Format Options":{"Color Spaces":["sRGB","AdobeRGB","ProPhoto RGB"]}}
std::ifstream is("example.json");
json j = json::parse(is);
std::cout << pretty_print(j) << std::endl;
Output:
{
"File Format Options": {
"Color Spaces": ["sRGB","AdobeRGB","ProPhoto RGB"]
}
}
#include <jsoncons/json.hpp>
class MyIterator
{
const char* p_;
public:
using iterator_category = std::input_iterator_tag;
using value_type = char;
using difference_type = std::ptrdiff_t;
using pointer = const char*;
using reference = const char&;
MyIterator(const char* p)
: p_(p)
{
}
reference operator*() const
{
return *p_;
}
pointer operator->() const
{
return p_;
}
MyIterator& operator++()
{
++p_;
return *this;
}
MyIterator operator++(int)
{
MyIterator temp(*this);
++*this;
return temp;
}
bool operator!=(const MyIterator& rhs) const
{
return p_ != rhs.p_;
}
};
int main()
{
char source[] = {'[','\"', 'f','o','o','\"',',','\"', 'b','a','r','\"',']'};
MyIterator first(source);
MyIterator last(source + sizeof(source));
json j = json::parse(first, last);
std::cout << j << "\n\n";
}
Output:
["foo","bar"]