diff options
| author | Cyrille Bagard <nocbos@gmail.com> | 2018-07-07 10:49:20 (GMT) | 
|---|---|---|
| committer | Cyrille Bagard <nocbos@gmail.com> | 2018-07-07 10:49:20 (GMT) | 
| commit | a857e1e9db9d298b7aa91e8f618e6c0ea4db84ac (patch) | |
| tree | e0dc140ee5bf5badbcee673e79c4b43f88a53322 /plugins/pychrysalide/analysis | |
| parent | 21d310503e29c61411491eef6be2fb83bb5ed61c (diff) | |
Extended the types API.
Diffstat (limited to 'plugins/pychrysalide/analysis')
| -rw-r--r-- | plugins/pychrysalide/analysis/module.c | 2 | ||||
| -rw-r--r-- | plugins/pychrysalide/analysis/routine.c | 347 | ||||
| -rw-r--r-- | plugins/pychrysalide/analysis/type.c | 304 | ||||
| -rw-r--r-- | plugins/pychrysalide/analysis/variable.c | 2 | 
4 files changed, 654 insertions, 1 deletions
| diff --git a/plugins/pychrysalide/analysis/module.c b/plugins/pychrysalide/analysis/module.c index 614adf0..60f08ce 100644 --- a/plugins/pychrysalide/analysis/module.c +++ b/plugins/pychrysalide/analysis/module.c @@ -39,6 +39,7 @@  #include "variable.h"  #include "contents/module.h"  #include "db/module.h" +#include "types/module.h"  #include "../access.h" @@ -103,6 +104,7 @@ bool add_analysis_module_to_python_module(PyObject *super)      result &= add_analysis_contents_module_to_python_module(module);      result &= add_analysis_db_module_to_python_module(module); +    result &= add_analysis_types_module_to_python_module(module);      if (result)          register_access_to_python_module("pychrysalide.analysis", module); diff --git a/plugins/pychrysalide/analysis/routine.c b/plugins/pychrysalide/analysis/routine.c index a95131d..fddc026 100644 --- a/plugins/pychrysalide/analysis/routine.c +++ b/plugins/pychrysalide/analysis/routine.c @@ -37,6 +37,7 @@  #include "block.h" +#include "type.h"  #include "../helpers.h"  #include "../format/symbol.h" @@ -48,15 +49,39 @@ static PyObject *py_binary_routine_to_str(PyObject *);  /* Crée un nouvel objet Python de type 'BinRoutine'. */  static PyObject *py_binary_routine_new(PyTypeObject *, PyObject *, PyObject *); +/* Fournit le groupe d'appartenance d'une routine donnée. */ +static PyObject *py_binary_routine_get_namespace(PyObject *, void *); + +/* Définit le groupe d'appartenance d'une routine donnée. */ +static int py_binary_routine_set_namespace(PyObject *, PyObject *, void *); +  /* Fournit le nom humain d'une routine. */  static PyObject *py_binary_routine_get_name(PyObject *, void *);  /* Définit le nom humain d'une routine. */  static int py_binary_routine_set_name(PyObject *, PyObject *, void *); +/* Fournit le type construisant le nom humain d'une routine. */ +static PyObject *py_binary_routine_get_typed_name(PyObject *, void *); + +/* Définit de façon indirecte le nom humain d'une routine. */ +static int py_binary_routine_set_typed_name(PyObject *, PyObject *, void *); + +/* Fournit le type de retour d'une routine. */ +static PyObject *py_binary_routine_get_return_type(PyObject *, void *); + +/* Définit le type de retour d'une routine. */ +static int py_binary_routine_set_return_type(PyObject *, PyObject *, void *); + +/* Fournit la liste des arguments associés à la routine. */ +static PyObject *py_binary_routine_get_args(PyObject *, void *); +  /* Fournit les blocs basiques de la routine. */  static PyObject *py_binary_routine_get_basic_blocks(PyObject *, void *); +/* Définit les blocs basiques de la routine. */ +static int py_binary_routine_set_basic_blocks(PyObject *, PyObject *, void *); +  /****************************************************************************** @@ -120,6 +145,104 @@ static PyObject *py_binary_routine_new(PyTypeObject *type, PyObject *args, PyObj  *  Paramètres  : self    = objet Python concerné par l'appel.                 *  *                closure = non utilisé ici.                                   *  *                                                                             * +*  Description : Fournit le groupe d'appartenance d'une routine donnée.       * +*                                                                             * +*  Retour      : Eventuelle instance d'appartenance ou None.                  * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static PyObject *py_binary_routine_get_namespace(PyObject *self, void *closure) +{ +    PyObject *result;                       /* Valeur à retourner          */ +    GBinRoutine *routine;                   /* Elément à consulter         */ +    GDataType *ns;                          /* Espace de noms              */ + +    routine = G_BIN_ROUTINE(pygobject_get(self)); +    ns = g_binary_routine_get_namespace(routine); + +    if (ns != NULL) +    { +        result = pygobject_new(G_OBJECT(ns)); +        g_object_unref(G_OBJECT(ns)); +    } + +    else +    { +        result = Py_None; +        Py_INCREF(result); +    } + +    return result; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                value   = valeur fournie à intégrer ou prendre en compte.    * +*                closure = non utilisé ici.                                   * +*                                                                             * +*  Description : Définit le groupe d'appartenance d'une routine donnée.       * +*                                                                             * +*  Retour      : Bilan de l'opération pour Python.                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static int py_binary_routine_set_namespace(PyObject *self, PyObject *value, void *closure) +{ +    GBinRoutine *routine;                   /* Elément à traiter           */ +    GDataType *ns;                          /* Espace de noms              */ +    char *sep;                              /* Séparateur des espaces      */ + +    if ((!PyTuple_Check(value) || (PyTuple_Check(value) && PyTuple_Size(value) != 2)) && value != Py_None) +    { +        PyErr_SetString(PyExc_TypeError, +                        _("The attribute value must be a tuple with GDataType and a separator or None.")); +        return -1; +    } + +    routine = G_BIN_ROUTINE(pygobject_get(self)); + +    if (value == Py_None) +        g_binary_routine_set_namespace(routine, NULL, NULL); + +    else +    { +        if (!PyObject_IsInstance(PyTuple_GetItem(value, 0), (PyObject *)get_python_data_type_type())) +        { +            PyErr_SetString(PyExc_TypeError, _("The first tuple item must be a GDataType.")); +            return -1; +        } + +        if (!PyUnicode_Check(PyTuple_GetItem(value, 1))) +        { +            PyErr_SetString(PyExc_TypeError, _("The second tuple item must be a string.")); +            return -1; +        } + +        ns = G_DATA_TYPE(pygobject_get(PyTuple_GetItem(value, 0))); +        sep = strdup(PyUnicode_DATA(pygobject_get(PyTuple_GetItem(value, 1)))); + +        g_object_ref(G_OBJECT(ns)); +        g_binary_routine_set_namespace(routine, ns, sep); + +    } + +    return 0; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                closure = non utilisé ici.                                   * +*                                                                             *  *  Description : Fournit le nom humain d'une routine.                         *  *                                                                             *  *  Retour      : Désignation humainement lisible ou None si non définie.      * @@ -189,6 +312,214 @@ static int py_binary_routine_set_name(PyObject *self, PyObject *value, void *clo  /******************************************************************************  *                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                closure = non utilisé ici.                                   * +*                                                                             * +*  Description : Fournit le type construisant le nom humain d'une routine.    * +*                                                                             * +*  Retour      : Eventuel type à l'origine du nom ou None.                    * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static PyObject *py_binary_routine_get_typed_name(PyObject *self, void *closure) +{ +    PyObject *result;                       /* Valeur à retourner          */ +    GBinRoutine *routine;                   /* Elément à consulter         */ +    GDataType *name;                        /* Type de nom                 */ + +    routine = G_BIN_ROUTINE(pygobject_get(self)); +    name = g_binary_routine_get_typed_name(routine); + +    if (name != NULL) +    { +        result = pygobject_new(G_OBJECT(name)); +        g_object_unref(G_OBJECT(name)); +    } + +    else +    { +        result = Py_None; +        Py_INCREF(result); +    } + +    return result; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                value   = valeur fournie à intégrer ou prendre en compte.    * +*                closure = non utilisé ici.                                   * +*                                                                             * +*  Description : Définit de façon indirecte le nom humain d'une routine.      * +*                                                                             * +*  Retour      : Bilan de l'opération pour Python.                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static int py_binary_routine_set_typed_name(PyObject *self, PyObject *value, void *closure) +{ +    GBinRoutine *routine;                   /* Elément à traiter           */ +    GDataType *name;                        /* Type de nom                 */ + +    if (!PyObject_IsInstance(value, (PyObject *)get_python_data_type_type()) && value != Py_None) +    { +        PyErr_SetString(PyExc_TypeError, _("The attribute value must be a GDataType or None.")); +        return -1; +    } + +    routine = G_BIN_ROUTINE(pygobject_get(self)); + +    if (value == Py_None) +        g_binary_routine_set_return_type(routine, NULL); + +    else +    { +        name = G_DATA_TYPE(pygobject_get(value)); + +        g_object_ref(G_OBJECT(name)); +        g_binary_routine_set_typed_name(routine, name); + +    } + +    return 0; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                closure = non utilisé ici.                                   * +*                                                                             * +*  Description : Fournit le type de retour d'une routine.                     * +*                                                                             * +*  Retour      : Indication sur le type de retour en place.                   * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static PyObject *py_binary_routine_get_return_type(PyObject *self, void *closure) +{ +    PyObject *result;                       /* Valeur à retourner          */ +    GBinRoutine *routine;                   /* Elément à consulter         */ +    GDataType *ret;                         /* Type de retour              */ + +    routine = G_BIN_ROUTINE(pygobject_get(self)); +    ret = g_binary_routine_get_return_type(routine); + +    if (ret != NULL) +    { +        result = pygobject_new(G_OBJECT(ret)); +        g_object_unref(G_OBJECT(ret)); +    } + +    else +    { +        result = Py_None; +        Py_INCREF(result); +    } + +    return result; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                value   = valeur fournie à intégrer ou prendre en compte.    * +*                closure = non utilisé ici.                                   * +*                                                                             * +*  Description : Définit le type de retour d'une routine.                     * +*                                                                             * +*  Retour      : Bilan de l'opération pour Python.                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static int py_binary_routine_set_return_type(PyObject *self, PyObject *value, void *closure) +{ +    GBinRoutine *routine;                   /* Elément à traiter           */ +    GDataType *ret;                         /* Type de retour              */ + +    if (!PyObject_IsInstance(value, (PyObject *)get_python_data_type_type()) && value != Py_None) +    { +        PyErr_SetString(PyExc_TypeError, _("The attribute value must be a GDataType or None.")); +        return -1; +    } + +    routine = G_BIN_ROUTINE(pygobject_get(self)); + +    if (value == Py_None) +        g_binary_routine_set_return_type(routine, NULL); + +    else +    { +        ret = G_DATA_TYPE(pygobject_get(value)); + +        g_object_ref(G_OBJECT(ret)); +        g_binary_routine_set_return_type(routine, ret); + +    } + +    return 0; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : self    = classe représentant une routine binaire.           * +*                closure = adresse non utilisée ici.                          * +*                                                                             * +*  Description : Fournit la liste des arguments associés à la routine.        * +*                                                                             * +*  Retour      : Ensemble de blocs déterminés via les instructions.           * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static PyObject *py_binary_routine_get_args(PyObject *self, void *closure) +{ +    PyObject *result;                       /* Résultat à retourner        */ +    GBinRoutine *routine;                   /* Version native              */ +    size_t count;                           /* Nombre de paramètres        */ +    size_t i;                               /* Boucle de parcours          */ +    GBinVariable *arg;                      /* Argument à transcrire       */ + +    routine = G_BIN_ROUTINE(pygobject_get(self)); + +    count = g_binary_routine_get_args_count(routine); + +    result = PyTuple_New(count); + +    for (i = 0; i < count; i++) +    { +        arg = g_binary_routine_get_arg(routine, i); + +        PyTuple_SetItem(result, i, pygobject_new(G_OBJECT(arg))); + +        g_object_unref(arg); + +    } + +    return result; + +} + + +/****************************************************************************** +*                                                                             *  *  Paramètres  : self    = classe représentant une routine binaire.           *  *                closure = adresse non utilisée ici.                          *  *                                                                             * @@ -269,10 +600,26 @@ PyTypeObject *get_python_binary_routine_type(void)      static PyGetSetDef py_binary_routine_getseters[] = {          { +            "namespace", py_binary_routine_get_namespace, py_binary_routine_set_namespace, +            "Namespace for the routine, None if any.", NULL +        }, +        {              "name", py_binary_routine_get_name, py_binary_routine_set_name,              "Name of the current routine.", NULL          },          { +            "typed_name", py_binary_routine_get_typed_name, py_binary_routine_set_typed_name, +            "Name of the current routine provided by a type.", NULL +        }, +        { +            "ret", py_binary_routine_get_return_type, py_binary_routine_set_return_type, +            "Return type of the routine, None if any.", NULL +        }, +        { +            "args", py_binary_routine_get_args, NULL, +            "Arguments for the routine.", NULL +        }, +        {              "basic_blocks", py_binary_routine_get_basic_blocks, py_binary_routine_set_basic_blocks,              "Basic blocks of the binary routine.", NULL          }, diff --git a/plugins/pychrysalide/analysis/type.c b/plugins/pychrysalide/analysis/type.c index 146e490..3694877 100644 --- a/plugins/pychrysalide/analysis/type.c +++ b/plugins/pychrysalide/analysis/type.c @@ -29,6 +29,9 @@  #include <pygobject.h> +#include <i18n.h> + +  #include <analysis/type.h> @@ -39,6 +42,27 @@  /* Décrit le type fourni sous forme de caractères. */  static PyObject *py_data_type_to_str(PyObject *); +/* Fournit le groupe d'appartenance d'un type donné. */ +static PyObject *py_data_type_get_namespace(PyObject *, void *); + +/* Définit le groupe d'appartenance d'un type donné. */ +static int py_data_type_set_namespace(PyObject *, PyObject *, void *); + +/* Fournit les qualificatifs associés à une instance de type. */ +static PyObject *py_data_type_get_qualifiers(PyObject *, void *); + +/* Définit l'ensemble des qualificatifs d'une instance de type. */ +static int py_data_type_set_qualifiers(PyObject *, PyObject *, void *); + +/* Indique si le type est un pointeur. */ +static PyObject *py_data_type_is_pointer(PyObject *, void *); + +/* Indique si le type est une référence. */ +static PyObject *py_data_type_is_reference(PyObject *, void *); + +/* Définit les constantes pour les types de données. */ +static bool py_data_type_define_constants(PyTypeObject *); +  /****************************************************************************** @@ -74,6 +98,237 @@ static PyObject *py_data_type_to_str(PyObject *self)  /******************************************************************************  *                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                closure = non utilisé ici.                                   * +*                                                                             * +*  Description : Fournit le groupe d'appartenance d'un type donné.            * +*                                                                             * +*  Retour      : Eventuelle instance d'appartenance ou None.                  * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static PyObject *py_data_type_get_namespace(PyObject *self, void *closure) +{ +    PyObject *result;                       /* Valeur à retourner          */ +    GDataType *type;                        /* Elément à consulter         */ +    GDataType *ns;                          /* Espace de noms              */ + +    type = G_DATA_TYPE(pygobject_get(self)); +    ns = g_data_type_get_namespace(type); + +    if (ns != NULL) +    { +        result = pygobject_new(G_OBJECT(ns)); +        g_object_unref(G_OBJECT(ns)); +    } + +    else +    { +        result = Py_None; +        Py_INCREF(result); +    } + +    return result; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                value   = valeur fournie à intégrer ou prendre en compte.    * +*                closure = non utilisé ici.                                   * +*                                                                             * +*  Description : Définit le groupe d'appartenance d'un type donné.            * +*                                                                             * +*  Retour      : Bilan de l'opération pour Python.                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static int py_data_type_set_namespace(PyObject *self, PyObject *value, void *closure) +{ +    GDataType *type;                        /* Elément à traiter           */ +    GDataType *ns;                          /* Espace de noms              */ +    char *sep;                              /* Séparateur des espaces      */ + +    if ((!PyTuple_Check(value) || (PyTuple_Check(value) && PyTuple_Size(value) != 2)) && value != Py_None) +    { +        PyErr_SetString(PyExc_TypeError, +                        _("The attribute value must be a tuple with GDataType and a separator or None.")); +        return -1; +    } + +    type = G_DATA_TYPE(pygobject_get(self)); + +    if (value == Py_None) +        g_data_type_set_namespace(type, NULL, NULL); + +    else +    { +        if (!PyObject_IsInstance(PyTuple_GetItem(value, 0), (PyObject *)get_python_data_type_type())) +        { +            PyErr_SetString(PyExc_TypeError, _("The first tuple item must be a GDataType.")); +            return -1; +        } + +        if (!PyUnicode_Check(PyTuple_GetItem(value, 1))) +        { +            PyErr_SetString(PyExc_TypeError, _("The second tuple item must be a string.")); +            return -1; +        } + +        ns = G_DATA_TYPE(pygobject_get(PyTuple_GetItem(value, 0))); +        sep = strdup(PyUnicode_DATA(pygobject_get(PyTuple_GetItem(value, 1)))); + +        g_object_ref(G_OBJECT(ns)); +        g_data_type_set_namespace(type, ns, sep); + +    } + +    return 0; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                closure = non utilisé ici.                                   * +*                                                                             * +*  Description : Fournit les qualificatifs associés à une instance de type.   * +*                                                                             * +*  Retour      : Qualificatifs éventuels.                                     * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static PyObject *py_data_type_get_qualifiers(PyObject *self, void *closure) +{ +    PyObject *result;                       /* Valeur à retourner          */ +    GDataType *type;                        /* Elément à consulter         */ +    TypeQualifier qualifiers;               /* Qualificatifs en place      */ + +    type = G_DATA_TYPE(pygobject_get(self)); +    qualifiers = g_data_type_get_qualifiers(type); + +    result = PyLong_FromUnsignedLong(qualifiers); + +    return result; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                value   = valeur fournie à intégrer ou prendre en compte.    * +*                closure = non utilisé ici.                                   * +*                                                                             * +*  Description : Définit l'ensemble des qualificatifs d'une instance de type. * +*                                                                             * +*  Retour      : Bilan de l'opération pour Python.                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static int py_data_type_set_qualifiers(PyObject *self, PyObject *value, void *closure) +{ +    GDataType *type;                        /* Elément à traiter           */ +    unsigned long qualifiers;               /* Qualificatifs à intégrer    */ + +    if (!PyLong_Check(value)) +    { +        PyErr_SetString(PyExc_TypeError, _("The attribute value must be a integer mask.")); +        return -1; +    } + +    qualifiers = PyLong_AsUnsignedLong(value); + +    if (qualifiers > TQF_ALL) +    { +        PyErr_SetString(PyExc_TypeError, _("Invalid value for type qualifiers.")); +        return -1; +    } + +    type = G_DATA_TYPE(pygobject_get(self)); + +    g_data_type_set_qualifiers(type, qualifiers); + +    return 0; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                closure = non utilisé ici.                                   * +*                                                                             * +*  Description : Indique si le type est un pointeur.                          * +*                                                                             * +*  Retour      : Bilan de la consultation.                                    * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static PyObject *py_data_type_is_pointer(PyObject *self, void *closure) +{ +    PyObject *result;                       /* Valeur à retourner          */ +    GDataType *type;                        /* Elément à consulter         */ +    bool status;                            /* Etat à faire suivre         */ + +    type = G_DATA_TYPE(pygobject_get(self)); + +    status = g_data_type_is_pointer(type); + +    result = status ? Py_True : Py_False; +    Py_INCREF(result); + +    return result; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : self    = objet Python concerné par l'appel.                 * +*                closure = non utilisé ici.                                   * +*                                                                             * +*  Description : Indique si le type est une référence.                        * +*                                                                             * +*  Retour      : Bilan de la consultation.                                    * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static PyObject *py_data_type_is_reference(PyObject *self, void *closure) +{ +    PyObject *result;                       /* Valeur à retourner          */ +    GDataType *type;                        /* Elément à consulter         */ +    bool status;                            /* Etat à faire suivre         */ + +    type = G_DATA_TYPE(pygobject_get(self)); + +    status = g_data_type_is_reference(type); + +    result = status ? Py_True : Py_False; +    Py_INCREF(result); + +    return result; + +} + + +/****************************************************************************** +*                                                                             *  *  Paramètres  : -                                                            *  *                                                                             *  *  Description : Fournit un accès à une définition de type à diffuser.        * @@ -91,6 +346,22 @@ PyTypeObject *get_python_data_type_type(void)      };      static PyGetSetDef py_data_type_getseters[] = { +        { +            "namespace", py_data_type_get_namespace, py_data_type_set_namespace, +            "Namespace for the type, None if any.", NULL +        }, +        { +            "qualifiers", py_data_type_get_qualifiers, py_data_type_set_qualifiers, +            "Qualifiers linked to the type, TQF_NONE if any.", NULL +        }, +        { +            "is_pointer", py_data_type_is_pointer, NULL, +            "True if the type is a pointer.", NULL +        }, +        { +            "is_reference", py_data_type_is_reference, NULL, +            "True if the type is a reference.", NULL +        },          { NULL }      }; @@ -118,6 +389,36 @@ PyTypeObject *get_python_data_type_type(void)  /******************************************************************************  *                                                                             * +*  Paramètres  : obj_type = type dont le dictionnaire est à compléter.        * +*                                                                             * +*  Description : Définit les constantes pour les types de données.            * +*                                                                             * +*  Retour      : -                                                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static bool py_data_type_define_constants(PyTypeObject *obj_type) +{ +    bool result;                            /* Bilan à retourner           */ + +    result = true; + +    result &= PyDict_AddIntMacro(obj_type, TQF_NONE); +    result &= PyDict_AddIntMacro(obj_type, TQF_RESTRICT); +    result &= PyDict_AddIntMacro(obj_type, TQF_VOLATILE); +    result &= PyDict_AddIntMacro(obj_type, TQF_CONST); + +    result &= PyDict_AddIntMacro(obj_type, TQF_ALL); + +    return result; + +} + + +/****************************************************************************** +*                                                                             *  *  Paramètres  : module = module dont la définition est à compléter.          *  *                                                                             *  *  Description : Prend en charge l'objet 'pychrysalide.analysis.DataType'.    * @@ -140,6 +441,9 @@ bool register_python_data_type(PyObject *module)      if (!register_class_for_pygobject(dict, G_TYPE_DATA_TYPE, py_data_type_type, &PyGObject_Type))          return false; +    if (!py_data_type_define_constants(py_data_type_type)) +        return false; +      return true;  } diff --git a/plugins/pychrysalide/analysis/variable.c b/plugins/pychrysalide/analysis/variable.c index 7437e54..268e3c9 100644 --- a/plugins/pychrysalide/analysis/variable.c +++ b/plugins/pychrysalide/analysis/variable.c @@ -167,7 +167,7 @@ static PyObject *py_binary_variable_get_name(PyObject *self, void *closure)  static int py_binary_variable_set_name(PyObject *self, PyObject *value, void *closure)  { -    GBinVariable *variable;                 /* Elément à consulter         */ +    GBinVariable *variable;                 /* Elément à traiter           */      if (!PyUnicode_Check(value) && value != Py_None)      { | 
