Decodes a Binary JSON (BSON) data format into a C++ data structure.
#include <jsoncons_ext/bson/bson.hpp>
template<class T>
T decode_bson(const std::vector<uint8_t>& source,
const bson_decode_options& options = bson_decode_options()); (1) (until 0.152.0)
template<class T, class Source>
T decode_bson(const Source& source,
const bson_decode_options& options = bson_decode_options()); (1) (since 0.152.0)
template<class T>
T decode_bson(std::istream& is,
const bson_decode_options& options = bson_decode_options()); (2)
template<class T, class InputIt>
T decode_bson(InputIt first, InputIt last,
const bson_decode_options& options = bson_decode_options()); (3) (since 0.153.0)
template<class T, class Source,class Allocator,class TempAllocator>
T decode_bson(const allocator_set<Allocator,TempAllocator>& alloc_set,
const Source& source,
const bson_decode_options& options = bson_decode_options()); (4) (since 0.171.0)
template<class T,class Allocator,class TempAllocator>
T decode_bson(const allocator_set<Allocator,TempAllocator>& alloc_set,
std::istream& is,
const bson_decode_options& options = bson_decode_options()); (5) (since 0.171.0)
(1) Reads BSON data from a contiguous byte sequence provided by source
into a type T, using the specified (or defaulted) options.
Type Source
must be a container that has member functions data()
and size()
,
and member type value_type
with size exactly 8 bits (since 0.152.0.)
Any of the values types int8_t
, uint8_t
, char
, unsigned char
and std::byte
(since C++17) are allowed.
Type 'T' must be an instantiation of basic_json
or support json_type_traits.
(2) Reads BSON data from a binary stream into a type T, using the specified (or defaulted) options. Type 'T' must be an instantiation of basic_json or support json_type_traits.
(3) Reads BSON data from the range [first
,last
) into a type T, using the specified (or defaulted) options.
Type 'T' must be an instantiation of basic_json
or support json_type_traits.
Functions (4)-(5) are identical to (1)-(2) except an allocator_set is passed as an additional argument and provides allocators for result data and temporary allocations.
Throws a ser_error if parsing fails, and a conv_error if type conversion fails.
#include <jsoncons/json.hpp>
#include <jsoncons_ext/bson/bson.hpp>
#include <iostream>
int main()
{
std::vector<uint8_t> input = { 0x13,0x00,0x00,0x00, // Document has 19 bytes
0x05, // Binary data
0x70,0x44,0x00, // "pD"
0x05,0x00,0x00,0x00, // Length is 5
0x80, // Subtype is 128
0x48,0x65,0x6c,0x6c,0x6f, // 'H','e','l','l','o'
0x00 // terminating null
};
json j = bson::decode_bson<json>(input);
std::cout << "JSON:\n" << pretty_print(j) << "\n\n";
std::cout << "tag: " << j["pD"].tag() << "\n";
std::cout << "ext_tag: " << j["pD"].ext_tag() << "\n";
auto bytes = j["pD"].as<std::vector<uint8_t>>();
std::cout << "binary data: " << byte_string_view{ bytes } << "\n";
}
Output:
JSON:
{
"pD": "SGVsbG8"
}
tag: ext
ext_tag: 128
binary data: 48,65,6c,6c,6f
Note that printing a json value by default encodes byte strings as base64url strings, but the json value holds the actual bytes.
encode_bson encodes a json value to the Binary JSON data format.