added a constructor from an input stream
This commit is contained in:
parent
104c4b5286
commit
2c720b26ab
6 changed files with 176 additions and 0 deletions
55
doc/examples/basic_json__istream.cpp
Normal file
55
doc/examples/basic_json__istream.cpp
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
#include <json.hpp>
|
||||||
|
|
||||||
|
using json = nlohmann::json;
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
// a JSON text
|
||||||
|
auto text = R"(
|
||||||
|
{
|
||||||
|
"Image": {
|
||||||
|
"Width": 800,
|
||||||
|
"Height": 600,
|
||||||
|
"Title": "View from 15th Floor",
|
||||||
|
"Thumbnail": {
|
||||||
|
"Url": "http://www.example.com/image/481989943",
|
||||||
|
"Height": 125,
|
||||||
|
"Width": 100
|
||||||
|
},
|
||||||
|
"Animated" : false,
|
||||||
|
"IDs": [116, 943, 234, 38793]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)";
|
||||||
|
|
||||||
|
// fill a stream with JSON text
|
||||||
|
std::stringstream ss;
|
||||||
|
ss << text;
|
||||||
|
|
||||||
|
// create JSON from stream
|
||||||
|
json j_complete(ss);
|
||||||
|
std::cout << std::setw(4) << j_complete << "\n\n";
|
||||||
|
|
||||||
|
|
||||||
|
// define parser callback
|
||||||
|
json::parser_callback_t cb = [](int depth, json::parse_event_t event, json & parsed)
|
||||||
|
{
|
||||||
|
// skip object elements with key "Thumbnail"
|
||||||
|
if (event == json::parse_event_t::key and parsed == json("Thumbnail"))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// fill a stream with JSON text
|
||||||
|
ss.clear();
|
||||||
|
ss << text;
|
||||||
|
|
||||||
|
// create JSON from stream (with callback)
|
||||||
|
json j_filtered(ss, cb);
|
||||||
|
std::cout << std::setw(4) << j_filtered << '\n';
|
||||||
|
}
|
1
doc/examples/basic_json__istream.link
Normal file
1
doc/examples/basic_json__istream.link
Normal file
|
@ -0,0 +1 @@
|
||||||
|
<a target="_blank" href="http://melpon.org/wandbox/permlink/lUltfC5TlmxeUq5X"><b>online</b></a>
|
34
doc/examples/basic_json__istream.output
Normal file
34
doc/examples/basic_json__istream.output
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
{
|
||||||
|
"Image": {
|
||||||
|
"Animated": false,
|
||||||
|
"Height": 600,
|
||||||
|
"IDs": [
|
||||||
|
116,
|
||||||
|
943,
|
||||||
|
234,
|
||||||
|
38793
|
||||||
|
],
|
||||||
|
"Thumbnail": {
|
||||||
|
"Height": 125,
|
||||||
|
"Url": "http://www.example.com/image/481989943",
|
||||||
|
"Width": 100
|
||||||
|
},
|
||||||
|
"Title": "View from 15th Floor",
|
||||||
|
"Width": 800
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
"Image": {
|
||||||
|
"Animated": false,
|
||||||
|
"Height": 600,
|
||||||
|
"IDs": [
|
||||||
|
116,
|
||||||
|
943,
|
||||||
|
234,
|
||||||
|
38793
|
||||||
|
],
|
||||||
|
"Title": "View from 15th Floor",
|
||||||
|
"Width": 800
|
||||||
|
}
|
||||||
|
}
|
25
src/json.hpp
25
src/json.hpp
|
@ -1806,6 +1806,31 @@ class basic_json
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
@brief construct a JSON value given an input stream
|
||||||
|
|
||||||
|
@param[in,out] i stream to read a serialized JSON value from
|
||||||
|
@param[in] cb a parser callback function of type @ref parser_callback_t
|
||||||
|
which is used to control the deserialization by filtering unwanted values
|
||||||
|
(optional)
|
||||||
|
|
||||||
|
@complexity Linear in the length of the input. The parser is a predictive
|
||||||
|
LL(1) parser. The complexity can be higher if the parser callback function
|
||||||
|
@a cb has a super-linear complexity.
|
||||||
|
|
||||||
|
@note A UTF-8 byte order mark is silently ignored.
|
||||||
|
|
||||||
|
@liveexample{The example below demonstrates constructing a JSON value from
|
||||||
|
a `std::stringstream` with and without callback
|
||||||
|
function.,basic_json__istream}
|
||||||
|
|
||||||
|
@since version 2.0.0
|
||||||
|
*/
|
||||||
|
basic_json(std::istream& i, parser_callback_t cb = nullptr)
|
||||||
|
{
|
||||||
|
*this = parser(i, cb).parse();
|
||||||
|
}
|
||||||
|
|
||||||
///////////////////////////////////////
|
///////////////////////////////////////
|
||||||
// other constructors and destructor //
|
// other constructors and destructor //
|
||||||
///////////////////////////////////////
|
///////////////////////////////////////
|
||||||
|
|
|
@ -1806,6 +1806,31 @@ class basic_json
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*!
|
||||||
|
@brief construct a JSON value given an input stream
|
||||||
|
|
||||||
|
@param[in,out] i stream to read a serialized JSON value from
|
||||||
|
@param[in] cb a parser callback function of type @ref parser_callback_t
|
||||||
|
which is used to control the deserialization by filtering unwanted values
|
||||||
|
(optional)
|
||||||
|
|
||||||
|
@complexity Linear in the length of the input. The parser is a predictive
|
||||||
|
LL(1) parser. The complexity can be higher if the parser callback function
|
||||||
|
@a cb has a super-linear complexity.
|
||||||
|
|
||||||
|
@note A UTF-8 byte order mark is silently ignored.
|
||||||
|
|
||||||
|
@liveexample{The example below demonstrates constructing a JSON value from
|
||||||
|
a `std::stringstream` with and without callback
|
||||||
|
function.,basic_json__istream}
|
||||||
|
|
||||||
|
@since version 2.0.0
|
||||||
|
*/
|
||||||
|
basic_json(std::istream& i, parser_callback_t cb = nullptr)
|
||||||
|
{
|
||||||
|
*this = parser(i, cb).parse();
|
||||||
|
}
|
||||||
|
|
||||||
///////////////////////////////////////
|
///////////////////////////////////////
|
||||||
// other constructors and destructor //
|
// other constructors and destructor //
|
||||||
///////////////////////////////////////
|
///////////////////////////////////////
|
||||||
|
|
|
@ -1264,6 +1264,42 @@ TEST_CASE("constructors")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SECTION("create a JSON value from an input stream")
|
||||||
|
{
|
||||||
|
SECTION("sts::stringstream")
|
||||||
|
{
|
||||||
|
std::stringstream ss;
|
||||||
|
ss << "[\"foo\",1,2,3,false,{\"one\":1}]";
|
||||||
|
json j(ss);
|
||||||
|
CHECK(j == json({"foo", 1, 2, 3, false, {{"one", 1}}}));
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("with callback function")
|
||||||
|
{
|
||||||
|
std::stringstream ss;
|
||||||
|
ss << "[\"foo\",1,2,3,false,{\"one\":1}]";
|
||||||
|
json j(ss, [](int, json::parse_event_t, const json & val)
|
||||||
|
{
|
||||||
|
// filter all number(2) elements
|
||||||
|
if (val == json(2))
|
||||||
|
{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
CHECK(j == json({"foo", 1, 3, false, {{"one", 1}}}));
|
||||||
|
}
|
||||||
|
|
||||||
|
SECTION("std::ifstream")
|
||||||
|
{
|
||||||
|
std::ifstream f("test/json_tests/pass1.json");
|
||||||
|
json j(f);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
TEST_CASE("other constructors and destructor")
|
TEST_CASE("other constructors and destructor")
|
||||||
|
|
Loading…
Reference in a new issue