mirror of
https://github.com/RGBCube/serenity
synced 2025-05-14 05:54:58 +00:00
JsonParser: Support basic escaped string characters.
I didn't implement \uXXXX-style escape in this patch. That's a FIXME.
This commit is contained in:
parent
6469d7f043
commit
e9b619c4aa
1 changed files with 37 additions and 2 deletions
|
@ -54,9 +54,44 @@ void JsonParser::consume_specific(char expected_ch)
|
|||
String JsonParser::consume_quoted_string()
|
||||
{
|
||||
consume_specific('"');
|
||||
auto string = extract_while([](char ch) { return ch != '"'; });
|
||||
StringBuilder builder;
|
||||
for (;;) {
|
||||
char ch = peek();
|
||||
if (ch == '"')
|
||||
break;
|
||||
if (ch != '\\') {
|
||||
builder.append(consume());
|
||||
continue;
|
||||
}
|
||||
consume();
|
||||
char escaped_ch = consume();
|
||||
switch (escaped_ch) {
|
||||
case 'n':
|
||||
builder.append('\n');
|
||||
break;
|
||||
case 'r':
|
||||
builder.append('\n');
|
||||
break;
|
||||
case 't':
|
||||
builder.append('\t');
|
||||
break;
|
||||
case 'b':
|
||||
builder.append('\b');
|
||||
break;
|
||||
case 'f':
|
||||
builder.append('\f');
|
||||
break;
|
||||
case 'u':
|
||||
// FIXME: Implement \uXXXX
|
||||
ASSERT_NOT_REACHED();
|
||||
break;
|
||||
default:
|
||||
builder.append(escaped_ch);
|
||||
break;
|
||||
}
|
||||
}
|
||||
consume_specific('"');
|
||||
return string;
|
||||
return builder.to_string();
|
||||
}
|
||||
|
||||
JsonValue JsonParser::parse_object()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue