minor style adjustments

This commit is contained in:
Niels 2015-01-09 20:48:16 +01:00
parent 3fa2e900ef
commit 0cd2ecf48f
2 changed files with 121 additions and 35 deletions

View file

@ -2482,35 +2482,91 @@ Parses a string after opening quotes (\p ") where read.
@post The character after the closing quote \p " is the current character @ref @post The character after the closing quote \p " is the current character @ref
current_. Whitespace is skipped. current_. Whitespace is skipped.
@todo Unicode escapes such as \uxxxx are missing - see
https://github.com/nlohmann/json/issues/12
*/ */
std::string json::parser::parseString() std::string json::parser::parseString()
{ {
// remember the position where the first character of the string was
const auto startPos = pos_;
// true if and only if the amount of backslashes before the current // true if and only if the amount of backslashes before the current
// character is even // character is even
bool evenAmountOfBackslashes = true; bool evenAmountOfBackslashes = true;
// the result of the parse process
std::string result;
// iterate with pos_ over the whole string // iterate with pos_ over the whole string
for (; pos_ < buffer_.size(); pos_++) for (; pos_ < buffer_.size(); pos_++)
{ {
char currentChar = buffer_[pos_]; char currentChar = buffer_[pos_];
// currentChar is a quote, so we might have found the end of the string // uneven amount of backslashes means the user wants to escape something
if (!evenAmountOfBackslashes)
{
// slash, backslash and quote are copied as is
if (currentChar == '/' or currentChar == '\\' or currentChar == '"')
{
result += currentChar;
}
else
{
// all other characters are replaced by their respective
// special character
switch (currentChar)
{
case 't':
{
result += '\t';
break;
}
case 'b':
{
result += '\b';
break;
}
case 'f':
{
result += '\f';
break;
}
case 'n':
{
result += '\n';
break;
}
case 'r':
{
result += '\r';
break;
}
default:
{
error("expected one of \\, /, b, f, n, r, t behind backslash.");
}
}
// TODO implement \uXXXX
}
}
else
{
if (currentChar == '"') if (currentChar == '"')
{ {
// but only if the amount of backslashes before that quote is even // currentChar is a quote, so we found the end of the string
if (evenAmountOfBackslashes)
{
const auto stringLength = pos_ - startPos;
// set pos_ behind the trailing quote // set pos_ behind the trailing quote
pos_++; pos_++;
// find next char to parse // find next char to parse
next(); next();
// return string inside the quotes // bring the result of the parsing process back to the caller
return buffer_.substr(startPos, stringLength); return result;
}
else if (currentChar != '\\')
{
// All non-backslash characters are added to the end of the
// result string. The only backslashes we want in the result
// are the ones that are escaped (which happens above).
result += currentChar;
} }
} }

View file

@ -2039,6 +2039,9 @@ Parses a string after opening quotes (\p ") where read.
@post The character after the closing quote \p " is the current character @ref @post The character after the closing quote \p " is the current character @ref
current_. Whitespace is skipped. current_. Whitespace is skipped.
@todo Unicode escapes such as \uxxxx are missing - see
https://github.com/nlohmann/json/issues/12
*/ */
std::string json::parser::parseString() std::string json::parser::parseString()
{ {
@ -2050,39 +2053,63 @@ std::string json::parser::parseString()
std::string result; std::string result;
// iterate with pos_ over the whole string // iterate with pos_ over the whole string
for (; pos_ < buffer_.size(); pos_++) { for (; pos_ < buffer_.size(); pos_++)
{
char currentChar = buffer_[pos_]; char currentChar = buffer_[pos_];
// uneven amount of backslashes means the user wants to escape something // uneven amount of backslashes means the user wants to escape something
if (!evenAmountOfBackslashes) { if (!evenAmountOfBackslashes)
{
// slash, backslash and quote are copied as is // slash, backslash and quote are copied as is
if ( currentChar == '/' if (currentChar == '/' or currentChar == '\\' or currentChar == '"')
|| currentChar == '\\' {
|| currentChar == '"') {
result += currentChar; result += currentChar;
} else { }
// All other characters are replaced by their respective special character else
if (currentChar == 't') { {
// all other characters are replaced by their respective
// special character
switch (currentChar)
{
case 't':
{
result += '\t'; result += '\t';
} else if (currentChar == 'b') { break;
}
case 'b':
{
result += '\b'; result += '\b';
} else if (currentChar == 'f') { break;
}
case 'f':
{
result += '\f'; result += '\f';
} else if (currentChar == 'n') { break;
}
case 'n':
{
result += '\n'; result += '\n';
} else if (currentChar == 'r') { break;
}
case 'r':
{
result += '\r'; result += '\r';
} else { break;
}
default:
{
error("expected one of \\, /, b, f, n, r, t behind backslash."); error("expected one of \\, /, b, f, n, r, t behind backslash.");
} }
}
// TODO implement \uXXXX // TODO implement \uXXXX
} }
} else { }
if (currentChar == '"') { else
{
if (currentChar == '"')
{
// currentChar is a quote, so we found the end of the string // currentChar is a quote, so we found the end of the string
// set pos_ behind the trailing quote // set pos_ behind the trailing quote
pos_++; pos_++;
// find next char to parse // find next char to parse
@ -2090,9 +2117,12 @@ std::string json::parser::parseString()
// bring the result of the parsing process back to the caller // bring the result of the parsing process back to the caller
return result; return result;
} else if (currentChar != '\\') { }
// all non-backslash characters are added to the end of the result string. else if (currentChar != '\\')
// the only backslashes we want in the result are the ones that are escaped (which happens above). {
// All non-backslash characters are added to the end of the
// result string. The only backslashes we want in the result
// are the ones that are escaped (which happens above).
result += currentChar; result += currentChar;
} }
} }