summaryrefslogtreecommitdiff
path: root/json-glib/json-path.c
diff options
context:
space:
mode:
authorGarrett Regier <garrettregier@gmail.com>2016-10-20 19:44:09 -0700
committerGarrett Regier <garrettregier@gmail.com>2017-06-16 17:16:32 -0700
commitd78ad648942637fb9212d1d93670509d4c7f687b (patch)
treee1e2fe26f63d2d12446fee7aa291f1363e84ec6d /json-glib/json-path.c
parent7b3c405df41c0b6f6fe58fdb05c922614f08c4c4 (diff)
downloadjson-glib-d78ad648942637fb9212d1d93670509d4c7f687b.tar.gz
core: Avoid json_object_get_members()
Use JsonObject's private members_ordered GQueue instead. This avoids a g_list_copy(). https://bugzilla.gnome.org/show_bug.cgi?id=773504
Diffstat (limited to 'json-glib/json-path.c')
-rw-r--r--json-glib/json-path.c14
1 files changed, 6 insertions, 8 deletions
diff --git a/json-glib/json-path.c b/json-glib/json-path.c
index dd04d58..fe6e7b1 100644
--- a/json-glib/json-path.c
+++ b/json-glib/json-path.c
@@ -755,10 +755,10 @@ walk_path_node (GList *path,
case JSON_NODE_OBJECT:
{
JsonObject *object = json_node_get_object (root);
- GList *members, *l;
+ GQueue *members = json_object_get_members_internal (object);
+ GList *l;
- members = json_object_get_members (object);
- for (l = members; l != NULL; l = l->next)
+ for (l = members->head; l != NULL; l = l->next)
{
JsonNode *m = json_object_get_member (object, l->data);
@@ -774,7 +774,6 @@ walk_path_node (GList *path,
walk_path_node (path, m, results);
}
}
- g_list_free (members);
}
break;
@@ -815,10 +814,10 @@ walk_path_node (GList *path,
if (JSON_NODE_HOLDS_OBJECT (root))
{
JsonObject *object = json_node_get_object (root);
- GList *members, *l;
+ GQueue *members = json_object_get_members_internal (object);
+ GList *l;
- members = json_object_get_members (object);
- for (l = members; l != NULL; l = l->next)
+ for (l = members->head; l != NULL; l = l->next)
{
JsonNode *member = json_object_get_member (object, l->data);
@@ -830,7 +829,6 @@ walk_path_node (GList *path,
json_array_add_element (results, json_node_copy (member));
}
}
- g_list_free (members);
}
else
json_array_add_element (results, json_node_copy (root));