diff options
author | Garrett Regier <garrettregier@gmail.com> | 2016-10-20 19:44:09 -0700 |
---|---|---|
committer | Garrett Regier <garrettregier@gmail.com> | 2017-06-16 17:16:32 -0700 |
commit | d78ad648942637fb9212d1d93670509d4c7f687b (patch) | |
tree | e1e2fe26f63d2d12446fee7aa291f1363e84ec6d /json-glib/json-path.c | |
parent | 7b3c405df41c0b6f6fe58fdb05c922614f08c4c4 (diff) | |
download | json-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.c | 14 |
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)); |