summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCyrille Bagard <nocbos@gmail.com>2021-11-30 01:56:58 (GMT)
committerCyrille Bagard <nocbos@gmail.com>2021-11-30 01:56:58 (GMT)
commitde06b3ebc7021c20d94013bd39f4ba2c2e5ce3fa (patch)
tree463af79c1045e4180958d9ef9d0af33d3eebf7b9
parent7101133d0e862d2296d9709dc6ef1e64ebbc2ea0 (diff)
Access demanglers by key.
-rw-r--r--plugins/dexbnf/core.c2
-rw-r--r--plugins/dexbnf/demangler.c27
-rw-r--r--plugins/itanium/core.c2
-rw-r--r--plugins/itanium/demangler.c27
-rw-r--r--plugins/javadesc/core.c2
-rw-r--r--plugins/javadesc/demangler.c27
-rw-r--r--plugins/pychrysalide/mangling/demangler.c52
-rw-r--r--src/core/demanglers.c31
-rw-r--r--src/core/demanglers.h2
-rw-r--r--src/core/processors.c5
-rw-r--r--src/mangling/demangler-int.h4
-rw-r--r--src/mangling/demangler.c36
-rw-r--r--src/mangling/demangler.h3
13 files changed, 207 insertions, 13 deletions
diff --git a/plugins/dexbnf/core.c b/plugins/dexbnf/core.c
index 2b9408a..37e5a15 100644
--- a/plugins/dexbnf/core.c
+++ b/plugins/dexbnf/core.c
@@ -65,7 +65,7 @@ G_MODULE_EXPORT bool chrysalide_plugin_init(GPluginModule *plugin)
{
bool result; /* Bilan à retourner */
- result = register_demangler_type("dex", G_TYPE_DEX_DEMANGLER);
+ result = register_demangler_type(G_TYPE_DEX_DEMANGLER);
#ifdef HAVE_PYTHON3_BINDINGS
if (result)
diff --git a/plugins/dexbnf/demangler.c b/plugins/dexbnf/demangler.c
index 503f7ce..03f24f7 100644
--- a/plugins/dexbnf/demangler.c
+++ b/plugins/dexbnf/demangler.c
@@ -58,6 +58,9 @@ static void g_dex_demangler_dispose(GDexDemangler *);
/* Procède à la libération totale de la mémoire. */
static void g_dex_demangler_finalize(GDexDemangler *);
+/* Fournit la désignation interne du décodeur de désignations. */
+static char *g_dex_demangler_get_key(const GDexDemangler *);
+
/* Indique le type défini pour un décodeur de désignations. */
@@ -88,6 +91,7 @@ static void g_dex_demangler_class_init(GDexDemanglerClass *klass)
demangler = G_COMP_DEMANGLER_CLASS(klass);
+ demangler->get_key = (get_demangler_key_fc)g_dex_demangler_get_key;
demangler->can_demangle = (can_be_demangled_fc)NULL;
demangler->ns_sep = ".";
@@ -173,3 +177,26 @@ GCompDemangler *g_dex_demangler_new(void)
return G_COMP_DEMANGLER(result);
}
+
+
+/******************************************************************************
+* *
+* Paramètres : demangler = décodeur à consulter. *
+* *
+* Description : Fournit la désignation interne du décodeur de désignations. *
+* *
+* Retour : Simple chaîne de caractères. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+static char *g_dex_demangler_get_key(const GDexDemangler *demangler)
+{
+ char *result; /* Désignation à renvoyer */
+
+ result = strdup("dex");
+
+ return result;
+
+}
diff --git a/plugins/itanium/core.c b/plugins/itanium/core.c
index 6bf67c1..dd74f53 100644
--- a/plugins/itanium/core.c
+++ b/plugins/itanium/core.c
@@ -65,7 +65,7 @@ G_MODULE_EXPORT bool chrysalide_plugin_init(GPluginModule *plugin)
{
bool result; /* Bilan à retourner */
- result = register_demangler_type("itanium", G_TYPE_ITANIUM_DEMANGLER);
+ result = register_demangler_type(G_TYPE_ITANIUM_DEMANGLER);
#ifdef HAVE_PYTHON3_BINDINGS
if (result)
diff --git a/plugins/itanium/demangler.c b/plugins/itanium/demangler.c
index 5fe0d09..fc445f5 100644
--- a/plugins/itanium/demangler.c
+++ b/plugins/itanium/demangler.c
@@ -58,6 +58,9 @@ static void g_itanium_demangler_dispose(GItaniumDemangler *);
/* Procède à la libération totale de la mémoire. */
static void g_itanium_demangler_finalize(GItaniumDemangler *);
+/* Fournit la désignation interne du décodeur de désignations. */
+static char *g_itanium_demangler_get_key(const GItaniumDemangler *);
+
/* Indique le type défini pour un décodeur de désignations. */
@@ -88,6 +91,7 @@ static void g_itanium_demangler_class_init(GItaniumDemanglerClass *klass)
demangler = G_COMP_DEMANGLER_CLASS(klass);
+ demangler->get_key = (get_demangler_key_fc)g_itanium_demangler_get_key;
demangler->can_demangle = (can_be_demangled_fc)NULL;
demangler->ns_sep = "::";
@@ -173,3 +177,26 @@ GCompDemangler *g_itanium_demangler_new(void)
return G_COMP_DEMANGLER(result);
}
+
+
+/******************************************************************************
+* *
+* Paramètres : demangler = décodeur à consulter. *
+* *
+* Description : Fournit la désignation interne du décodeur de désignations. *
+* *
+* Retour : Simple chaîne de caractères. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+static char *g_itanium_demangler_get_key(const GItaniumDemangler *demangler)
+{
+ char *result; /* Désignation à renvoyer */
+
+ result = strdup("itanium");
+
+ return result;
+
+}
diff --git a/plugins/javadesc/core.c b/plugins/javadesc/core.c
index bda0f56..e7b4773 100644
--- a/plugins/javadesc/core.c
+++ b/plugins/javadesc/core.c
@@ -65,7 +65,7 @@ G_MODULE_EXPORT bool chrysalide_plugin_init(GPluginModule *plugin)
{
bool result; /* Bilan à retourner */
- result = register_demangler_type("java", G_TYPE_JAVA_DEMANGLER);
+ result = register_demangler_type(G_TYPE_JAVA_DEMANGLER);
#ifdef HAVE_PYTHON3_BINDINGS
if (result)
diff --git a/plugins/javadesc/demangler.c b/plugins/javadesc/demangler.c
index 78b62f1..eaacacf 100644
--- a/plugins/javadesc/demangler.c
+++ b/plugins/javadesc/demangler.c
@@ -58,6 +58,9 @@ static void g_java_demangler_dispose(GJavaDemangler *);
/* Procède à la libération totale de la mémoire. */
static void g_java_demangler_finalize(GJavaDemangler *);
+/* Fournit la désignation interne du décodeur de désignations. */
+static char *g_java_demangler_get_key(const GJavaDemangler *);
+
/* Indique le type défini pour un décodeur de désignations. */
@@ -88,6 +91,7 @@ static void g_java_demangler_class_init(GJavaDemanglerClass *klass)
demangler = G_COMP_DEMANGLER_CLASS(klass);
+ demangler->get_key = (get_demangler_key_fc)g_java_demangler_get_key;
demangler->can_demangle = (can_be_demangled_fc)NULL;
demangler->ns_sep = ".";
@@ -173,3 +177,26 @@ GCompDemangler *g_java_demangler_new(void)
return G_COMP_DEMANGLER(result);
}
+
+
+/******************************************************************************
+* *
+* Paramètres : demangler = décodeur à consulter. *
+* *
+* Description : Fournit la désignation interne du décodeur de désignations. *
+* *
+* Retour : Simple chaîne de caractères. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+static char *g_java_demangler_get_key(const GJavaDemangler *demangler)
+{
+ char *result; /* Désignation à renvoyer */
+
+ result = strdup("java");
+
+ return result;
+
+}
diff --git a/plugins/pychrysalide/mangling/demangler.c b/plugins/pychrysalide/mangling/demangler.c
index 87a19dc..5779693 100644
--- a/plugins/pychrysalide/mangling/demangler.c
+++ b/plugins/pychrysalide/mangling/demangler.c
@@ -25,6 +25,7 @@
#include "demangler.h"
+#include <malloc.h>
#include <pygobject.h>
@@ -41,6 +42,9 @@
+/* Fournit la désignation interne du décodeur de désignations. */
+static PyObject *py_compiler_demangler_get_key(PyObject *, void *);
+
/* Tente de décoder une chaîne de caractères donnée en type. */
static PyObject *py_compiler_demangler_decode_type(PyObject *, PyObject *);
@@ -51,6 +55,53 @@ static PyObject *py_compiler_demangler_decode_routine(PyObject *, PyObject *);
/******************************************************************************
* *
+* Paramètres : self = objet Python concerné par l'appel. *
+* closure = non utilisé ici. *
+* *
+* Description : Fournit la désignation interne du décodeur de désignations. *
+* *
+* Retour : Simple chaîne de caractères. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+static PyObject *py_compiler_demangler_get_key(PyObject *self, void *closure)
+{
+ PyObject *result; /* Instance Python à retourner */
+ GCompDemangler *demangler; /* Version GLib de l'opérande */
+ char *key; /* Désignation du décodeur */
+
+#define COMPILER_DEMANGLER_KEY_ATTRIB PYTHON_GET_DEF_FULL \
+( \
+ key, py_compiler_demangler, \
+ "Provide the small name used to identify the demangler," \
+ " as a code string." \
+)
+
+ demangler = G_COMP_DEMANGLER(pygobject_get(self));
+ assert(demangler != NULL);
+
+ key = g_compiler_demangler_get_key(demangler);
+
+ if (key != NULL)
+ {
+ result = PyUnicode_FromString(key);
+ free(key);
+ }
+ else
+ {
+ result = Py_None;
+ Py_INCREF(result);
+ }
+
+ return result;
+
+}
+
+
+/******************************************************************************
+* *
* Paramètres : self = décodeur à solliciter pour l'opération. *
* args = chaîne de caractères à décoder. *
* *
@@ -184,6 +235,7 @@ PyTypeObject *get_python_compiler_demangler_type(void)
};
static PyGetSetDef py_comp_demangler_getseters[] = {
+ COMPILER_DEMANGLER_KEY_ATTRIB,
{ NULL }
};
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);
diff --git a/src/core/demanglers.h b/src/core/demanglers.h
index 842f345..883692a 100644
--- a/src/core/demanglers.h
+++ b/src/core/demanglers.h
@@ -33,7 +33,7 @@
/* Enregistre un décodeur répondant à une appellation donnée. */
-bool register_demangler_type(const char *, GType);
+bool register_demangler_type(GType);
/* Décharge toutes les définitions de décodeurs. */
void unload_demanglers_definitions(void);
diff --git a/src/core/processors.c b/src/core/processors.c
index 666ddac..e4a558f 100644
--- a/src/core/processors.c
+++ b/src/core/processors.c
@@ -185,7 +185,10 @@ bool register_processor_type(GType type)
new = find_processor_by_key(key);
- if (new == NULL)
+ if (new != NULL)
+ free(key);
+
+ else
{
_processors_definitions = realloc(_processors_definitions,
++_processors_definitions_count * sizeof(proc_t));
diff --git a/src/mangling/demangler-int.h b/src/mangling/demangler-int.h
index 839a701..daf67fd 100644
--- a/src/mangling/demangler-int.h
+++ b/src/mangling/demangler-int.h
@@ -30,6 +30,9 @@
+/* Fournit la désignation interne du décodeur de désignations. */
+typedef char *(* get_demangler_key_fc) (const GCompDemangler *);
+
/* Indique si une chaîne peut être traitée par le décodeur. */
typedef bool (* can_be_demangled_fc) (const char *);
@@ -46,6 +49,7 @@ struct _GCompDemanglerClass
{
GObjectClass parent; /* A laisser en premier */
+ get_demangler_key_fc get_key; /* Code représentant la classe */
can_be_demangled_fc can_demangle; /* Possibilité de traitement */
const char *ns_sep; /* Motif de séparation */
diff --git a/src/mangling/demangler.c b/src/mangling/demangler.c
index 4137baf..619d76d 100644
--- a/src/mangling/demangler.c
+++ b/src/mangling/demangler.c
@@ -24,6 +24,9 @@
#include "demangler.h"
+#include <assert.h>
+
+
#include "demangler-int.h"
@@ -128,6 +131,39 @@ static void g_compiler_demangler_finalize(GCompDemangler *demangler)
/******************************************************************************
* *
+* Paramètres : demangler = décodeur à consulter. *
+* *
+* Description : Fournit la désignation interne du décodeur de désignations. *
+* *
+* Retour : Simple chaîne de caractères. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+char *g_compiler_demangler_get_key(const GCompDemangler *demangler)
+{
+ char *result; /* Désignation à renvoyer */
+ GCompDemanglerClass *class; /* Classe de l'instance */
+
+ class = G_COMP_DEMANGLER_GET_CLASS(demangler);
+
+ if (class->get_key == NULL)
+ {
+ assert(false);
+ result = NULL;
+ }
+
+ else
+ result = class->get_key(demangler);
+
+ return result;
+
+}
+
+
+/******************************************************************************
+* *
* Paramètres : demangler = décodeur à consulter pour le résultat. *
* *
* Description : Indique le motif de séparation des espaces de noms. *
diff --git a/src/mangling/demangler.h b/src/mangling/demangler.h
index 490c6c4..629dfde 100644
--- a/src/mangling/demangler.h
+++ b/src/mangling/demangler.h
@@ -47,6 +47,9 @@ typedef struct _GCompDemanglerClass GCompDemanglerClass;
/* Indique le type défini pour un décodeur de désignations. */
GType g_compiler_demangler_get_type(void);
+/* Fournit la désignation interne du décodeur de désignations. */
+char *g_compiler_demangler_get_key(const GCompDemangler *);
+
/* Indique le motif de séparation des espaces de noms. */
const char *g_compiler_demangler_get_ns_separator(const GCompDemangler *);