diff options
author | Cyrille Bagard <nocbos@gmail.com> | 2015-03-25 22:24:41 (GMT) |
---|---|---|
committer | Cyrille Bagard <nocbos@gmail.com> | 2015-03-25 22:24:41 (GMT) |
commit | a6bedf6104ccd7d8050e9d6a58f32c0827e3383c (patch) | |
tree | 3d06871144b1074ea5b70f4a4a6e08cf1418ff44 | |
parent | 276ec9c9b8a3b283751c8d8c59f70c3fc88d5b0d (diff) |
Fixed a regression by taking care of results before going to a error exit.
git-svn-id: svn://svn.gna.org/svn/chrysalide/trunk@494 abbe820e-26c8-41b2-8c08-b7b2b41f8b0a
-rw-r--r-- | ChangeLog | 9 | ||||
-rw-r--r-- | tools/d2c/conv.c | 2 | ||||
-rw-r--r-- | tools/d2c/macros.c | 167 | ||||
-rw-r--r-- | tools/d2c/macros.h | 30 |
4 files changed, 10 insertions, 198 deletions
@@ -1,3 +1,12 @@ +15-03-25 Cyrille Bagard <nocbos@gmail.com> + + * tools/d2c/conv.c: + Fix a regression by taking care of results before going to a error exit. + + * tools/d2c/macros.c: + * tools/d2c/macros.h: + Deleted entries: replaced a long time ago by the 'pproc.[ch]' files. + 15-03-21 Cyrille Bagard <nocbos@gmail.com> * src/analysis/blocks/flow.c: diff --git a/tools/d2c/conv.c b/tools/d2c/conv.c index 9947593..3fae6df 100644 --- a/tools/d2c/conv.c +++ b/tools/d2c/conv.c @@ -358,7 +358,7 @@ bool define_conv_func(conv_func *func, bool last, bool internal, int fd, const c { /* Si l'on doit manipuler une propriété d'instructon... */ if (internal) - result = call_instr_func(callable, func->args, fd, bits, list, pp); + result = checked_call_instr_func(callable, func->args, fd, bits, list, pp); /* Si on doit constituer un opérande à ajouter... */ else diff --git a/tools/d2c/macros.c b/tools/d2c/macros.c deleted file mode 100644 index b1c44f0..0000000 --- a/tools/d2c/macros.c +++ /dev/null @@ -1,167 +0,0 @@ - -/* Chrysalide - Outil d'analyse de fichiers binaires - * pproc.c - remplacements à la volée de chaînes de caractères - * - * Copyright (C) 2014 Cyrille Bagard - * - * This file is part of Chrysalide. - * - * OpenIDA 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. - * - * OpenIDA 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 Foobar. If not, see <http://www.gnu.org/licenses/>. - */ - - -#include "pproc.h" - - -#include <malloc.h> - - - - - - -/* Conversion des chaînes en chaînes */ -typedef struct _string_exch -{ - const char *src; /* Chaîne à trouver */ - const char *dest; /* Chaîne de remplacement */ - -} string_exch; - - -/* Pré-processeur avec support des macros */ -struct _pre_processor -{ - string_exch *macros; /* Remplacements de chaînes */ - size_t macros_count; /* Nombre de ces remplacements */ - - - -} - - - - - - -/****************************************************************************** -* * -* Paramètres : - * -* * -* Description : Crée un nouveau suivi de l'encodage d'une instruction. * -* * -* Retour : Nouvelle structure prête à emploi. * -* * -* Remarques : - * -* * -******************************************************************************/ - -encoding_spec *create_encoding_spec(void) -{ - encoding_spec *result; /* Définition vierge à renvoyer*/ - - result = (encoding_spec *)calloc(1, sizeof(encoding_spec)); - - result->bits = create_coding_bits(); - result->syntax = create_asm_syntax(); - result->conversions = create_conv_list(); - result->rules = create_decoding_rules(); - - return result; - -} - - -/****************************************************************************** -* * -* Paramètres : spec = spécification d'encodage à libérer de la mémoire. * -* * -* Description : Supprime de la mémoire un suivi d'encodage d'une instruction.* -* * -* Retour : - * -* * -* Remarques : - * -* * -******************************************************************************/ - -void delete_encoding_spec(encoding_spec *spec) -{ - delete_coding_bits(spec->bits); - delete_asm_syntax(spec->syntax); - delete_conv_list(spec->conversions); - delete_decoding_rules(spec->rules); - - free(spec); - -} - - - -/****************************************************************************** -* * -* Paramètres : coder = gestion par la machine en remplacement de l'humain. * -* src = chaîne à remplacer dans les définitions. * -* dest = chaîne de remplacement. * -* * -* Description : Constitue la matière d'un système de macros. * -* * -* Retour : - * -* * -* Remarques : - * -* * -******************************************************************************/ - -void define_macro_for_coder(rented_coder *coder, const char *src, const char *dest) -{ - string_exch *macro; /* Nouvelle macro à constituer */ - - coder->macros = (string_exch *)realloc(coder->macros, ++coder->macros_count * sizeof(string_exch)); - - macro = &coder->macros[coder->macros_count - 1]; - - macro->src = src; - macro->dest = dest; - -} - - -/****************************************************************************** -* * -* Paramètres : coder = gestion par la machine en remplacement de l'humain. * -* src = chaîne à remplacer dans les définitions. * -* * -* Description : Recherche l'existence d'une macro pour un remplacement. * -* * -* Retour : - * -* * -* Remarques : - * -* * -******************************************************************************/ - -static const char *find_macro_in_coder(const rented_coder *coder, const char *src) -{ - const char *result; /* Trouvaille à renvoyer */ - size_t i; /* Boucle de parcours */ - - result = NULL; - - for (i = 0; i < coder->macros_count && result == NULL; i++) - if (strcmp(coder->macros[i].src, src) == 0) - result = coder->macros[i].dest; - - return result; - -} - - diff --git a/tools/d2c/macros.h b/tools/d2c/macros.h deleted file mode 100644 index 3755f00..0000000 --- a/tools/d2c/macros.h +++ /dev/null @@ -1,30 +0,0 @@ - -/* Chrysalide - Outil d'analyse de fichiers binaires - * macros.h - prototypes pour les remplacements à la volée de chaînes de caractères - * - * Copyright (C) 2014 Cyrille Bagard - * - * This file is part of Chrysalide. - * - * OpenIDA 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. - * - * OpenIDA 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 Foobar. If not, see <http://www.gnu.org/licenses/>. - */ - - -#ifndef _TOOLS_MACROS_H -#define _TOOLS_MACROS_H - - - - -#endif /* _TOOLS_MACROS_H */ |