diff options
Diffstat (limited to 'src/arch/operands')
| -rw-r--r-- | src/arch/operands/Makefile.am | 4 | ||||
| -rw-r--r-- | src/arch/operands/feeder-int.h | 66 | ||||
| -rw-r--r-- | src/arch/operands/feeder.c | 161 | ||||
| -rw-r--r-- | src/arch/operands/feeder.h | 70 | ||||
| -rw-r--r-- | src/arch/operands/proxy-int.h | 51 | ||||
| -rw-r--r-- | src/arch/operands/proxy.c | 326 | ||||
| -rw-r--r-- | src/arch/operands/proxy.h | 65 | 
7 files changed, 743 insertions, 0 deletions
diff --git a/src/arch/operands/Makefile.am b/src/arch/operands/Makefile.am index 4e52f58..74f057d 100644 --- a/src/arch/operands/Makefile.am +++ b/src/arch/operands/Makefile.am @@ -2,9 +2,13 @@  noinst_LTLIBRARIES = libarchoperands.la  libarchoperands_la_SOURCES =			\ +	feeder-int.h						\ +	feeder.h feeder.c					\  	immediate.h immediate.c				\  	register-int.h						\  	register.h register.c				\ +	proxy-int.h							\ +	proxy.h proxy.c						\  	rename-int.h						\  	rename.h rename.c					\  	targetable-int.h					\ diff --git a/src/arch/operands/feeder-int.h b/src/arch/operands/feeder-int.h new file mode 100644 index 0000000..9a58dd5 --- /dev/null +++ b/src/arch/operands/feeder-int.h @@ -0,0 +1,66 @@ + +/* Chrysalide - Outil d'analyse de fichiers binaires + * feeder-int.h - définitions internes propres aux fournisseurs d'éléments non architecturaux + * + * Copyright (C) 2018 Cyrille Bagard + * + *  This file is part of Chrysalide. + * + *  Chrysalide is free software; you can redistribute it and/or modify + *  it under the terms of the GNU General Public License as published by + *  the Free Software Foundation; either version 3 of the License, or + *  (at your option) any later version. + * + *  Chrysalide is distributed in the hope that it will be useful, + *  but WITHOUT ANY WARRANTY; without even the implied warranty of + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *  GNU General Public License for more details. + * + *  You should have received a copy of the GNU General Public License + *  along with Chrysalide.  If not, see <http://www.gnu.org/licenses/>. + */ + + +#ifndef _ARCH_OPERANDS_FEEDER_INT_H +#define _ARCH_OPERANDS_FEEDER_INT_H + + +#include "feeder.h" + + + +/* Compare un fournisseur avec un autre. */ +typedef int (* compare_proxy_operand_fc) (const GProxyFeeder *, const GProxyFeeder *); + +/* Traduit un fournisseur en version humainement lisible. */ +typedef void (* print_proxy_feeder_fc) (const GProxyFeeder *, GBufferLine *); + +/* Charge un fournisseur depuis une mémoire tampon. */ +typedef bool (* unserialize_proxy_feeder_fc) (GProxyFeeder *, GBinFormat *, packed_buffer *); + +/* Sauvegarde un fournisseur dans une mémoire tampon. */ +typedef bool (* serialize_proxy_feeder_fc) (const GProxyFeeder *, packed_buffer *); + + + +/* Fournisseur d'élément non architectural (interface) */ +struct _GProxyFeederIface +{ +    GTypeInterface base_iface;              /* A laisser en premier        */ + +    compare_proxy_operand_fc compare;       /* Comparaison entre éléments  */ + +    print_proxy_feeder_fc print;            /* Affichage sur une ligne     */ + +    unserialize_proxy_feeder_fc unserialize;/* Restauration de l'élément   */ +    serialize_proxy_feeder_fc serialize;    /* Sauvegarder de l'élément    */ + +}; + + +/* Redéfinition */ +typedef GProxyFeederIface GProxyFeederInterface; + + + +#endif  /* _ARCH_OPERANDS_FEEDER_INT_H */ diff --git a/src/arch/operands/feeder.c b/src/arch/operands/feeder.c new file mode 100644 index 0000000..6d24efc --- /dev/null +++ b/src/arch/operands/feeder.c @@ -0,0 +1,161 @@ + +/* Chrysalide - Outil d'analyse de fichiers binaires + * feeder.c - fourniture d'éléments non architecturaux + * + * Copyright (C) 2018 Cyrille Bagard + * + *  This file is part of Chrysalide. + * + *  Chrysalide is free software; you can redistribute it and/or modify + *  it under the terms of the GNU General Public License as published by + *  the Free Software Foundation; either version 3 of the License, or + *  (at your option) any later version. + * + *  Chrysalide is distributed in the hope that it will be useful, + *  but WITHOUT ANY WARRANTY; without even the implied warranty of + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *  GNU General Public License for more details. + * + *  You should have received a copy of the GNU General Public License + *  along with Chrysalide.  If not, see <http://www.gnu.org/licenses/>. + */ + + +#include "feeder.h" + + +#include "feeder-int.h" + + + +/* Procède à l'initialisation de l'interface de rassemblement. */ +static void g_proxy_feeder_default_init(GProxyFeederInterface *); + + + +/* Détermine le type d'une interface pour la Fourniture d'éléments non architecturaux. */ +G_DEFINE_INTERFACE(GProxyFeeder, g_proxy_feeder, G_TYPE_OBJECT) + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : iface = interface GLib à initialiser.                        * +*                                                                             * +*  Description : Procède à l'initialisation de l'interface de rassemblement.  * +*                                                                             * +*  Retour      : -                                                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static void g_proxy_feeder_default_init(GProxyFeederInterface *iface) +{ + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : a = premier fournisseur à consulter.                         * +*                b = second fournisseur à consulter.                          * +*                                                                             * +*  Description : Compare un fournisseur avec un autre.                        * +*                                                                             * +*  Retour      : Bilan de la comparaison.                                     * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +int g_proxy_feeder_compare(const GProxyFeeder *a, const GProxyFeeder *b) +{ +    int result;                             /* Bilan à retourner           */ +    GProxyFeederIface *iface;               /* Interface utilisée          */ + +    iface = G_PROXY_FEEDER_GET_IFACE(a); + +    result = iface->compare(a, b); + +    return result; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : feeder = fournisseur à traiter.                              * +*                line   = ligne tampon où imprimer l'élément donné.           * +*                                                                             * +*  Description : Traduit un fournisseur en version humainement lisible.       * +*                                                                             * +*  Retour      : -                                                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +void g_proxy_feeder_print(const GProxyFeeder *feeder, GBufferLine *line) +{ +    GProxyFeederIface *iface;               /* Interface utilisée          */ + +    iface = G_PROXY_FEEDER_GET_IFACE(feeder); + +    iface->print(feeder, line); + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : feeder = fournisseur à constituer.                           * +*                format = format binaire chargé associé à l'architecture.     * +*                pbuf   = zone tampon à remplir.                              * +*                                                                             * +*  Description : Charge un fournisseur depuis une mémoire tampon.             * +*                                                                             * +*  Retour      : Bilan de l'opération.                                        * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +bool g_proxy_feeder_unserialize(GProxyFeeder *feeder, GBinFormat *format, packed_buffer *pbuf) +{ +    bool result;                            /* Bilan à retourner           */ +    GProxyFeederIface *iface;               /* Interface utilisée          */ + +    iface = G_PROXY_FEEDER_GET_IFACE(feeder); + +    result = iface->unserialize(feeder, format, pbuf); + +    return result; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : feeder = fournisseur à consulter.                            * +*                pbuf   = zone tampon à remplir.                              * +*                                                                             * +*  Description : Sauvegarde un fournisseur dans une mémoire tampon.           * +*                                                                             * +*  Retour      : Bilan de l'opération.                                        * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +bool g_proxy_feeder_serialize(const GProxyFeeder *feeder, packed_buffer *pbuf) +{ +    bool result;                            /* Bilan à retourner           */ +    GProxyFeederIface *iface;               /* Interface utilisée          */ + +    iface = G_PROXY_FEEDER_GET_IFACE(feeder); + +    result = iface->serialize(feeder, pbuf); + +    return result; + +} diff --git a/src/arch/operands/feeder.h b/src/arch/operands/feeder.h new file mode 100644 index 0000000..7cea504 --- /dev/null +++ b/src/arch/operands/feeder.h @@ -0,0 +1,70 @@ + +/* Chrysalide - Outil d'analyse de fichiers binaires + * feeder.h - prototypes pour la fourniture d'éléments non architecturaux + * + * Copyright (C) 2018 Cyrille Bagard + * + *  This file is part of Chrysalide. + * + *  Chrysalide is free software; you can redistribute it and/or modify + *  it under the terms of the GNU General Public License as published by + *  the Free Software Foundation; either version 3 of the License, or + *  (at your option) any later version. + * + *  Chrysalide is distributed in the hope that it will be useful, + *  but WITHOUT ANY WARRANTY; without even the implied warranty of + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *  GNU General Public License for more details. + * + *  You should have received a copy of the GNU General Public License + *  along with Chrysalide.  If not, see <http://www.gnu.org/licenses/>. + */ + + +#ifndef _ARCH_OPERANDS_FEEDER_H +#define _ARCH_OPERANDS_FEEDER_H + + +#include <glib-object.h> +#include <stdbool.h> + + +#include "../../common/packed.h" +#include "../../format/format.h" +#include "../../glibext/gbufferline.h" + + + +#define G_TYPE_PROXY_FEEDER             (g_proxy_feeder_get_type()) +#define G_PROXY_FEEDER(obj)             (G_TYPE_CHECK_INSTANCE_CAST((obj), G_TYPE_PROXY_FEEDER, GProxyFeeder)) +#define G_PROXY_FEEDER_CLASS(vtable)    (G_TYPE_CHECK_CLASS_CAST((vtable), G_TYPE_PROXY_FEEDER, GProxyFeederIface)) +#define G_IS_PROXY_FEEDER(obj)          (G_TYPE_CHECK_INSTANCE_TYPE((obj), G_TYPE_PROXY_FEEDER)) +#define G_IS_PROXY_FEEDER_CLASS(vtable) (G_TYPE_CHECK_CLASS_TYPE((vtable), G_TYPE_PROXY_FEEDER)) +#define G_PROXY_FEEDER_GET_IFACE(inst)  (G_TYPE_INSTANCE_GET_INTERFACE((inst), G_TYPE_PROXY_FEEDER, GProxyFeederIface)) + + +/* Fournisseur d'élément non architectural (coquille vide) */ +typedef struct _GProxyFeeder GProxyFeeder; + +/* Fournisseur d'élément non architectural (interface) */ +typedef struct _GProxyFeederIface GProxyFeederIface; + + +/* Détermine le type d'une interface pour la Fourniture d'éléments non architecturaux. */ +GType g_proxy_feeder_get_type(void) G_GNUC_CONST; + +/* Compare un fournisseur avec un autre. */ +int g_proxy_feeder_compare(const GProxyFeeder *, const GProxyFeeder *); + +/* Traduit un fournisseur en version humainement lisible. */ +void g_proxy_feeder_print(const GProxyFeeder *, GBufferLine *); + +/* Charge un fournisseur depuis une mémoire tampon. */ +bool g_proxy_feeder_unserialize(GProxyFeeder *, GBinFormat *, packed_buffer *); + +/* Sauvegarde un fournisseur dans une mémoire tampon. */ +bool g_proxy_feeder_serialize(const GProxyFeeder *, packed_buffer *); + + + +#endif  /* _ARCH_OPERANDS_FEEDER_H */ diff --git a/src/arch/operands/proxy-int.h b/src/arch/operands/proxy-int.h new file mode 100644 index 0000000..c184986 --- /dev/null +++ b/src/arch/operands/proxy-int.h @@ -0,0 +1,51 @@ + +/* Chrysalide - Outil d'analyse de fichiers binaires + * proxy-int.h - définitions internes pour les opérandes renvoyant vers des éléments non architecturaux + * + * Copyright (C) 2020 Cyrille Bagard + * + *  This file is part of Chrysalide. + * + *  Chrysalide is free software; you can redistribute it and/or modify + *  it under the terms of the GNU General Public License as published by + *  the Free Software Foundation; either version 3 of the License, or + *  (at your option) any later version. + * + *  Chrysalide is distributed in the hope that it will be useful, + *  but WITHOUT ANY WARRANTY; without even the implied warranty of + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *  GNU General Public License for more details. + * + *  You should have received a copy of the GNU General Public License + *  along with Chrysalide.  If not, see <http://www.gnu.org/licenses/>. + */ + + +#ifndef _ARCH_OPERANDS_PROXY_INT_H +#define _ARCH_OPERANDS_PROXY_INT_H + + +#include "proxy.h" +#include "../operand-int.h" + + + +/* Définition d'un opérande renvoyant vers un élément (instance) */ +struct _GProxyOperand +{ +    GArchOperand parent;                    /* Instance parente            */ + +    GProxyFeeder *feeder;                   /* Fournisseur de contenu      */ + +}; + +/* Définition d'un opérande renvoyant vers un élément (classe) */ +struct _GProxyOperandClass +{ +    GArchOperandClass parent;               /* Classe parente              */ + +}; + + + +#endif  /* _ARCH_OPERANDS_PROXY_INT_H */ diff --git a/src/arch/operands/proxy.c b/src/arch/operands/proxy.c new file mode 100644 index 0000000..469e656 --- /dev/null +++ b/src/arch/operands/proxy.c @@ -0,0 +1,326 @@ + +/* Chrysalide - Outil d'analyse de fichiers binaires + * proxy.c - opérandes renvoyant vers des éléments non architecturaux + * + * Copyright (C) 2018 Cyrille Bagard + * + *  This file is part of Chrysalide. + * + *  Chrysalide is free software; you can redistribute it and/or modify + *  it under the terms of the GNU General Public License as published by + *  the Free Software Foundation; either version 3 of the License, or + *  (at your option) any later version. + * + *  Chrysalide is distributed in the hope that it will be useful, + *  but WITHOUT ANY WARRANTY; without even the implied warranty of + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *  GNU General Public License for more details. + * + *  You should have received a copy of the GNU General Public License + *  along with Chrysalide.  If not, see <http://www.gnu.org/licenses/>. + */ + + +#include "proxy.h" + + +#include "proxy-int.h" + + + +/* ------------------ OPERANDES CONSTITUANT DE PURS INTERMEDIAIRES ------------------ */ + + +/* Initialise la classe des opérandes renvoyant vers un élément. */ +static void g_proxy_operand_class_init(GProxyOperandClass *); + +/* Initialise une instance d'opérande renvoyant vers un élément. */ +static void g_proxy_operand_init(GProxyOperand *); + +/* Supprime toutes les références externes. */ +static void g_proxy_operand_dispose(GProxyOperand *); + +/* Procède à la libération totale de la mémoire. */ +static void g_proxy_operand_finalize(GProxyOperand *); + +/* Compare un opérande avec un autre. */ +static int g_proxy_operand_compare(const GProxyOperand *, const GProxyOperand *); + +/* Traduit un opérande en version humainement lisible. */ +static void g_proxy_operand_print(const GProxyOperand *, GBufferLine *); + + + +/* --------------------- TRANSPOSITIONS VIA CACHE DES OPERANDES --------------------- */ + + +/* Charge un opérande depuis une mémoire tampon. */ +static bool g_proxy_operand_unserialize(GProxyOperand *, GAsmStorage *, GBinFormat *, packed_buffer *); + +/* Sauvegarde un opérande dans une mémoire tampon. */ +static bool g_proxy_operand_serialize(const GProxyOperand *, GAsmStorage *, packed_buffer *); + + + +/* ---------------------------------------------------------------------------------- */ +/*                    OPERANDES CONSTITUANT DE PURS INTERMEDIAIRES                    */ +/* ---------------------------------------------------------------------------------- */ + + +/* Indique le type défini pour un opérande de valeur numérique. */ +G_DEFINE_TYPE(GProxyOperand, g_proxy_operand, G_TYPE_ARCH_OPERAND); + + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : klass = classe à initialiser.                                * +*                                                                             * +*  Description : Initialise la classe des opérandes renvoyant vers un élément.* +*                                                                             * +*  Retour      : -                                                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static void g_proxy_operand_class_init(GProxyOperandClass *klass) +{ +    GObjectClass *object;                   /* Autre version de la classe  */ +    GArchOperandClass *operand;             /* Version de classe parente   */ + +    object = G_OBJECT_CLASS(klass); +    operand = G_ARCH_OPERAND_CLASS(klass); + +    object->dispose = (GObjectFinalizeFunc/* ! */)g_proxy_operand_dispose; +    object->finalize = (GObjectFinalizeFunc)g_proxy_operand_finalize; + +    operand->compare = (operand_compare_fc)g_proxy_operand_compare; +    operand->print = (operand_print_fc)g_proxy_operand_print; + +    operand->unserialize = (unserialize_operand_fc)g_proxy_operand_unserialize; +    operand->serialize = (serialize_operand_fc)g_proxy_operand_serialize; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : operand = instance à initialiser.                            * +*                                                                             * +*  Description : Initialise une instance d'opérande renvoyant vers un élément.* +*                                                                             * +*  Retour      : -                                                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static void g_proxy_operand_init(GProxyOperand *operand) +{ + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : operand = instance d'objet GLib à traiter.                   * +*                                                                             * +*  Description : Supprime toutes les références externes.                     * +*                                                                             * +*  Retour      : -                                                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static void g_proxy_operand_dispose(GProxyOperand *operand) +{ +    if (operand->feeder != NULL) +        g_object_unref(G_OBJECT(operand->feeder)); + +    G_OBJECT_CLASS(g_proxy_operand_parent_class)->dispose(G_OBJECT(operand)); + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : operand = instance d'objet GLib à traiter.                   * +*                                                                             * +*  Description : Procède à la libération totale de la mémoire.                * +*                                                                             * +*  Retour      : -                                                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static void g_proxy_operand_finalize(GProxyOperand *operand) +{ +    G_OBJECT_CLASS(g_proxy_operand_parent_class)->finalize(G_OBJECT(operand)); + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : feeder = fournisseur sur lequel s'appuyer.                   * +*                                                                             * +*  Description : Crée un opérande renvoyant vers un élément non architectural.* +*                                                                             * +*  Retour      : Opérande mis en place.                                       * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +GArchOperand *g_proxy_operand_new(GProxyFeeder *feeder) +{ +    GProxyOperand *result;                    /* Opérande à retourner        */ + +    result = g_object_new(G_TYPE_PROXY_OPERAND, NULL); + +    result->feeder = feeder; + +    return G_ARCH_OPERAND(result); + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : a = premier opérande à consulter.                            * +*                b = second opérande à consulter.                             * +*                                                                             * +*  Description : Compare un opérande avec un autre.                           * +*                                                                             * +*  Retour      : Bilan de la comparaison.                                     * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static int g_proxy_operand_compare(const GProxyOperand *a, const GProxyOperand *b) +{ +    int result;                             /* Bilan à retourner           */ + +    result = g_proxy_feeder_compare(a->feeder, b->feeder); + +    return result; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : operand = opérande à traiter.                                * +*                line    = ligne tampon où imprimer l'opérande donné.         * +*                                                                             * +*  Description : Traduit un opérande en version humainement lisible.          * +*                                                                             * +*  Retour      : -                                                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static void g_proxy_operand_print(const GProxyOperand *operand, GBufferLine *line) +{ +    g_proxy_feeder_print(operand->feeder, line); + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : operand = opérande à consulter.                              * +*                                                                             * +*  Description : Fournit le fournisseur représenté par l'opérande.            * +*                                                                             * +*  Retour      : Fournisseur associé à l'opérande.                            * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +GProxyFeeder *g_proxy_operand_get_feeder(const GProxyOperand *operand) +{ +    GProxyFeeder *result;                   /* Instance à retourner        */ + +    result = operand->feeder; + +    g_object_ref(G_OBJECT(result)); + +    return result; + +} + + + +/* ---------------------------------------------------------------------------------- */ +/*                       TRANSPOSITIONS VIA CACHE DES OPERANDES                       */ +/* ---------------------------------------------------------------------------------- */ + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : operand = opérande d'assemblage à constituer.                * +*                storage = mécanisme de sauvegarde à manipuler.               * +*                format  = format binaire chargé associé à l'architecture.    * +*                pbuf    = zone tampon à remplir.                             * +*                                                                             * +*  Description : Charge un opérande depuis une mémoire tampon.                * +*                                                                             * +*  Retour      : Bilan de l'opération.                                        * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static bool g_proxy_operand_unserialize(GProxyOperand *operand, GAsmStorage *storage, GBinFormat *format, packed_buffer *pbuf) +{ +    bool result;                            /* Bilan à retourner           */ +    GArchOperandClass *parent;              /* Classe parente à consulter  */ + +    parent = G_ARCH_OPERAND_CLASS(g_proxy_operand_parent_class); + +    result = parent->unserialize(G_ARCH_OPERAND(operand), storage, format, pbuf); + +    if (result) +        result = g_proxy_feeder_unserialize(operand->feeder, format, pbuf); + +    return result; + +} + + +/****************************************************************************** +*                                                                             * +*  Paramètres  : operand = opérande d'assemblage à consulter.                 * +*                storage = mécanisme de sauvegarde à manipuler.               * +*                pbuf    = zone tampon à remplir.                             * +*                                                                             * +*  Description : Sauvegarde un opérande dans une mémoire tampon.              * +*                                                                             * +*  Retour      : Bilan de l'opération.                                        * +*                                                                             * +*  Remarques   : -                                                            * +*                                                                             * +******************************************************************************/ + +static bool g_proxy_operand_serialize(const GProxyOperand *operand, GAsmStorage *storage, packed_buffer *pbuf) +{ +    bool result;                            /* Bilan à retourner           */ +    GArchOperandClass *parent;              /* Classe parente à consulter  */ + +    parent = G_ARCH_OPERAND_CLASS(g_proxy_operand_parent_class); + +    result = parent->serialize(G_ARCH_OPERAND(operand), storage, pbuf); + +    if (result) +        result = g_proxy_feeder_serialize(operand->feeder, pbuf); + +    return result; + +} diff --git a/src/arch/operands/proxy.h b/src/arch/operands/proxy.h new file mode 100644 index 0000000..16b07a8 --- /dev/null +++ b/src/arch/operands/proxy.h @@ -0,0 +1,65 @@ + +/* Chrysalide - Outil d'analyse de fichiers binaires + * proxy.h - prototypes pour les opérandes renvoyant vers des éléments non architecturaux + * + * Copyright (C) 2018 Cyrille Bagard + * + *  This file is part of Chrysalide. + * + *  Chrysalide is free software; you can redistribute it and/or modify + *  it under the terms of the GNU General Public License as published by + *  the Free Software Foundation; either version 3 of the License, or + *  (at your option) any later version. + * + *  Chrysalide is distributed in the hope that it will be useful, + *  but WITHOUT ANY WARRANTY; without even the implied warranty of + *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the + *  GNU General Public License for more details. + * + *  You should have received a copy of the GNU General Public License + *  along with Chrysalide.  If not, see <http://www.gnu.org/licenses/>. + */ + + +#ifndef _ARCH_OPERANDS_PROXY_H +#define _ARCH_OPERANDS_PROXY_H + + +#include <glib-object.h> + + +#include "feeder.h" +#include "../operand.h" + + + +/* ------------------ OPERANDES CONSTITUANT DE PURS INTERMEDIAIRES ------------------ */ + + +#define G_TYPE_PROXY_OPERAND            g_proxy_operand_get_type() +#define G_PROXY_OPERAND(obj)            (G_TYPE_CHECK_INSTANCE_CAST((obj), G_TYPE_PROXY_OPERAND, GProxyOperand)) +#define G_IS_PROXY_OPERAND(obj)         (G_TYPE_CHECK_INSTANCE_TYPE((obj), G_TYPE_PROXY_OPERAND)) +#define G_PROXY_OPERAND_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST((klass), G_TYPE_PROXY_OPERAND, GProxyOperandClass)) +#define G_IS_PROXY_OPERAND_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), G_TYPE_PROXY_OPERAND)) +#define G_PROXY_OPERAND_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS((obj), G_TYPE_PROXY_OPERAND, GProxyOperandClass)) + + +/* Définition d'un opérande renvoyant vers un élément (instance) */ +typedef struct _GProxyOperand GProxyOperand; + +/* Définition d'un opérande renvoyant vers un élément (classe) */ +typedef struct _GProxyOperandClass GProxyOperandClass; + + +/* Indique le type défini pour un opérande d'architecture. */ +GType g_proxy_operand_get_type(void); + +/* Crée un opérande renvoyant vers un élément non architectural. */ +GArchOperand *g_proxy_operand_new(GProxyFeeder *); + +/* Fournit le fournisseur représenté par l'opérande. */ +GProxyFeeder *g_proxy_operand_get_feeder(const GProxyOperand *); + + + +#endif  /* _ARCH_OPERANDS_PROXY_H */  | 
