Extracted class EscapedString

This commit is contained in:
Benoît Blanchon
2014-07-07 13:38:35 +02:00
parent adb8fa4d44
commit 1b62502b36
5 changed files with 100 additions and 54 deletions

View File

@ -0,0 +1,65 @@
/*
* Arduino JSON library
* Benoit Blanchon 2014 - MIT License
*/
#include "EscapedString.h"
size_t EscapedString::printTo(Print& p) const
{
const char* s = rawString;
if (!s)
{
return p.print("null");
}
size_t n = 0;
n += p.write('\"');
while (*s)
{
switch (*s)
{
case '"':
n += p.print("\\\"");
break;
case '\\':
n += p.print("\\\\");
break;
case '\b':
n += p.print("\\b");
break;
case '\f':
n += p.print("\\f");
break;
case '\n':
n += p.print("\\n");
break;
case '\r':
n += p.print("\\r");
break;
case '\t':
n += p.print("\\t");
break;
default:
n += p.write(*s);
break;
}
s++;
}
n += p.write('\"');
return n;
}

View File

@ -0,0 +1,24 @@
/*
* Arduino JSON library
* Benoit Blanchon 2014 - MIT License
*/
#pragma once
#include "Print.h"
class EscapedString
{
public:
EscapedString(const char* s)
: rawString(s)
{
}
size_t printTo(Print&) const;
private:
const char* rawString;
};

View File

@ -3,6 +3,7 @@
* Benoit Blanchon 2014 - MIT License * Benoit Blanchon 2014 - MIT License
*/ */
#include "EscapedString.h"
#include "JsonValue.h" #include "JsonValue.h"
using namespace ArduinoJson::Generator; using namespace ArduinoJson::Generator;
@ -27,58 +28,6 @@ size_t JsonValue::printPrintableTo(const Content& c, Print& p)
size_t JsonValue::printStringTo(const Content& c, Print& p) size_t JsonValue::printStringTo(const Content& c, Print& p)
{ {
const char* s = c.asString; EscapedString s(c.asString);
return s.printTo(p);
if (!s)
{
return p.print("null");
}
size_t n = 0;
n += p.write('\"');
while (*s)
{
switch (*s)
{
case '"':
n += p.print("\\\"");
break;
case '\\':
n += p.print("\\\\");
break;
case '\b':
n += p.print("\\b");
break;
case '\f':
n += p.print("\\f");
break;
case '\n':
n += p.print("\\n");
break;
case '\r':
n += p.print("\\r");
break;
case '\t':
n += p.print("\\t");
break;
default:
n += p.write(*s);
break;
}
s++;
}
n += p.write('\"');
return n;
} }

View File

@ -84,6 +84,7 @@
</Link> </Link>
</ItemDefinitionGroup> </ItemDefinitionGroup>
<ItemGroup> <ItemGroup>
<ClCompile Include="..\JsonGenerator\EscapedString.cpp" />
<ClCompile Include="..\JsonGenerator\JsonValue.cpp" /> <ClCompile Include="..\JsonGenerator\JsonValue.cpp" />
<ClCompile Include="..\JsonGenerator\StringBuilder.cpp" /> <ClCompile Include="..\JsonGenerator\StringBuilder.cpp" />
<ClCompile Include="JsonArrayTests.cpp" /> <ClCompile Include="JsonArrayTests.cpp" />
@ -93,6 +94,7 @@
<ClCompile Include="StringBuilderTests.cpp" /> <ClCompile Include="StringBuilderTests.cpp" />
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ClInclude Include="..\JsonGenerator\EscapedString.h" />
<ClInclude Include="..\JsonGenerator\JsonArray.h" /> <ClInclude Include="..\JsonGenerator\JsonArray.h" />
<ClInclude Include="..\JsonGenerator\JsonHashTable.h" /> <ClInclude Include="..\JsonGenerator\JsonHashTable.h" />
<ClInclude Include="..\JsonGenerator\JsonObjectBase.h" /> <ClInclude Include="..\JsonGenerator\JsonObjectBase.h" />

View File

@ -36,6 +36,9 @@
<ClCompile Include="Print.cpp"> <ClCompile Include="Print.cpp">
<Filter>Source Files</Filter> <Filter>Source Files</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\JsonGenerator\EscapedString.cpp">
<Filter>Source Files</Filter>
</ClCompile>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ClInclude Include="..\JsonGenerator\JsonArray.h"> <ClInclude Include="..\JsonGenerator\JsonArray.h">
@ -59,5 +62,8 @@
<ClInclude Include="..\JsonGenerator\StringBuilder.h"> <ClInclude Include="..\JsonGenerator\StringBuilder.h">
<Filter>Header Files</Filter> <Filter>Header Files</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\JsonGenerator\EscapedString.h">
<Filter>Header Files</Filter>
</ClInclude>
</ItemGroup> </ItemGroup>
</Project> </Project>