Avoid awkward do-while in Tokenizer.pullQuotedString

Not a big deal, but I think this reads more clearly now.
This commit is contained in:
Chris Martin 2014-11-05 14:35:42 -05:00
parent d6ffa8fc0f
commit b83089b91d

View File

@ -457,23 +457,22 @@ final class Tokenizer {
private Token pullQuotedString() throws ProblemException {
// the open quote has already been consumed
StringBuilder sb = new StringBuilder();
int c = '\0'; // value doesn't get used
do {
c = nextCharRaw();
while (true) {
int c = nextCharRaw();
if (c == -1)
throw problem("End of input but string quote was still open");
if (c == '\\') {
pullEscapeSequence(sb);
} else if (c == '"') {
// end the loop, done!
break;
} else if (Character.isISOControl(c)) {
throw problem(asString(c), "JSON does not allow unescaped " + asString(c)
+ " in quoted strings, use a backslash escape");
} else {
sb.appendCodePoint(c);
}
} while (c != '"');
}
// maybe switch to triple-quoted string, sort of hacky...
if (sb.length() == 0) {