summaryrefslogtreecommitdiff
path: root/libs/libjson/src
diff options
context:
space:
mode:
authorGeorge Hazan <ghazan@miranda.im>2018-01-03 22:43:15 +0300
committerGeorge Hazan <ghazan@miranda.im>2018-01-03 22:43:15 +0300
commit654aba9d146fa931628790e2b16c5ca0f28907b3 (patch)
treec0d15a8c186e7ab1a5ec7135ada6e70f7480e17f /libs/libjson/src
parenta0ad33a285bac4d7f0ad3f29c9edc925e8c1429e (diff)
libjson:
- fix for printing null fields; - fix for passing NULL_PARAM & JSON_PARAM
Diffstat (limited to 'libs/libjson/src')
-rw-r--r--libs/libjson/src/JSONWriter.cpp3
-rw-r--r--libs/libjson/src/internalJSONNode.cpp3
-rw-r--r--libs/libjson/src/stdafx.cxx8
3 files changed, 11 insertions, 3 deletions
diff --git a/libs/libjson/src/JSONWriter.cpp b/libs/libjson/src/JSONWriter.cpp
index d5f7e5d380..ce753970c8 100644
--- a/libs/libjson/src/JSONWriter.cpp
+++ b/libs/libjson/src/JSONWriter.cpp
@@ -158,8 +158,9 @@ json_string internalJSONNode::Write(unsigned int indent, bool arrayChild){
case JSON_ARRAY: //write out the child nodes int he array
Fetch();
return WriteComment(indent) + WriteName(formatted, arrayChild) + JSON_TEXT("[") + WriteChildren(indent) + JSON_TEXT("]");
- case JSON_NUMBER: //write out a literal, without quotes
case JSON_NULL:
+ return WriteComment(indent) + WriteName(formatted, arrayChild) + CONST_NULL;
+ case JSON_NUMBER: //write out a literal, without quotes
case JSON_BOOL:
return WriteComment(indent) + WriteName(formatted, arrayChild) + _string;
}
diff --git a/libs/libjson/src/internalJSONNode.cpp b/libs/libjson/src/internalJSONNode.cpp
index 7cee25f27a..1b51582db2 100644
--- a/libs/libjson/src/internalJSONNode.cpp
+++ b/libs/libjson/src/internalJSONNode.cpp
@@ -36,6 +36,9 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
lots of copies, but since strings are copy on write, this assignment
is much faster
*/
+
+const json_string CONST_NULL(JSON_TEXT("null"));
+
static const json_string CONST_TRUE(JSON_TEXT("true"));
static const json_string CONST_FALSE(JSON_TEXT("false"));
diff --git a/libs/libjson/src/stdafx.cxx b/libs/libjson/src/stdafx.cxx
index 98f83a0b3a..32eb3c894f 100644
--- a/libs/libjson/src/stdafx.cxx
+++ b/libs/libjson/src/stdafx.cxx
@@ -54,12 +54,16 @@ LIBJSON_DLL(JSONNode&) operator<<(JSONNode &json, const WCHAR_PARAM &param)
LIBJSON_DLL(JSONNode&) operator<<(JSONNode &json, const NULL_PARAM &param)
{
- json.push_back(JSONNode(param.szName, nullptr));
+ JSONNode newOne(JSON_NULL);
+ newOne.set_name(param.szName);
+ json.push_back(newOne);
return json;
}
LIBJSON_DLL(JSONNode&) operator<<(JSONNode &json, const JSON_PARAM &param)
{
- json.push_back(JSONNode(param.szName, param.node));
+ JSONNode newOne(param.node);
+ newOne.set_name(param.szName);
+ json.push_back(newOne);
return json;
}