diff options
author | Cyrille Bagard <nocbos@gmail.com> | 2013-01-27 00:43:59 (GMT) |
---|---|---|
committer | Cyrille Bagard <nocbos@gmail.com> | 2013-01-27 00:43:59 (GMT) |
commit | 7f35f8d2f211fdf087252ede7665e9c81f35cdc7 (patch) | |
tree | d1c88366bc73e51db38ef982897e95950405bf52 /src/decomp/expr/return.c | |
parent | 2050b07c42c15738662dd9b3c5841694b64ab2a3 (diff) |
Implemented the first steps for visiting or replacing items in decompiled instructions.
git-svn-id: svn://svn.gna.org/svn/chrysalide/trunk@331 abbe820e-26c8-41b2-8c08-b7b2b41f8b0a
Diffstat (limited to 'src/decomp/expr/return.c')
-rw-r--r-- | src/decomp/expr/return.c | 78 |
1 files changed, 78 insertions, 0 deletions
diff --git a/src/decomp/expr/return.c b/src/decomp/expr/return.c index a9c10d9..d012893 100644 --- a/src/decomp/expr/return.c +++ b/src/decomp/expr/return.c @@ -53,6 +53,12 @@ static void g_return_expression_class_init(GReturnExpressionClass *); /* Initialise une instance d'ordre de retour. */ static void g_return_expression_init(GReturnExpression *); +/* Visite un ensemble hiérarchique d'instructions décompilées. */ +static bool g_return_expression_visit(GReturnExpression *, dec_instr_visitor_cb, DecInstrVisitFlags, void *); + +/* Remplace une instruction décompilée par une autre. */ +static bool g_return_expression_replace(GReturnExpression *, GDecInstruction *, GDecInstruction *); + /* Imprime pour l'écran un version humaine d'une expression. */ static GBufferLine *g_return_expression_print(const GReturnExpression *, GCodeBuffer *, GBufferLine *, GLangOutput *); @@ -98,6 +104,8 @@ static void g_return_expression_init(GReturnExpression *expr) instr = G_DEC_INSTRUCTION(expr); + instr->visit = (dec_instr_visit_fc)g_return_expression_visit; + instr->replace = (dec_instr_replace_fc)g_return_expression_replace; instr->print = (dec_instr_print_fc)g_return_expression_print; } @@ -130,6 +138,76 @@ GDecInstruction *g_return_expression_new(GDecExpression *payload) /****************************************************************************** * * +* Paramètres : expr = première instruction à venir visiter. * +* callback = procédure à appeler à chaque instruction visitée. * +* flags = moments des appels à réaliser en retour. * +* data = données quelconques associées au visiteur. * +* * +* Description : Visite un ensemble hiérarchique d'instructions décompilées. * +* * +* Retour : true si le parcours a été jusqu'à son terme, false sinon. * +* * +* Remarques : - * +* * +******************************************************************************/ + +static bool g_return_expression_visit(GReturnExpression *expr, dec_instr_visitor_cb callback, DecInstrVisitFlags flags, void *data) +{ + bool result; /* Bilan à retourner */ + + if (expr->payload) + result = g_dec_instruction_visit(G_DEC_INSTRUCTION(expr->payload), callback, flags, data); + else + result = false; + + return result; + +} + + +/****************************************************************************** +* * +* Paramètres : expr = première instruction à venir ausculter. * +* old = instruction décompilée à venir remplacer. * +* new = instruction décompilée à utiliser dorénavant. * +* * +* Description : Remplace une instruction décompilée par une autre. * +* * +* Retour : true si un remplacement a été effectué, false sinon. * +* * +* Remarques : - * +* * +******************************************************************************/ + +static bool g_return_expression_replace(GReturnExpression *expr, GDecInstruction *old, GDecInstruction *new) +{ + bool result; /* Bilan à retourner */ + + if (expr->payload) + { + if (expr->payload == G_DEC_EXPRESSION(old)) + { + g_object_unref(G_OBJECT(expr->payload)); + g_object_ref(G_OBJECT(new)); + expr->payload = G_DEC_EXPRESSION(new); + + result = true; + + } + else + result = g_dec_instruction_replace(G_DEC_INSTRUCTION(expr->payload), old, new); + + } + else + result = false; + + return result; + +} + + +/****************************************************************************** +* * * Paramètres : expr = expression à transcrire en version humaine. * * buffer = tampon où doit se réaliser l'insertion. * * line = ligne d'impression prête à emploi ou NULL. * |