diff libpurple/xmlnode.c @ 23513:cab5420c3879

merge of '5033650a1e57437cc3f2894adc41935daa6b3269' and '95fe62719d362e8857a89e906a9008305e31dd5e'
author Elliott Sales de Andrade <qulogic@pidgin.im>
date Wed, 09 Jul 2008 00:32:18 +0000
parents c4ec724b3b53
children e23b447aa5ca 4152b5c1c051 2ecd716746e6
line wrap: on
line diff
--- a/libpurple/xmlnode.c	Wed Jul 09 00:27:44 2008 +0000
+++ b/libpurple/xmlnode.c	Wed Jul 09 00:32:18 2008 +0000
@@ -728,6 +728,13 @@
 	return ret;
 }
 
+static void
+xmlnode_copy_foreach_ns(gpointer key, gpointer value, gpointer user_data)
+{
+	GHashTable *ret = (GHashTable *)user_data;
+	g_hash_table_insert(ret, g_strdup(key), g_strdup(value));
+}
+
 xmlnode *
 xmlnode_copy(const xmlnode *src)
 {
@@ -739,17 +746,23 @@
 
 	ret = new_node(src->name, src->type);
 	ret->xmlns = g_strdup(src->xmlns);
-	if(src->data) {
-		if(src->data_sz) {
+	if (src->data) {
+		if (src->data_sz) {
 			ret->data = g_memdup(src->data, src->data_sz);
 			ret->data_sz = src->data_sz;
 		} else {
 			ret->data = g_strdup(src->data);
 		}
 	}
+	ret->prefix = g_strdup(src->prefix);
+	if (src->namespace_map) {
+		ret->namespace_map = g_hash_table_new_full(g_str_hash, g_str_equal,
+		                                           g_free, g_free);
+		g_hash_table_foreach(src->namespace_map, xmlnode_copy_foreach_ns, ret->namespace_map);
+	}
 
-	for(child = src->child; child; child = child->next) {
-		if(sibling) {
+	for (child = src->child; child; child = child->next) {
+		if (sibling) {
 			sibling->next = xmlnode_copy(child);
 			sibling = sibling->next;
 		} else {