summaryrefslogtreecommitdiff
path: root/src/analysis/type.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/analysis/type.c')
-rw-r--r--src/analysis/type.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/src/analysis/type.c b/src/analysis/type.c
index 5c1878f..d0ab4f5 100644
--- a/src/analysis/type.c
+++ b/src/analysis/type.c
@@ -25,6 +25,7 @@
#include <malloc.h>
+#include <string.h>
#include "type-int.h"
@@ -130,6 +131,9 @@ static void g_data_type_dispose(GDataType *type)
static void g_data_type_finalize(GDataType *type)
{
+ if (type->ns_sep != NULL)
+ free(type->ns_sep);
+
G_OBJECT_CLASS(g_data_type_parent_class)->finalize(G_OBJECT(type));
}
@@ -152,6 +156,7 @@ GDataType *g_data_type_dup(const GDataType *type)
GDataType *result; /* Copie à retourner */
GDataTypeClass *class; /* Classe du type */
GDataType *ns; /* Eventuel espace de noms */
+ char *ns_sep; /* Séparation des espaces */
class = G_DATA_TYPE_GET_CLASS(type);
@@ -160,7 +165,10 @@ GDataType *g_data_type_dup(const GDataType *type)
if (type->namespace != NULL)
{
ns = g_data_type_dup(type->namespace);
- g_data_type_set_namespace(result, ns, type->ns_sep);
+ ns_sep = type->ns_sep != NULL ? strdup(type->ns_sep) : NULL;
+
+ g_data_type_set_namespace(result, ns, ns_sep);
+
}
result->qualifiers = type->qualifiers;
@@ -232,11 +240,14 @@ char *g_data_type_to_string(const GDataType *type, bool include)
* *
******************************************************************************/
-void g_data_type_set_namespace(GDataType *type, GDataType *namespace, const char *sep)
+void g_data_type_set_namespace(GDataType *type, GDataType *namespace, char *sep)
{
if (type->namespace != NULL)
g_object_unref(G_OBJECT(type->namespace));
+ if (type->ns_sep != NULL)
+ free(type->ns_sep);
+
type->namespace = namespace;
type->ns_sep = sep;