diff options
Diffstat (limited to 'src/core/demanglers.c')
-rw-r--r-- | src/core/demanglers.c | 31 |
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); |