forked from bblanchon/ArduinoJson
Refactoring...
This commit is contained in:
@ -7,53 +7,42 @@
|
|||||||
|
|
||||||
size_t PrettyPrintDecorator::write(uint8_t c)
|
size_t PrettyPrintDecorator::write(uint8_t c)
|
||||||
{
|
{
|
||||||
size_t n;
|
size_t n = inString ? handleStringChar(c) : handleMarkupChar(c);
|
||||||
|
|
||||||
switch (c)
|
|
||||||
{
|
|
||||||
case '{':
|
|
||||||
case '[':
|
|
||||||
n = inString ? writeNormalChar(c) : writeOpening(c);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case '}':
|
|
||||||
case ']':
|
|
||||||
n = inString ? writeNormalChar(c) : writeClosing(c);
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ',':
|
|
||||||
n = inString ? writeNormalChar(c) : writeComma();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case ':':
|
|
||||||
n = inString ? writeNormalChar(c) : writeColumn();
|
|
||||||
break;
|
|
||||||
|
|
||||||
case '\"':
|
|
||||||
n = writeNormalChar(c);
|
|
||||||
|
|
||||||
if (previousChar != '\\')
|
|
||||||
inString = !inString;
|
|
||||||
|
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
n = writeNormalChar(c);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
previousChar = c;
|
previousChar = c;
|
||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t PrettyPrintDecorator::writeln()
|
size_t PrettyPrintDecorator::handleStringChar(uint8_t c)
|
||||||
{
|
{
|
||||||
size_t n = sink.write('\n');
|
bool isQuote = c == '"' && previousChar != '\\';
|
||||||
|
|
||||||
for (int i = 0; i < indent; i++)
|
return isQuote ? writeQuote() : writeNormalChar(c);
|
||||||
n += sink.write(' ');
|
}
|
||||||
|
|
||||||
return n;
|
size_t PrettyPrintDecorator::handleMarkupChar(uint8_t c)
|
||||||
|
{
|
||||||
|
switch (c)
|
||||||
|
{
|
||||||
|
case '{':
|
||||||
|
case '[':
|
||||||
|
return writeOpening(c);
|
||||||
|
|
||||||
|
case '}':
|
||||||
|
case ']':
|
||||||
|
return writeClosing(c);
|
||||||
|
|
||||||
|
case ',':
|
||||||
|
return writeComma();
|
||||||
|
|
||||||
|
case ':':
|
||||||
|
return writeColumn();
|
||||||
|
|
||||||
|
case '"':
|
||||||
|
return writeQuote();
|
||||||
|
|
||||||
|
default:
|
||||||
|
return writeNormalChar(c); // <- should not happen anyway
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
size_t PrettyPrintDecorator::writeNormalChar(uint8_t c)
|
size_t PrettyPrintDecorator::writeNormalChar(uint8_t c)
|
||||||
@ -84,6 +73,13 @@ size_t PrettyPrintDecorator::writeOpening(uint8_t c)
|
|||||||
return n;
|
return n;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
size_t PrettyPrintDecorator::writeQuote()
|
||||||
|
{
|
||||||
|
size_t n = writeNormalChar('"');
|
||||||
|
inString = !inString;
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
|
||||||
size_t PrettyPrintDecorator::writeClosing(uint8_t c)
|
size_t PrettyPrintDecorator::writeClosing(uint8_t c)
|
||||||
{
|
{
|
||||||
bool inEmptyBlock = previousChar == '{' || previousChar == '[';
|
bool inEmptyBlock = previousChar == '{' || previousChar == '[';
|
||||||
@ -92,3 +88,13 @@ size_t PrettyPrintDecorator::writeClosing(uint8_t c)
|
|||||||
|
|
||||||
return inEmptyBlock ? sink.write(c) : writeln() + sink.write(c);
|
return inEmptyBlock ? sink.write(c) : writeln() + sink.write(c);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
size_t PrettyPrintDecorator::writeln()
|
||||||
|
{
|
||||||
|
size_t n = sink.write('\n');
|
||||||
|
|
||||||
|
for (int i = 0; i < indent; i++)
|
||||||
|
n += sink.write(' ');
|
||||||
|
|
||||||
|
return n;
|
||||||
|
}
|
@ -29,10 +29,14 @@ private:
|
|||||||
|
|
||||||
size_t writeln();
|
size_t writeln();
|
||||||
|
|
||||||
size_t writeNormalChar(uint8_t c);
|
size_t handleStringChar(uint8_t);
|
||||||
|
size_t handleMarkupChar(uint8_t);
|
||||||
|
|
||||||
|
size_t writeClosing(uint8_t);
|
||||||
size_t writeColumn();
|
size_t writeColumn();
|
||||||
size_t writeComma();
|
size_t writeComma();
|
||||||
size_t writeOpening(uint8_t c);
|
size_t writeNormalChar(uint8_t);
|
||||||
size_t writeClosing(uint8_t c);
|
size_t writeOpening(uint8_t);
|
||||||
|
size_t writeQuote();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user