Blob Blame History Raw
From 4790093363f4bb625905bdb3a81a62c598d41405 Mon Sep 17 00:00:00 2001
From: Jakub Filak <jfilak@redhat.com>
Date: Fri, 19 Dec 2014 00:16:44 +0100
Subject: [LIBREPORT PATCH 123/124] lib: add a clone function for map_string_t

Related: #1140224, #1174833

Signed-off-by: Jakub Filak <jfilak@redhat.com>
---
 src/include/libreport_types.h |  2 ++
 src/lib/abrt_types.c          | 17 +++++++++++++++++
 2 files changed, 19 insertions(+)

diff --git a/src/include/libreport_types.h b/src/include/libreport_types.h
index 41ed5d7..2c60972 100644
--- a/src/include/libreport_types.h
+++ b/src/include/libreport_types.h
@@ -33,6 +33,8 @@ typedef GHashTable map_string_t;
 map_string_t *new_map_string(void);
 #define free_map_string libreport_free_map_string
 void free_map_string(map_string_t *ms);
+#define clone_map_string libreport_clone_map_string
+map_string_t *clone_map_string(map_string_t *ms);
 #define size_map_string libreport_size_map_string
 static inline
 unsigned size_map_string(map_string_t *ms)
diff --git a/src/lib/abrt_types.c b/src/lib/abrt_types.c
index 1ad4acc..fddaa46 100644
--- a/src/lib/abrt_types.c
+++ b/src/lib/abrt_types.c
@@ -29,6 +29,23 @@ void free_map_string(map_string_t *ms)
         g_hash_table_destroy(ms);
 }
 
+map_string_t *clone_map_string(map_string_t *ms)
+{
+    if (ms == NULL)
+        return NULL;
+
+    map_string_t *clone = new_map_string();
+
+    const char *key;
+    const char *value;
+    map_string_iter_t iter;
+    init_map_string_iter(&iter, ms);
+    while(next_map_string_iter(&iter, &key, &value))
+        insert_map_string(clone, xstrdup(key), xstrdup(value));
+
+    return clone;
+}
+
 const char *get_map_string_item_or_empty(map_string_t *ms, const char *key)
 {
     const char *v = (const char*)g_hash_table_lookup(ms, key);
-- 
1.8.3.1