summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Jonathan Beck2009-02-14 17:32:19 +0100
committerGravatar Jonathan Beck2009-02-14 17:32:19 +0100
commitaa3a4c8d45be9da585d1aae141a546cfbbdf509f (patch)
tree5924d46f2392127fa75272daa99e85fc73c9e9bf
parent461c947d1238a1ca5604ec34bd4fe84e040334f7 (diff)
downloadlibplist-aa3a4c8d45be9da585d1aae141a546cfbbdf509f.tar.gz
libplist-aa3a4c8d45be9da585d1aae141a546cfbbdf509f.tar.bz2
Fix some memory leaks.
-rw-r--r--src/bplist.c1
-rw-r--r--src/plist.c16
-rw-r--r--src/plist.h2
-rw-r--r--src/xplist.c52
4 files changed, 42 insertions, 29 deletions
diff --git a/src/bplist.c b/src/bplist.c
index 003bff1..d848e6a 100644
--- a/src/bplist.c
+++ b/src/bplist.c
@@ -487,6 +487,7 @@ void plist_from_bin(const char *plist_bin, uint32_t length, plist_t * plist)
}
*plist = nodeslist[root_object];
+ free(nodeslist);
}
static guint plist_data_hash(gconstpointer key)
diff --git a/src/plist.c b/src/plist.c
index 87a1de5..c69f4c1 100644
--- a/src/plist.c
+++ b/src/plist.c
@@ -44,16 +44,27 @@ plist_data_t plist_new_plist_data()
return data;
}
-void plist_free_plist_data(plist_data_t data)
+static void plist_free_node(GNode * node, gpointer none)
{
+ plist_data_t data = plist_get_data(node);
if (data) {
switch (data->type) {
-
+ case PLIST_KEY:
+ case PLIST_STRING:
+ free(data->strval);
+ break;
+ case PLIST_UNICODE:
+ free(data->unicodeval);
+ break;
+ case PLIST_DATA:
+ free(data->buff);
+ break;
default:
break;
}
free(data);
}
+ node->data = NULL;
}
plist_t plist_new_dict()
@@ -133,6 +144,7 @@ static plist_t plist_add_sub_element(plist_t node, plist_type type, const void *
void plist_free(plist_t plist)
{
+ g_node_children_foreach(plist, G_TRAVERSE_ALL, plist_free_node, NULL);
g_node_destroy(plist);
}
diff --git a/src/plist.h b/src/plist.h
index 48b66f1..4bb97e3 100644
--- a/src/plist.h
+++ b/src/plist.h
@@ -49,7 +49,7 @@ typedef struct plist_data_s *plist_data_t;
plist_t plist_new_node(plist_data_t data);
plist_data_t plist_get_data(const plist_t node);
plist_data_t plist_new_plist_data();
-void plist_free_plist_data(plist_data_t node);
+
#endif
diff --git a/src/xplist.c b/src/xplist.c
index e985243..525706c 100644
--- a/src/xplist.c
+++ b/src/xplist.c
@@ -112,18 +112,6 @@ static xmlDocPtr new_xml_plist()
return plist_xml;
}
-/** Destroys a previously created XML document.
- *
- * @param plist The XML document to destroy.
- */
-static void free_plist(xmlDocPtr plist)
-{
- if (!plist)
- return;
-
- xmlFreeDoc(plist);
-}
-
static void node_to_xml(GNode * node, gpointer xml_struct)
{
struct xml_node *xstruct = NULL;
@@ -284,61 +272,72 @@ static void xml_to_node(xmlNodePtr xml_node, plist_t * plist_node)
}
if (!xmlStrcmp(node->name, XPLIST_INT)) {
- char *strval = (char *) xmlNodeGetContent(node);
- data->intval = g_ascii_strtoull(strval, NULL, 0);
+ xmlChar *strval = xmlNodeGetContent(node);
+ data->intval = g_ascii_strtoull((char *)strval, NULL, 0);
data->type = PLIST_UINT;
data->length = 8;
+ xmlFree(strval);
continue;
}
if (!xmlStrcmp(node->name, XPLIST_REAL)) {
- char *strval = (char *) xmlNodeGetContent(node);
- data->realval = atof(strval);
+ xmlChar *strval = xmlNodeGetContent(node);
+ data->realval = atof((char *)strval);
data->type = PLIST_REAL;
data->length = 8;
+ xmlFree(strval);
continue;
}
if (!xmlStrcmp(node->name, XPLIST_DATE)) {
- g_time_val_from_iso8601((char *) xmlNodeGetContent(node), &data->timeval);
+ xmlChar *strval = xmlNodeGetContent(node);
+ g_time_val_from_iso8601((char *) strval, &data->timeval);
data->type = PLIST_DATE;
data->length = sizeof(GTimeVal);
+ xmlFree(strval);
continue;
}
if (!xmlStrcmp(node->name, XPLIST_STRING)) {
-
- tmp = xmlNodeGetContent(node);
- len = strlen((char *) tmp);
+ xmlChar *strval = xmlNodeGetContent(node);
+ len = strlen((char *) strval);
items_read = 0;
items_written = 0;
error = NULL;
- type = xmlDetectCharEncoding(tmp, len);
+ type = xmlDetectCharEncoding(strval, len);
if (XML_CHAR_ENCODING_UTF8 == type) {
- data->unicodeval = g_utf8_to_utf16((char *) tmp, len, &items_read, &items_written, &error);
+ data->unicodeval = g_utf8_to_utf16((char *) strval, len, &items_read, &items_written, &error);
data->type = PLIST_UNICODE;
data->length = items_written;
} else if (XML_CHAR_ENCODING_ASCII == type || XML_CHAR_ENCODING_NONE == type) {
- data->strval = strdup((char *) xmlNodeGetContent(node));
+ data->strval = strdup((char *) strval);
data->type = PLIST_STRING;
data->length = strlen(data->strval);
}
+ xmlFree(strval);
continue;
}
if (!xmlStrcmp(node->name, XPLIST_KEY)) {
- data->strval = strdup((char *) xmlNodeGetContent(node));
+ xmlChar *strval = xmlNodeGetContent(node);
+ data->strval = strdup((char *) strval);
data->type = PLIST_KEY;
data->length = strlen(data->strval);
+ xmlFree(strval);
continue;
}
if (!xmlStrcmp(node->name, XPLIST_DATA)) {
+ xmlChar *strval = xmlNodeGetContent(node);
gsize size = 0;
- data->buff = g_base64_decode((char *) xmlNodeGetContent(node), &size);
+ guchar *dec = g_base64_decode((char *) strval, &size);
+ data->buff = (uint8_t*) malloc( size * sizeof(uint8_t));
+ memcpy(data->buff, dec, size * sizeof(uint8_t));
+ g_free(dec);
data->length = size;
data->type = PLIST_DATA;
+ xmlFree(strval);
continue;
}
@@ -374,7 +373,7 @@ void plist_to_xml(plist_t plist, char **plist_xml, uint32_t * length)
xmlDocDumpMemory(plist_doc, (xmlChar **) plist_xml, &size);
if (size >= 0)
*length = size;
- free_plist(plist_doc);
+ xmlFreeDoc(plist_doc);
}
void plist_from_xml(const char *plist_xml, uint32_t length, plist_t * plist)
@@ -383,4 +382,5 @@ void plist_from_xml(const char *plist_xml, uint32_t length, plist_t * plist)
xmlNodePtr root_node = xmlDocGetRootElement(plist_doc);
xml_to_node(root_node, plist);
+ xmlFreeDoc(plist_doc);
}