diff options
author | George Hazan <george.hazan@gmail.com> | 2015-05-26 11:22:59 +0000 |
---|---|---|
committer | George Hazan <george.hazan@gmail.com> | 2015-05-26 11:22:59 +0000 |
commit | 06ad3075a2f5743dcd8be2305dfa6a459f54c5e3 (patch) | |
tree | a265720ac87f6dbb73f7ef3cb2fdf0d5d20020a8 /src/mir_core | |
parent | 0abc2a0018c17277a27e64ef7d76566441d8071d (diff) |
JSONNode::as_mstring() -> a safe way to read strings in Unicode directly from json
git-svn-id: http://svn.miranda-ng.org/main/trunk@13845 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'src/mir_core')
-rw-r--r-- | src/mir_core/src/json/JSONNode.h | 36 | ||||
-rw-r--r-- | src/mir_core/src/json/internalJSONNode.h | 6 | ||||
-rw-r--r-- | src/mir_core/src/mir_core.def | 1 | ||||
-rw-r--r-- | src/mir_core/src/mir_core64.def | 1 |
4 files changed, 34 insertions, 10 deletions
diff --git a/src/mir_core/src/json/JSONNode.h b/src/mir_core/src/json/JSONNode.h index 0812a70b71..93ca2dd2cd 100644 --- a/src/mir_core/src/json/JSONNode.h +++ b/src/mir_core/src/json/JSONNode.h @@ -114,6 +114,7 @@ public: #endif
json_string as_string(void) const;
+ CMString as_mstring(void) const;
long as_int(void) const;
double as_float(void) const;
bool as_bool(void) const;
@@ -479,19 +480,23 @@ inline JSONNode::JSONNode(char mytype) : internal(internalJSONNode::newInternal( (mytype == JSON_NODE), JSON_TEXT("Not a proper JSON type"));
incAllocCount();
}
-inline JSONNode::JSONNode(const JSONNode & orig): internal(orig.internal -> incRef()) {
+inline JSONNode::JSONNode(const JSONNode & orig): internal(orig.internal -> incRef())
+{
incAllocCount();
}
//this allows a temp node to simply transfer its contents, even with ref counting off
-inline JSONNode::JSONNode(bool, JSONNode & orig): internal(orig.internal){
+inline JSONNode::JSONNode(bool, JSONNode & orig): internal(orig.internal)
+{
orig.internal = 0;
incAllocCount();
}
-inline JSONNode::~JSONNode(void){
+inline JSONNode::~JSONNode(void)
+{
if (internal) decRef();
decAllocCount();
}
-inline json_index_t JSONNode::size(void) const {
+inline json_index_t JSONNode::size(void) const
+{
JSON_CHECK_INTERNAL();
return internal -> size();
}
@@ -526,13 +531,15 @@ inline const json_char* JSONNode::name(void) const JSON_CHECK_INTERNAL();
return internal -> name();
}
-inline void JSONNode::set_name(const json_string & newname){
+inline void JSONNode::set_name(const json_string & newname)
+{
JSON_CHECK_INTERNAL();
makeUniqueInternal();
internal -> setname(newname);
}
#ifdef JSON_COMMENTS
- inline void JSONNode::set_comment(const json_string & newname){
+ inline void JSONNode::set_comment(const json_string & newname)
+ {
JSON_CHECK_INTERNAL();
makeUniqueInternal();
internal -> setcomment(newname);
@@ -542,11 +549,18 @@ inline void JSONNode::set_name(const json_string & newname){ return internal -> getcomment();
}
#endif
-inline json_string JSONNode::as_string(void) const {
+inline json_string JSONNode::as_string(void) const
+{
JSON_CHECK_INTERNAL();
return internal -> as_string();
}
-inline long JSONNode::as_int(void) const {
+inline CMString JSONNode::as_mstring(void) const
+{
+ JSON_CHECK_INTERNAL();
+ return internal->as_mstring();
+}
+inline long JSONNode::as_int(void) const
+{
JSON_CHECK_INTERNAL();
return internal -> as_int();
}
@@ -569,10 +583,12 @@ inline bool JSONNode::as_bool(void) const { return JSONBase64::json_decode64(as_string());
}
#endif
-inline JSONNode & JSONNode::operator[](const json_char *name_t) {
+inline JSONNode & JSONNode::operator[](const json_char *name_t)
+{
return at(name_t);
}
-inline const JSONNode & JSONNode::operator[](const json_char *name_t) const {
+inline const JSONNode & JSONNode::operator[](const json_char *name_t) const
+{
return at(name_t);
}
#ifdef JSON_LIBRARY
diff --git a/src/mir_core/src/json/internalJSONNode.h b/src/mir_core/src/json/internalJSONNode.h index cf626ceae0..6d857d3cd1 100644 --- a/src/mir_core/src/json/internalJSONNode.h +++ b/src/mir_core/src/json/internalJSONNode.h @@ -88,6 +88,7 @@ public: json_string getcomment(void) const;
#endif
json_string as_string(void) const;
+ CMString as_mstring(void) const;
long as_int(void) const;
json_number as_float(void) const;
bool as_bool(void) const;
@@ -288,6 +289,11 @@ inline json_string internalJSONNode::as_string(void) const { return _string;
}
+inline CMString internalJSONNode::as_mstring(void) const {
+ Fetch();
+ return CMString(ptrT(mir_utf8decodeT(_string.c_str())));
+}
+
inline long internalJSONNode::as_int(void) const {
Fetch();
switch(type()) {
diff --git a/src/mir_core/src/mir_core.def b/src/mir_core/src/mir_core.def index 58bbb59e16..ef180d7bdd 100644 --- a/src/mir_core/src/mir_core.def +++ b/src/mir_core/src/mir_core.def @@ -1241,3 +1241,4 @@ Proto_RegisterModule @1074 NONAME ?write_formatted@JSONNode@@QAE?AV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@XZ @1244 NONAME
?isnull@JSONNode@@QBE_NXZ @1245 NONAME
??BJSONNode@@QBE_NXZ @1246 NONAME
+?as_mstring@JSONNode@@QBE?AV?$CMStringT@_WV?$ChTraitsCRT@_W@@@@XZ @1247 NONAME
diff --git a/src/mir_core/src/mir_core64.def b/src/mir_core/src/mir_core64.def index 699e984893..c75553762f 100644 --- a/src/mir_core/src/mir_core64.def +++ b/src/mir_core/src/mir_core64.def @@ -1241,3 +1241,4 @@ Proto_RegisterModule @1074 NONAME ?write_formatted@JSONNode@@QEAA?AV?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@XZ @1244 NONAME
?isnull@JSONNode@@QEBA_NXZ @1245 NONAME
??BJSONNode@@QEBA_NXZ @1246 NONAME
+?as_mstring@JSONNode@@QEBA?AV?$CMStringT@_WV?$ChTraitsCRT@_W@@@@XZ @1247 NONAME
|