mirror of
https://github.com/pocoproject/poco.git
synced 2025-10-23 16:48:06 +02:00
* Fix JSON unicode handling (see http://pocoproject.org/forum/viewtopic.php?f=10&t=5686)
This commit is contained in:
@@ -38,6 +38,7 @@
|
||||
#include "Poco/JSON/JSONException.h"
|
||||
#include "Poco/Ascii.h"
|
||||
#include "Poco/Token.h"
|
||||
#include "Poco/UnicodeConverter.h"
|
||||
#undef min
|
||||
#undef max
|
||||
#include <limits>
|
||||
@@ -140,28 +141,28 @@ public:
|
||||
switch(c)
|
||||
{
|
||||
case '"' :
|
||||
c = '"';
|
||||
_value += '"';
|
||||
break;
|
||||
case '\\' :
|
||||
c = '\\';
|
||||
_value += '\\';
|
||||
break;
|
||||
case '/' :
|
||||
c = '/';
|
||||
_value += '/';
|
||||
break;
|
||||
case 'b' :
|
||||
c = '\b';
|
||||
_value += '\b';
|
||||
break;
|
||||
case 'f' :
|
||||
c = '\f';
|
||||
_value += '\f';
|
||||
break;
|
||||
case 'n' :
|
||||
c = '\n';
|
||||
_value += '\n';
|
||||
break;
|
||||
case 'r' :
|
||||
c = '\r';
|
||||
_value += '\r';
|
||||
break;
|
||||
case 't' :
|
||||
c = '\t';
|
||||
_value += '\t';
|
||||
break;
|
||||
case 'u' : // Unicode
|
||||
{
|
||||
@@ -196,7 +197,11 @@ public:
|
||||
{
|
||||
throw JSONException("Invalid unicode");
|
||||
}
|
||||
c = unicode;
|
||||
//unicode to utf8
|
||||
std::string utf8;
|
||||
UnicodeConverter::toUTF8((const UTF32Char*)&unicode,1,utf8);
|
||||
_value += utf8;
|
||||
|
||||
break;
|
||||
}
|
||||
default:
|
||||
@@ -204,8 +209,9 @@ public:
|
||||
throw JSONException(format("Invalid escape '%c' character used", (char) c));
|
||||
}
|
||||
}
|
||||
}else{
|
||||
_value += c;
|
||||
}
|
||||
_value += c;
|
||||
c = istr.get();
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user