summaryrefslogtreecommitdiff
path: root/json-glib/json-array.c
diff options
context:
space:
mode:
authorEmmanuele Bassi <ebassi@linux.intel.com>2010-06-16 11:54:55 +0100
committerEmmanuele Bassi <ebassi@linux.intel.com>2010-09-25 20:19:31 +0100
commita2c7523ee67c0d6270bcf7eaaac528edff93e7ce (patch)
tree697fc0c27bcb6454e82a10bc1dc0a24a46e8792d /json-glib/json-array.c
parent3046a0222e73a3da2d87eb088302de45e2846aa0 (diff)
downloadjson-glib-a2c7523ee67c0d6270bcf7eaaac528edff93e7ce.tar.gz
Allow NULL as a value for strings, arrays and objectsjson-glib-0-10
We should not warn when asking for a string, array or object if the contents were 'null'. (cherry picked from commit 3f8c8f99126dc1a70d847eded13afd4b64395250) Signed-off-by: Emmanuele Bassi <ebassi@linux.intel.com>
Diffstat (limited to 'json-glib/json-array.c')
-rw-r--r--json-glib/json-array.c42
1 files changed, 33 insertions, 9 deletions
diff --git a/json-glib/json-array.c b/json-glib/json-array.c
index 5149aad..6e0dada 100644
--- a/json-glib/json-array.c
+++ b/json-glib/json-array.c
@@ -343,7 +343,10 @@ json_array_get_string_element (JsonArray *array,
node = g_ptr_array_index (array->elements, index_);
g_return_val_if_fail (node != NULL, NULL);
- g_return_val_if_fail (JSON_NODE_TYPE (node) == JSON_NODE_VALUE, NULL);
+ g_return_val_if_fail (JSON_NODE_HOLDS_VALUE (node) || JSON_NODE_HOLDS_NULL (node), NULL);
+
+ if (JSON_NODE_HOLDS_NULL (node))
+ return NULL;
return json_node_get_string (node);
}
@@ -401,7 +404,10 @@ json_array_get_array_element (JsonArray *array,
node = g_ptr_array_index (array->elements, index_);
g_return_val_if_fail (node != NULL, NULL);
- g_return_val_if_fail (JSON_NODE_TYPE (node) == JSON_NODE_ARRAY, NULL);
+ g_return_val_if_fail (JSON_NODE_HOLDS_ARRAY (node) || JSON_NODE_HOLDS_NULL (node), NULL);
+
+ if (JSON_NODE_HOLDS_NULL (node))
+ return NULL;
return json_node_get_array (node);
}
@@ -431,7 +437,10 @@ json_array_get_object_element (JsonArray *array,
node = g_ptr_array_index (array->elements, index_);
g_return_val_if_fail (node != NULL, NULL);
- g_return_val_if_fail (JSON_NODE_TYPE (node) == JSON_NODE_OBJECT, NULL);
+ g_return_val_if_fail (JSON_NODE_HOLDS_OBJECT (node) || JSON_NODE_HOLDS_NULL (node), NULL);
+
+ if (JSON_NODE_HOLDS_NULL (node))
+ return NULL;
return json_node_get_object (node);
}
@@ -565,8 +574,13 @@ json_array_add_string_element (JsonArray *array,
g_return_if_fail (array != NULL);
g_return_if_fail (value != NULL);
- node = json_node_new (JSON_NODE_VALUE);
- json_node_set_string (node, value);
+ if (value != NULL)
+ {
+ node = json_node_new (JSON_NODE_VALUE);
+ json_node_set_string (node, value);
+ }
+ else
+ node = json_node_new (JSON_NODE_NULL);
g_ptr_array_add (array->elements, node);
}
@@ -614,8 +628,13 @@ json_array_add_array_element (JsonArray *array,
g_return_if_fail (array != NULL);
g_return_if_fail (value != NULL);
- node = json_node_new (JSON_NODE_ARRAY);
- json_node_take_array (node, value);
+ if (value != NULL)
+ {
+ node = json_node_new (JSON_NODE_ARRAY);
+ json_node_take_array (node, value);
+ }
+ else
+ node = json_node_new (JSON_NODE_NULL);
g_ptr_array_add (array->elements, node);
}
@@ -641,8 +660,13 @@ json_array_add_object_element (JsonArray *array,
g_return_if_fail (array != NULL);
g_return_if_fail (value != NULL);
- node = json_node_new (JSON_NODE_OBJECT);
- json_node_take_object (node, value);
+ if (value != NULL)
+ {
+ node = json_node_new (JSON_NODE_OBJECT);
+ json_node_take_object (node, value);
+ }
+ else
+ node = json_node_new (JSON_NODE_NULL);
g_ptr_array_add (array->elements, node);
}