mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-26 02:18:04 +01:00 
			
		
		
		
	Only escape string values in Poco::JSON::Stringifier::stringify() #1027
This commit is contained in:
		| @@ -62,11 +62,15 @@ void Stringifier::stringify(const Var& any, std::ostream& out, unsigned int inde | |||||||
| 		if (any.type() == typeid(char)) formatString(value, out); | 		if (any.type() == typeid(char)) formatString(value, out); | ||||||
| 		else out << value; | 		else out << value; | ||||||
| 	} | 	} | ||||||
| 	else | 	else if (any.isString() || any.isDateTime() || any.isDate() || any.isTime()) | ||||||
| 	{ | 	{ | ||||||
| 		std::string value = any.convert<std::string>(); | 		std::string value = any.convert<std::string>(); | ||||||
| 		formatString(value, out); | 		formatString(value, out); | ||||||
| 	} | 	} | ||||||
|  | 	else | ||||||
|  | 	{ | ||||||
|  | 		out << any.convert<std::string>(); | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -23,6 +23,8 @@ | |||||||
| #include "Poco/TextConverter.h" | #include "Poco/TextConverter.h" | ||||||
| #include "Poco/Nullable.h" | #include "Poco/Nullable.h" | ||||||
| #include "Poco/Dynamic/Struct.h" | #include "Poco/Dynamic/Struct.h" | ||||||
|  | #include "Poco/DateTime.h" | ||||||
|  | #include "Poco/DateTimeFormatter.h" | ||||||
| #include <set> | #include <set> | ||||||
| #include <iostream> | #include <iostream> | ||||||
|  |  | ||||||
| @@ -30,7 +32,8 @@ | |||||||
| using namespace Poco::JSON; | using namespace Poco::JSON; | ||||||
| using namespace Poco::Dynamic; | using namespace Poco::Dynamic; | ||||||
| using Poco::DynamicStruct; | using Poco::DynamicStruct; | ||||||
|  | using Poco::DateTime; | ||||||
|  | using Poco::DateTimeFormatter; | ||||||
|  |  | ||||||
| JSONTest::JSONTest(const std::string& name): CppUnit::TestCase("JSON") | JSONTest::JSONTest(const std::string& name): CppUnit::TestCase("JSON") | ||||||
| { | { | ||||||
| @@ -897,6 +900,12 @@ void JSONTest::testStringElement() | |||||||
| 	Poco::Dynamic::Array da = *array; | 	Poco::Dynamic::Array da = *array; | ||||||
| 	assert (da.size() == 1); | 	assert (da.size() == 1); | ||||||
| 	assert (da[0] == "value"); | 	assert (da[0] == "value"); | ||||||
|  |  | ||||||
|  | 	std::stringstream s; | ||||||
|  | 	json = "[ \"\\u0017\" ]"; | ||||||
|  | 	Var v = Parser().parse(json); | ||||||
|  | 	Stringifier::condense(v, s); | ||||||
|  | 	assert(s.str() == "[\"\\u0017\"]"); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @@ -1245,6 +1254,27 @@ void JSONTest::testPrintHandler() | |||||||
|  |  | ||||||
| void JSONTest::testStringify() | void JSONTest::testStringify() | ||||||
| { | { | ||||||
|  | 	std::ostringstream os; | ||||||
|  | 	Var i = 123; | ||||||
|  | 	Stringifier::stringify(i, os); | ||||||
|  | 	assert(os.str() == "123"); | ||||||
|  |  | ||||||
|  | 	os.str(""); | ||||||
|  | 	Var f = 123.456; | ||||||
|  | 	Stringifier::stringify(f, os); | ||||||
|  | 	assert(os.str() == "123.456"); | ||||||
|  |  | ||||||
|  | 	os.str(""); | ||||||
|  | 	Var s = "abcdef"; | ||||||
|  | 	Stringifier::stringify(s, os); | ||||||
|  | 	assert(os.str() == "\"abcdef\""); | ||||||
|  |  | ||||||
|  | 	os.str(""); | ||||||
|  | 	DateTime dt; | ||||||
|  | 	Var d = dt; | ||||||
|  | 	Stringifier::stringify(d, os); | ||||||
|  | 	assert(os.str() == std::string("\"" + DateTimeFormatter::format(dt, Poco::DateTimeFormat::ISO8601_FORMAT) + "\"")); | ||||||
|  |  | ||||||
| 	std::string str1 = "\r"; | 	std::string str1 = "\r"; | ||||||
| 	std::string str2 = "\n"; | 	std::string str2 = "\n"; | ||||||
| 	Poco::JSON::Object obj1, obj2; | 	Poco::JSON::Object obj1, obj2; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Alex Fabijanic
					Alex Fabijanic