1
0
mirror of https://github.com/nlohmann/json.git synced 2025-07-28 12:02:00 +03:00

BSON: Bugfix for non-empty arrays

This commit is contained in:
Julian Becker
2018-09-15 14:08:38 +02:00
parent cf485c2907
commit df33a90774
3 changed files with 55 additions and 54 deletions

View File

@ -6141,17 +6141,21 @@ class binary_reader
return success;
}
void parse_bson_entries()
void parse_bson_entries(bool is_array)
{
while (auto entry_type = get())
{
string_t key;
get_bson_cstr(key);
if (!is_array)
{
sax->key(key);
}
switch (entry_type)
{
case 0x01: // double
{
string_t key;
get_bson_cstr(key);
sax->key(key);
double number;
get_number_little_endian(number);
sax->number_float(static_cast<number_float_t>(number), "");
@ -6159,9 +6163,6 @@ class binary_reader
break;
case 0x02: // string
{
string_t key;
get_bson_cstr(key);
sax->key(key);
std::int32_t len;
string_t value;
get_number_little_endian(len);
@ -6172,17 +6173,11 @@ class binary_reader
break;
case 0x08: // boolean
{
string_t key;
get_bson_cstr(key);
sax->key(key);
sax->boolean(static_cast<bool>(get()));
}
break;
case 0x10: // int32
{
string_t key;
get_bson_cstr(key);
sax->key(key);
std::int32_t value;
get_number_little_endian(value);
sax->number_integer(static_cast<std::int32_t>(value));
@ -6190,9 +6185,6 @@ class binary_reader
break;
case 0x12: // int64
{
string_t key;
get_bson_cstr(key);
sax->key(key);
std::int64_t value;
get_number_little_endian(value);
sax->number_integer(static_cast<std::int64_t>(value));
@ -6200,25 +6192,16 @@ class binary_reader
break;
case 0x0A: // null
{
string_t key;
get_bson_cstr(key);
sax->key(key);
sax->null();
}
break;
case 0x03: // object
{
string_t key;
get_bson_cstr(key);
sax->key(key);
parse_bson_internal();
}
break;
case 0x04: // array
{
string_t key;
get_bson_cstr(key);
sax->key(key);
parse_bson_array();
}
break;
@ -6236,7 +6219,7 @@ class binary_reader
return false;
}
parse_bson_entries();
parse_bson_entries(/*is_array*/true);
const auto result = sax->end_array();
@ -6253,7 +6236,7 @@ class binary_reader
return false;
}
parse_bson_entries();
parse_bson_entries(/*is_array*/false);
const auto result = sax->end_object();