Commit 87c250d8 by Niels

another commit to trigger coverage

parent cc274f81
...@@ -909,31 +909,37 @@ class basic_json ...@@ -909,31 +909,37 @@ class basic_json
{ {
break; break;
} }
case (value_t::number_integer): case (value_t::number_integer):
{ {
m_value.number_integer = 0; m_value.number_integer = 0;
break; break;
} }
case (value_t::number_float): case (value_t::number_float):
{ {
m_value.number_float = 0.0; m_value.number_float = 0.0;
break; break;
} }
case (value_t::boolean): case (value_t::boolean):
{ {
m_value.boolean = false; m_value.boolean = false;
break; break;
} }
case (value_t::string): case (value_t::string):
{ {
m_value.string->clear(); m_value.string->clear();
break; break;
} }
case (value_t::array): case (value_t::array):
{ {
m_value.array->clear(); m_value.array->clear();
break; break;
} }
case (value_t::object): case (value_t::object):
{ {
m_value.object->clear(); m_value.object->clear();
...@@ -2612,704 +2618,359 @@ class basic_json ...@@ -2612,704 +2618,359 @@ class basic_json
const lexer_char_t* marker; const lexer_char_t* marker;
// set up RE2C // set up RE2C
for (;;) for (;;)
{ {
// set current to the begin of the buffer // set current to the begin of the buffer
current_re2c = buffer_re2c; current_re2c = buffer_re2c;
{
lexer_char_t yych;
unsigned int yyaccept = 0;
static const unsigned char yybm[] = {
64, 64, 64, 64, 64, 64, 64, 64,
64, 192, 192, 64, 64, 192, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
192, 64, 0, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
96, 96, 96, 96, 96, 96, 96, 96,
96, 96, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 0, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
64, 64, 64, 64, 64, 64, 64, 64,
};
{ yych = *buffer_re2c;
lexer_char_t yych; if (yych <= ':') {
unsigned int yyaccept = 0; if (yych <= '!') {
static const unsigned char yybm[] = if (yych <= '\f') {
{ if (yych <= 0x08) goto json_parser_3;
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= '\n') goto json_parser_5;
64, 192, 192, 64, 64, 192, 64, 64, goto json_parser_3;
64, 64, 64, 64, 64, 64, 64, 64, } else {
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= '\r') goto json_parser_5;
192, 64, 0, 64, 64, 64, 64, 64, if (yych == ' ') goto json_parser_5;
64, 64, 64, 64, 64, 64, 64, 64, goto json_parser_3;
96, 96, 96, 96, 96, 96, 96, 96, }
96, 96, 64, 64, 64, 64, 64, 64, } else {
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= '-') {
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= '"') goto json_parser_6;
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= '+') goto json_parser_3;
64, 64, 64, 64, 0, 64, 64, 64, if (yych <= ',') goto json_parser_7;
64, 64, 64, 64, 64, 64, 64, 64, goto json_parser_9;
64, 64, 64, 64, 64, 64, 64, 64, } else {
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= '/') goto json_parser_3;
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= '0') goto json_parser_10;
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= '9') goto json_parser_12;
64, 64, 64, 64, 64, 64, 64, 64, goto json_parser_13;
64, 64, 64, 64, 64, 64, 64, 64, }
64, 64, 64, 64, 64, 64, 64, 64, }
64, 64, 64, 64, 64, 64, 64, 64, } else {
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= 'm') {
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= '\\') {
64, 64, 64, 64, 64, 64, 64, 64, if (yych == '[') goto json_parser_15;
64, 64, 64, 64, 64, 64, 64, 64, goto json_parser_3;
64, 64, 64, 64, 64, 64, 64, 64, } else {
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= ']') goto json_parser_17;
64, 64, 64, 64, 64, 64, 64, 64, if (yych == 'f') goto json_parser_19;
64, 64, 64, 64, 64, 64, 64, 64, goto json_parser_3;
64, 64, 64, 64, 64, 64, 64, 64, }
64, 64, 64, 64, 64, 64, 64, 64, } else {
64, 64, 64, 64, 64, 64, 64, 64, if (yych <= 'z') {
}; if (yych <= 'n') goto json_parser_20;
if (yych == 't') goto json_parser_21;
yych = *buffer_re2c; goto json_parser_3;
if (yych <= ':') } else {
{ if (yych <= '{') goto json_parser_22;
if (yych <= '!') if (yych == '}') goto json_parser_24;
{ goto json_parser_3;
if (yych <= '\f') }
{ }
if (yych <= 0x08) }
{
goto json_parser_3;
}
if (yych <= '\n')
{
goto json_parser_5;
}
goto json_parser_3;
}
else
{
if (yych <= '\r')
{
goto json_parser_5;
}
if (yych == ' ')
{
goto json_parser_5;
}
goto json_parser_3;
}
}
else
{
if (yych <= '-')
{
if (yych <= '"')
{
goto json_parser_6;
}
if (yych <= '+')
{
goto json_parser_3;
}
if (yych <= ',')
{
goto json_parser_7;
}
goto json_parser_9;
}
else
{
if (yych <= '/')
{
goto json_parser_3;
}
if (yych <= '0')
{
goto json_parser_10;
}
if (yych <= '9')
{
goto json_parser_12;
}
goto json_parser_13;
}
}
}
else
{
if (yych <= 'm')
{
if (yych <= '\\')
{
if (yych == '[')
{
goto json_parser_15;
}
goto json_parser_3;
}
else
{
if (yych <= ']')
{
goto json_parser_17;
}
if (yych == 'f')
{
goto json_parser_19;
}
goto json_parser_3;
}
}
else
{
if (yych <= 'z')
{
if (yych <= 'n')
{
goto json_parser_20;
}
if (yych == 't')
{
goto json_parser_21;
}
goto json_parser_3;
}
else
{
if (yych <= '{')
{
goto json_parser_22;
}
if (yych == '}')
{
goto json_parser_24;
}
goto json_parser_3;
}
}
}
json_parser_2: json_parser_2:
{ { continue; }
continue;
}
json_parser_3: json_parser_3:
++buffer_re2c; ++buffer_re2c;
json_parser_4: json_parser_4:
{ { return last_token = token_type::parse_error; }
return last_token = token_type::parse_error;
}
json_parser_5: json_parser_5:
yych = *++buffer_re2c; yych = *++buffer_re2c;
goto json_parser_60; goto json_parser_60;
json_parser_6: json_parser_6:
yyaccept = 0; yyaccept = 0;
yych = *(marker = ++buffer_re2c); yych = *(marker = ++buffer_re2c);
goto json_parser_51; goto json_parser_51;
json_parser_7: json_parser_7:
++buffer_re2c; ++buffer_re2c;
{ { return last_token = token_type::value_separator; }
return last_token = token_type::value_separator;
}
json_parser_9: json_parser_9:
yych = *++buffer_re2c; yych = *++buffer_re2c;
if (yych <= '/') if (yych <= '/') goto json_parser_4;
{ if (yych <= '0') goto json_parser_49;
goto json_parser_4; if (yych <= '9') goto json_parser_40;
} goto json_parser_4;
if (yych <= '0')
{
goto json_parser_49;
}
if (yych <= '9')
{
goto json_parser_40;
}
goto json_parser_4;
json_parser_10: json_parser_10:
yyaccept = 1; yyaccept = 1;
yych = *(marker = ++buffer_re2c); yych = *(marker = ++buffer_re2c);
if (yych <= 'D') if (yych <= 'D') {
{ if (yych == '.') goto json_parser_42;
if (yych == '.') } else {
{ if (yych <= 'E') goto json_parser_43;
goto json_parser_42; if (yych == 'e') goto json_parser_43;
} }
}
else
{
if (yych <= 'E')
{
goto json_parser_43;
}
if (yych == 'e')
{
goto json_parser_43;
}
}
json_parser_11: json_parser_11:
{ { return last_token = token_type::value_number; }
return last_token = token_type::value_number;
}
json_parser_12: json_parser_12:
yyaccept = 1; yyaccept = 1;
yych = *(marker = ++buffer_re2c); yych = *(marker = ++buffer_re2c);
goto json_parser_41; goto json_parser_41;
json_parser_13: json_parser_13:
++buffer_re2c; ++buffer_re2c;
{ { return last_token = token_type::name_separator; }
return last_token = token_type::name_separator;
}
json_parser_15: json_parser_15:
++buffer_re2c; ++buffer_re2c;
{ { return last_token = token_type::begin_array; }
return last_token = token_type::begin_array;
}
json_parser_17: json_parser_17:
++buffer_re2c; ++buffer_re2c;
{ { return last_token = token_type::end_array; }
return last_token = token_type::end_array;
}
json_parser_19: json_parser_19:
yyaccept = 0; yyaccept = 0;
yych = *(marker = ++buffer_re2c); yych = *(marker = ++buffer_re2c);
if (yych == 'a') if (yych == 'a') goto json_parser_35;
{ goto json_parser_4;
goto json_parser_35;
}
goto json_parser_4;
json_parser_20: json_parser_20:
yyaccept = 0; yyaccept = 0;
yych = *(marker = ++buffer_re2c); yych = *(marker = ++buffer_re2c);
if (yych == 'u') if (yych == 'u') goto json_parser_31;
{ goto json_parser_4;
goto json_parser_31;
}
goto json_parser_4;
json_parser_21: json_parser_21:
yyaccept = 0; yyaccept = 0;
yych = *(marker = ++buffer_re2c); yych = *(marker = ++buffer_re2c);
if (yych == 'r') if (yych == 'r') goto json_parser_26;
{ goto json_parser_4;
goto json_parser_26;
}
goto json_parser_4;
json_parser_22: json_parser_22:
++buffer_re2c; ++buffer_re2c;
{ { return last_token = token_type::begin_object; }
return last_token = token_type::begin_object;
}
json_parser_24: json_parser_24:
++buffer_re2c; ++buffer_re2c;
{ { return last_token = token_type::end_object; }
return last_token = token_type::end_object;
}
json_parser_26: json_parser_26:
yych = *++buffer_re2c; yych = *++buffer_re2c;
if (yych == 'u') if (yych == 'u') goto json_parser_28;
{
goto json_parser_28;
}
json_parser_27: json_parser_27:
buffer_re2c = marker; buffer_re2c = marker;
if (yyaccept == 0) if (yyaccept == 0) {
{ goto json_parser_4;
goto json_parser_4; } else {
} goto json_parser_11;
else }
{
goto json_parser_11;
}
json_parser_28: json_parser_28:
yych = *++buffer_re2c; yych = *++buffer_re2c;
if (yych != 'e') if (yych != 'e') goto json_parser_27;
{ ++buffer_re2c;
goto json_parser_27; { return last_token = token_type::literal_true; }
}
++buffer_re2c;
{
return last_token = token_type::literal_true;
}
json_parser_31: json_parser_31:
yych = *++buffer_re2c; yych = *++buffer_re2c;
if (yych != 'l') if (yych != 'l') goto json_parser_27;
{ yych = *++buffer_re2c;
goto json_parser_27; if (yych != 'l') goto json_parser_27;
} ++buffer_re2c;
yych = *++buffer_re2c; { return last_token = token_type::literal_null; }
if (yych != 'l')
{
goto json_parser_27;
}
++buffer_re2c;
{
return last_token = token_type::literal_null;
}
json_parser_35: json_parser_35:
yych = *++buffer_re2c; yych = *++buffer_re2c;
if (yych != 'l') if (yych != 'l') goto json_parser_27;
{ yych = *++buffer_re2c;
goto json_parser_27; if (yych != 's') goto json_parser_27;
} yych = *++buffer_re2c;
yych = *++buffer_re2c; if (yych != 'e') goto json_parser_27;
if (yych != 's') ++buffer_re2c;
{ { return last_token = token_type::literal_false; }
goto json_parser_27;
}
yych = *++buffer_re2c;
if (yych != 'e')
{
goto json_parser_27;
}
++buffer_re2c;
{
return last_token = token_type::literal_false;
}
json_parser_40: json_parser_40:
yyaccept = 1; yyaccept = 1;
marker = ++buffer_re2c; marker = ++buffer_re2c;
yych = *buffer_re2c; yych = *buffer_re2c;
json_parser_41: json_parser_41:
if (yybm[0 + yych] & 32) if (yybm[0+yych] & 32) {
{ goto json_parser_40;
goto json_parser_40; }
} if (yych <= 'D') {
if (yych <= 'D') if (yych != '.') goto json_parser_11;
{ } else {
if (yych != '.') if (yych <= 'E') goto json_parser_43;
{ if (yych == 'e') goto json_parser_43;
goto json_parser_11; goto json_parser_11;
} }
}
else
{
if (yych <= 'E')
{
goto json_parser_43;
}
if (yych == 'e')
{
goto json_parser_43;
}
goto json_parser_11;
}
json_parser_42: json_parser_42:
yych = *++buffer_re2c; yych = *++buffer_re2c;
if (yych <= '/') if (yych <= '/') goto json_parser_27;
{ if (yych <= '9') goto json_parser_47;
goto json_parser_27; goto json_parser_27;
}
if (yych <= '9')
{
goto json_parser_47;
}
goto json_parser_27;
json_parser_43: json_parser_43:
yych = *++buffer_re2c; yych = *++buffer_re2c;
if (yych <= ',') if (yych <= ',') {
{ if (yych != '+') goto json_parser_27;
if (yych != '+') } else {
{ if (yych <= '-') goto json_parser_44;
goto json_parser_27; if (yych <= '/') goto json_parser_27;
} if (yych <= '9') goto json_parser_45;
} goto json_parser_27;
else }
{
if (yych <= '-')
{
goto json_parser_44;
}
if (yych <= '/')
{
goto json_parser_27;
}
if (yych <= '9')
{
goto json_parser_45;
}
goto json_parser_27;
}
json_parser_44: json_parser_44:
yych = *++buffer_re2c; yych = *++buffer_re2c;
if (yych <= '/') if (yych <= '/') goto json_parser_27;
{ if (yych >= ':') goto json_parser_27;
goto json_parser_27;
}
if (yych >= ':')
{
goto json_parser_27;
}
json_parser_45: json_parser_45:
++buffer_re2c; ++buffer_re2c;
yych = *buffer_re2c; yych = *buffer_re2c;
if (yych <= '/') if (yych <= '/') goto json_parser_11;
{ if (yych <= '9') goto json_parser_45;
goto json_parser_11; goto json_parser_11;
}
if (yych <= '9')
{
goto json_parser_45;
}
goto json_parser_11;
json_parser_47: json_parser_47:
yyaccept = 1; yyaccept = 1;
marker = ++buffer_re2c; marker = ++buffer_re2c;
yych = *buffer_re2c; yych = *buffer_re2c;
if (yych <= 'D') if (yych <= 'D') {
{ if (yych <= '/') goto json_parser_11;
if (yych <= '/') if (yych <= '9') goto json_parser_47;
{ goto json_parser_11;
goto json_parser_11; } else {
} if (yych <= 'E') goto json_parser_43;
if (yych <= '9') if (yych == 'e') goto json_parser_43;
{ goto json_parser_11;
goto json_parser_47; }
}
goto json_parser_11;
}
else
{
if (yych <= 'E')
{
goto json_parser_43;
}
if (yych == 'e')
{
goto json_parser_43;
}
goto json_parser_11;
}
json_parser_49: json_parser_49:
yyaccept = 1; yyaccept = 1;
yych = *(marker = ++buffer_re2c); yych = *(marker = ++buffer_re2c);
if (yych <= 'D') if (yych <= 'D') {
{ if (yych == '.') goto json_parser_42;
if (yych == '.') goto json_parser_11;
{ } else {
goto json_parser_42; if (yych <= 'E') goto json_parser_43;
} if (yych == 'e') goto json_parser_43;
goto json_parser_11; goto json_parser_11;
} }
else
{
if (yych <= 'E')
{
goto json_parser_43;
}
if (yych == 'e')
{
goto json_parser_43;
}
goto json_parser_11;
}
json_parser_50: json_parser_50:
++buffer_re2c; ++buffer_re2c;
yych = *buffer_re2c; yych = *buffer_re2c;
json_parser_51: json_parser_51:
if (yybm[0 + yych] & 64) if (yybm[0+yych] & 64) {
{ goto json_parser_50;
goto json_parser_50; }
} if (yych <= '"') goto json_parser_53;
if (yych <= '"') ++buffer_re2c;
{ yych = *buffer_re2c;
goto json_parser_53; if (yych <= 'e') {
} if (yych <= '/') {
++buffer_re2c; if (yych == '"') goto json_parser_50;
yych = *buffer_re2c; if (yych <= '.') goto json_parser_27;
if (yych <= 'e') goto json_parser_50;
{ } else {
if (yych <= '/') if (yych <= '\\') {
{ if (yych <= '[') goto json_parser_27;
if (yych == '"') goto json_parser_50;
{ } else {
goto json_parser_50; if (yych == 'b') goto json_parser_50;
} goto json_parser_27;
if (yych <= '.') }
{ }
goto json_parser_27; } else {
} if (yych <= 'q') {
goto json_parser_50; if (yych <= 'f') goto json_parser_50;
} if (yych == 'n') goto json_parser_50;
else goto json_parser_27;
{ } else {
if (yych <= '\\') if (yych <= 's') {
{ if (yych <= 'r') goto json_parser_50;
if (yych <= '[') goto json_parser_27;
{ } else {
goto json_parser_27; if (yych <= 't') goto json_parser_50;
} if (yych <= 'u') goto json_parser_55;
goto json_parser_50; goto json_parser_27;
} }
else }
{ }
if (yych == 'b')
{
goto json_parser_50;
}
goto json_parser_27;
}
}
}
else
{
if (yych <= 'q')
{
if (yych <= 'f')
{
goto json_parser_50;
}
if (yych == 'n')
{
goto json_parser_50;
}
goto json_parser_27;
}
else
{
if (yych <= 's')
{
if (yych <= 'r')
{
goto json_parser_50;
}
goto json_parser_27;
}
else
{
if (yych <= 't')
{
goto json_parser_50;
}
if (yych <= 'u')
{
goto json_parser_55;
}
goto json_parser_27;
}
}
}
json_parser_53: json_parser_53:
++buffer_re2c; ++buffer_re2c;
{ { return last_token = token_type::value_string; }
return last_token = token_type::value_string;
}
json_parser_55: json_parser_55:
++buffer_re2c; ++buffer_re2c;
yych = *buffer_re2c; yych = *buffer_re2c;
if (yych <= '@') if (yych <= '@') {
{ if (yych <= '/') goto json_parser_27;
if (yych <= '/') if (yych >= ':') goto json_parser_27;
{ } else {
goto json_parser_27; if (yych <= 'F') goto json_parser_56;
} if (yych <= '`') goto json_parser_27;
if (yych >= ':') if (yych >= 'g') goto json_parser_27;
{ }
goto json_parser_27;
}
}
else
{
if (yych <= 'F')
{
goto json_parser_56;
}
if (yych <= '`')
{
goto json_parser_27;
}
if (yych >= 'g')
{
goto json_parser_27;
}
}
json_parser_56: json_parser_56:
++buffer_re2c; ++buffer_re2c;
yych = *buffer_re2c; yych = *buffer_re2c;
if (yych <= '@') if (yych <= '@') {
{ if (yych <= '/') goto json_parser_27;
if (yych <= '/') if (yych >= ':') goto json_parser_27;
{ } else {
goto json_parser_27; if (yych <= 'F') goto json_parser_57;
} if (yych <= '`') goto json_parser_27;
if (yych >= ':') if (yych >= 'g') goto json_parser_27;
{ }
goto json_parser_27;
}
}
else
{
if (yych <= 'F')
{
goto json_parser_57;
}
if (yych <= '`')
{
goto json_parser_27;
}
if (yych >= 'g')
{
goto json_parser_27;
}
}
json_parser_57: json_parser_57:
++buffer_re2c; ++buffer_re2c;
yych = *buffer_re2c; yych = *buffer_re2c;
if (yych <= '@') if (yych <= '@') {
{ if (yych <= '/') goto json_parser_27;
if (yych <= '/') if (yych >= ':') goto json_parser_27;
{ } else {
goto json_parser_27; if (yych <= 'F') goto json_parser_58;
} if (yych <= '`') goto json_parser_27;
if (yych >= ':') if (yych >= 'g') goto json_parser_27;
{ }
goto json_parser_27;
}
}
else
{
if (yych <= 'F')
{
goto json_parser_58;
}
if (yych <= '`')
{
goto json_parser_27;
}
if (yych >= 'g')
{
goto json_parser_27;
}
}
json_parser_58: json_parser_58:
++buffer_re2c; ++buffer_re2c;
yych = *buffer_re2c; yych = *buffer_re2c;
if (yych <= '@') if (yych <= '@') {
{ if (yych <= '/') goto json_parser_27;
if (yych <= '/') if (yych <= '9') goto json_parser_50;
{ goto json_parser_27;
goto json_parser_27; } else {
} if (yych <= 'F') goto json_parser_50;
if (yych <= '9') if (yych <= '`') goto json_parser_27;
{ if (yych <= 'f') goto json_parser_50;
goto json_parser_50; goto json_parser_27;
} }
goto json_parser_27;
}
else
{
if (yych <= 'F')
{
goto json_parser_50;
}
if (yych <= '`')
{
goto json_parser_27;
}
if (yych <= 'f')
{
goto json_parser_50;
}
goto json_parser_27;
}
json_parser_59: json_parser_59:
++buffer_re2c; ++buffer_re2c;
yych = *buffer_re2c; yych = *buffer_re2c;
json_parser_60: json_parser_60:
if (yybm[0 + yych] & 128) if (yybm[0+yych] & 128) {
{ goto json_parser_59;
goto json_parser_59; }
} goto json_parser_2;
goto json_parser_2; }
}
} }
} }
...@@ -3370,7 +3031,7 @@ json_parser_60: ...@@ -3370,7 +3031,7 @@ json_parser_60:
@todo Take care of Unicode. @todo Take care of Unicode.
*/ */
std::string get_string() const inline std::string get_string() const
{ {
return std::string( return std::string(
reinterpret_cast<const char*>(current_re2c + 1), reinterpret_cast<const char*>(current_re2c + 1),
...@@ -3378,6 +3039,7 @@ json_parser_60: ...@@ -3378,6 +3039,7 @@ json_parser_60:
); );
} }
private:
/// the buffer /// the buffer
std::string buffer; std::string buffer;
/// a pointer to the next character to read from the buffer /// a pointer to the next character to read from the buffer
...@@ -3425,7 +3087,7 @@ template <> ...@@ -3425,7 +3087,7 @@ template <>
struct hash<nlohmann::json> struct hash<nlohmann::json>
{ {
/// return a hash value for a JSON object /// return a hash value for a JSON object
size_t operator()(const nlohmann::json& j) const inline size_t operator()(const nlohmann::json& j) const
{ {
// a naive hashing via the string representation // a naive hashing via the string representation
return hash<std::string>()(j.dump()); return hash<std::string>()(j.dump());
...@@ -3441,7 +3103,7 @@ no parse error occurred. ...@@ -3441,7 +3103,7 @@ no parse error occurred.
@param s a string representation of a JSON object @param s a string representation of a JSON object
@return a JSON object @return a JSON object
*/ */
nlohmann::json operator "" _json(const char* s, std::size_t) inline nlohmann::json operator "" _json(const char* s, std::size_t)
{ {
return nlohmann::json::parse(s); return nlohmann::json::parse(s);
} }
......
...@@ -909,31 +909,37 @@ class basic_json ...@@ -909,31 +909,37 @@ class basic_json
{ {
break; break;
} }
case (value_t::number_integer): case (value_t::number_integer):
{ {
m_value.number_integer = 0; m_value.number_integer = 0;
break; break;
} }
case (value_t::number_float): case (value_t::number_float):
{ {
m_value.number_float = 0.0; m_value.number_float = 0.0;
break; break;
} }
case (value_t::boolean): case (value_t::boolean):
{ {
m_value.boolean = false; m_value.boolean = false;
break; break;
} }
case (value_t::string): case (value_t::string):
{ {
m_value.string->clear(); m_value.string->clear();
break; break;
} }
case (value_t::array): case (value_t::array):
{ {
m_value.array->clear(); m_value.array->clear();
break; break;
} }
case (value_t::object): case (value_t::object):
{ {
m_value.object->clear(); m_value.object->clear();
...@@ -2730,7 +2736,7 @@ class basic_json ...@@ -2730,7 +2736,7 @@ class basic_json
@todo Take care of Unicode. @todo Take care of Unicode.
*/ */
std::string get_string() const inline std::string get_string() const
{ {
return std::string( return std::string(
reinterpret_cast<const char*>(current_re2c + 1), reinterpret_cast<const char*>(current_re2c + 1),
...@@ -2738,6 +2744,7 @@ class basic_json ...@@ -2738,6 +2744,7 @@ class basic_json
); );
} }
private:
/// the buffer /// the buffer
std::string buffer; std::string buffer;
/// a pointer to the next character to read from the buffer /// a pointer to the next character to read from the buffer
...@@ -2785,7 +2792,7 @@ template <> ...@@ -2785,7 +2792,7 @@ template <>
struct hash<nlohmann::json> struct hash<nlohmann::json>
{ {
/// return a hash value for a JSON object /// return a hash value for a JSON object
size_t operator()(const nlohmann::json& j) const inline size_t operator()(const nlohmann::json& j) const
{ {
// a naive hashing via the string representation // a naive hashing via the string representation
return hash<std::string>()(j.dump()); return hash<std::string>()(j.dump());
...@@ -2801,7 +2808,7 @@ no parse error occurred. ...@@ -2801,7 +2808,7 @@ no parse error occurred.
@param s a string representation of a JSON object @param s a string representation of a JSON object
@return a JSON object @return a JSON object
*/ */
nlohmann::json operator "" _json(const char* s, std::size_t) inline nlohmann::json operator "" _json(const char* s, std::size_t)
{ {
return nlohmann::json::parse(s); return nlohmann::json::parse(s);
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment