summaryrefslogtreecommitdiff
path: root/src/decomp/expr/block.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/decomp/expr/block.c')
-rw-r--r--src/decomp/expr/block.c61
1 files changed, 59 insertions, 2 deletions
diff --git a/src/decomp/expr/block.c b/src/decomp/expr/block.c
index b58972d..7c2387a 100644
--- a/src/decomp/expr/block.c
+++ b/src/decomp/expr/block.c
@@ -37,6 +37,8 @@ struct _GExprBlock
{
GDecExpression parent; /* A laisser en premier */
+ BlockBordeBehavior behavior; /* Type de Rendu des bordures */
+
GDecInstruction **list; /* Instructions contenues */
size_t count; /* Taille de cette liste */
@@ -113,6 +115,8 @@ static void g_expr_block_init(GExprBlock *block)
instr->replace = (dec_instr_replace_fc)g_expr_block_replace;
instr->print = (dec_instr_print_fc)g_expr_block_print;
+ block->behavior = BBB_AUTO;
+
}
@@ -143,6 +147,45 @@ GDecInstruction *g_expr_block_new(GDecInstruction *item)
/******************************************************************************
* *
+* Paramètres : block = première instruction à venir visiter. *
+* *
+* Description : Fournit le comportement du bloc pour le rendu de ses bords. *
+* *
+* Retour : Comportement pour le rendu des bordures. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+BlockBordeBehavior g_expr_block_get_border_behavior(const GExprBlock *block)
+{
+ return block->behavior;
+
+}
+
+
+/******************************************************************************
+* *
+* Paramètres : block = première instruction à venir visiter. *
+* behavior = comportement pour le rendu des bordures. *
+* *
+* Description : Définit le comportement du bloc pour le rendu de ses bords. *
+* *
+* Retour : - *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+void g_expr_block_set_border_behavior(GExprBlock *block, BlockBordeBehavior behavior)
+{
+ block->behavior = behavior;
+
+}
+
+
+/******************************************************************************
+* *
* Paramètres : block = première instruction à venir visiter. *
* callback = procédure à appeler à chaque instruction visitée. *
* flags = moments des appels à réaliser en retour. *
@@ -232,9 +275,23 @@ static bool g_expr_block_replace(GExprBlock *block, GDecInstruction *old, GDecIn
static GBufferLine *g_expr_block_print(const GExprBlock *block, GCodeBuffer *buffer, GBufferLine *line, GLangOutput *output)
{
GBufferLine *result; /* Ligne à retourner */
+ size_t expr_count; /* Taille officielle */
size_t i; /* Boucle de parcours */
- result = g_lang_output_start_code_block(output, buffer, line, block->count);
+ switch (block->behavior)
+ {
+ case BBB_AUTO:
+ expr_count = block->count;
+ break;
+ case BBB_FORCE_OFF:
+ expr_count = 1;
+ break;
+ case BBB_FORCE_ON:
+ expr_count = 2;
+ break;
+ }
+
+ result = g_lang_output_start_code_block(output, buffer, line, expr_count);
for (i = 0; i < block->count; i++)
{
@@ -245,7 +302,7 @@ static GBufferLine *g_expr_block_print(const GExprBlock *block, GCodeBuffer *buf
}
- result = g_lang_output_end_code_block(output, buffer, result, block->count);
+ result = g_lang_output_end_code_block(output, buffer, result, expr_count);
return result;