diff options
Diffstat (limited to 'src/decomp/expr/access.c')
-rw-r--r-- | src/decomp/expr/access.c | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/src/decomp/expr/access.c b/src/decomp/expr/access.c index 277209a..f06c47b 100644 --- a/src/decomp/expr/access.c +++ b/src/decomp/expr/access.c @@ -54,6 +54,12 @@ static void g_access_expression_class_init(GAccessExpressionClass *); /* Initialise une instance d'accessation quelconque. */ static void g_access_expression_init(GAccessExpression *); +/* Visite un ensemble hiérarchique d'instructions décompilées. */ +static bool g_access_expression_visit(GAccessExpression *, dec_instr_visitor_cb, DecInstrVisitFlags, void *); + +/* Remplace une instruction décompilée par une autre. */ +static bool g_access_expression_replace(GAccessExpression *, GDecInstruction *, GDecInstruction *); + /* Imprime pour l'écran un version humaine d'une expression. */ static GBufferLine *g_access_expression_print(const GAccessExpression *, GCodeBuffer *, GBufferLine *, GLangOutput *); @@ -99,6 +105,8 @@ static void g_access_expression_init(GAccessExpression *expr) instr = G_DEC_INSTRUCTION(expr); + instr->visit = (dec_instr_visit_fc)g_access_expression_visit; + instr->replace = (dec_instr_replace_fc)g_access_expression_replace; instr->print = (dec_instr_print_fc)g_access_expression_print; } @@ -133,6 +141,82 @@ GDecInstruction *g_access_expression_new(GDecExpression *owner, GDecExpression * /****************************************************************************** * * +* 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_access_expression_visit(GAccessExpression *expr, dec_instr_visitor_cb callback, DecInstrVisitFlags flags, void *data) +{ + bool result; /* Bilan à retourner */ + + result = g_dec_instruction_visit(G_DEC_INSTRUCTION(expr->owner), callback, flags, data); + + if (result) + result = g_dec_instruction_visit(G_DEC_INSTRUCTION(expr->target), callback, flags, data); + + 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_access_expression_replace(GAccessExpression *expr, GDecInstruction *old, GDecInstruction *new) +{ + bool result; /* Bilan à retourner */ + + if (expr->owner == G_DEC_EXPRESSION(old)) + { + g_object_unref(G_OBJECT(expr->owner)); + g_object_ref(G_OBJECT(new)); + expr->owner = G_DEC_EXPRESSION(new); + + result = true; + + } + else + result = g_dec_instruction_replace(G_DEC_INSTRUCTION(expr->owner), old, new); + + if (expr->target == G_DEC_EXPRESSION(old)) + { + g_object_unref(G_OBJECT(expr->target)); + g_object_ref(G_OBJECT(new)); + expr->target = G_DEC_EXPRESSION(new); + + result = true; + + } + else + result |= g_dec_instruction_replace(G_DEC_INSTRUCTION(expr->target), old, new); + + 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. * |