diff options
| author | 2018-12-10 02:20:24 +0100 | |
|---|---|---|
| committer | 2018-12-10 02:22:15 +0100 | |
| commit | 4de329327ce4aa175e8496d1bff8604bffb6c574 (patch) | |
| tree | 0c5fce7e138756a2479acab5a3098fa12ea6971b /src/plist.c | |
| parent | 71dd25e14616bd261c3b6c80ff990cd1078266f6 (diff) | |
| download | libplist-4de329327ce4aa175e8496d1bff8604bffb6c574.tar.gz libplist-4de329327ce4aa175e8496d1bff8604bffb6c574.tar.bz2 | |
Remove node_iterator and operate on node list directly to improve memory usage
Diffstat (limited to 'src/plist.c')
| -rw-r--r-- | src/plist.c | 11 | 
1 files changed, 4 insertions, 7 deletions
| diff --git a/src/plist.c b/src/plist.c index f62e6be..cd22ca6 100644 --- a/src/plist.c +++ b/src/plist.c @@ -36,7 +36,6 @@  #endif  #include <node.h> -#include <node_iterator.h>  #include <hashtable.h>  extern void plist_xml_init(void); @@ -209,12 +208,12 @@ static int plist_free_node(node_t* node)      plist_free_data(data);      node->data = NULL; -    node_iterator_t *ni = node_iterator_create(node->children);      node_t *ch; -    while ((ch = node_iterator_next(ni))) { +    for (ch = node_first_child(node); ch; ) { +        node_t *next = node_next_sibling(ch);          plist_free_node(ch); +        ch = next;      } -    node_iterator_destroy(ni);      node_destroy(node); @@ -366,12 +365,10 @@ static void plist_copy_node(node_t *node, void *parent_node_ptr)          *(plist_t*)parent_node_ptr = newnode;      } -    node_iterator_t *ni = node_iterator_create(node->children);      node_t *ch; -    while ((ch = node_iterator_next(ni))) { +    for (ch = node_first_child(node); ch; ch = node_next_sibling(ch)) {          plist_copy_node(ch, &newnode);      } -    node_iterator_destroy(ni);  }  PLIST_API plist_t plist_copy(plist_t node) | 
