summaryrefslogtreecommitdiff
path: root/src/core/demanglers.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/demanglers.c')
-rw-r--r--src/core/demanglers.c31
1 files changed, 23 insertions, 8 deletions
diff --git a/src/core/demanglers.c b/src/core/demanglers.c
index 400fd44..0eb4e36 100644
--- a/src/core/demanglers.c
+++ b/src/core/demanglers.c
@@ -32,7 +32,7 @@
typedef struct _demangler_t
{
char *key; /* Clef pour un accès rapide */
- GType instance; /* Type à manipuler en interne */
+ GType type; /* Type à manipuler en interne */
} demangler_t;
@@ -52,8 +52,7 @@ static demangler_t *find_demangler_by_key(const char *);
/******************************************************************************
* *
-* Paramètres : key = désignation rapide et interne d'un décodeur. *
-* instance = type GLib représentant le type à instancier. *
+* Paramètres : type = type GLib représentant le type à instancier. *
* *
* Description : Enregistre un décodeur répondant à une appellation donnée. *
* *
@@ -63,18 +62,28 @@ static demangler_t *find_demangler_by_key(const char *);
* *
******************************************************************************/
-bool register_demangler_type(const char *key, GType instance)
+bool register_demangler_type(GType type)
{
bool result; /* Bilan à retourner */
+ GCompDemangler *demangler; /* Instance pour consultation */
+ char *key; /* Désignation associée */
demangler_t *new; /* Nouvel élément à définir */
+ result = false;
+
+ demangler = g_object_new(type, NULL);
+
+ key = g_compiler_demangler_get_key(demangler);
+ if (key == NULL) goto done;
+
G_LOCK(_ddef_access);
new = find_demangler_by_key(key);
- result = (new == NULL);
+ if (new != NULL)
+ free(key);
- if (result)
+ else
{
_demanglers_definitions = (demangler_t *)realloc(_demanglers_definitions,
++_demanglers_definitions_count * sizeof(demangler_t));
@@ -82,12 +91,18 @@ bool register_demangler_type(const char *key, GType instance)
new = &_demanglers_definitions[_demanglers_definitions_count - 1];
new->key = strdup(key);
- new->instance = instance;
+ new->type = type;
+
+ result = true;
}
G_UNLOCK(_ddef_access);
+ done:
+
+ g_object_unref(G_OBJECT(demangler));
+
return result;
}
@@ -182,7 +197,7 @@ GCompDemangler *get_compiler_demangler_for_key(const char *key)
if (def == NULL)
result = NULL;
else
- result = g_object_new(def->instance, NULL);
+ result = g_object_new(def->type, NULL);
G_UNLOCK(_ddef_access);