From 8a543bfae12bd2a616ddd4ba68afb86c9439c195 Mon Sep 17 00:00:00 2001 From: "Wolfgang (Blub) Bumiller" Date: Thu, 3 May 2012 22:05:20 +0200 Subject: [PATCH] reorder ifthen codegen and fix a jump generation where I used ontrue instead of onfalse --- ast.c | 78 ++++++++++++++++++++++++++++++++--------------------------- 1 file changed, 43 insertions(+), 35 deletions(-) diff --git a/ast.c b/ast.c index 7a68ba3..6a6abe5 100644 --- a/ast.c +++ b/ast.c @@ -742,34 +742,60 @@ bool ast_ifthen_codegen(ast_ifthen *self, ast_function *func, bool lvalue, ir_va (void)out; (void)lvalue; - /* create blocks first, it's nicer if they're ordered */ + /* generate the condition */ + func->curblock = cond; + cgen = self->cond->expression.codegen; + if (!(*cgen)((ast_expression*)(self->cond), func, false, &condval)) + return false; + + /* on-true path */ if (self->on_true) { /* create on-true block */ ontrue = ir_function_create_block(func->ir_func, ast_function_label(func, "ontrue")); if (!ontrue) return false; + + /* enter the block */ + func->curblock = ontrue; + + /* generate */ + cgen = self->on_true->expression.codegen; + if (!(*cgen)((ast_expression*)(self->on_true), func, false, &dummy)) + return false; } else ontrue = NULL; + /* on-false path */ if (self->on_false) { /* create on-false block */ onfalse = ir_function_create_block(func->ir_func, ast_function_label(func, "onfalse")); if (!onfalse) return false; + + /* enter the block */ + func->curblock = onfalse; + + /* generate */ + cgen = self->on_false->expression.codegen; + if (!(*cgen)((ast_expression*)(self->on_false), func, false, &dummy)) + return false; } else onfalse = NULL; + /* Merge block were they all merge in to */ merge = ir_function_create_block(func->ir_func, ast_function_label(func, "endif")); if (!merge) return NULL; - /* generate the condition */ - func->curblock = cond; - cgen = self->cond->expression.codegen; - if (!(*cgen)((ast_expression*)(self->cond), func, false, &condval)) + /* add jumps ot the merge block */ + if (ontrue && !ir_block_create_jump(ontrue, merge)) + return false; + if (onfalse && !ir_block_create_jump(onfalse, merge)) return false; + /* we create the if here, that way all blocks are ordered :) + */ if (!ir_block_create_if(cond, condval, (ontrue ? ontrue : merge), (onfalse ? onfalse : merge))) @@ -777,36 +803,6 @@ bool ast_ifthen_codegen(ast_ifthen *self, ast_function *func, bool lvalue, ir_va return false; } - /* on-true path */ - if (ontrue) { - /* enter the block */ - func->curblock = ontrue; - - /* generate */ - cgen = self->on_true->expression.codegen; - if (!(*cgen)((ast_expression*)(self->on_true), func, false, &dummy)) - return false; - - /* jump to merge block */ - if (!ir_block_create_jump(ontrue, merge)) - return false; - } - - /* on-false path */ - if (onfalse) { - /* enter the block */ - func->curblock = onfalse; - - /* generate */ - cgen = self->on_false->expression.codegen; - if (!(*cgen)((ast_expression*)(self->on_false), func, false, &dummy)) - return false; - - /* jump to merge block */ - if (!ir_block_create_jump(ontrue, merge)) - return false; - } - /* Now enter the merge block */ func->curblock = merge; @@ -919,5 +915,17 @@ bool ast_ternary_codegen(ast_ternary *self, ast_function *func, bool lvalue, ir_ bool ast_loop_codegen(ast_loop *self, ast_function *func, bool lvalue, ir_value **out) { + ast_expression_codegen *cgen; + + ir_value *precond; + ir_value *postcond; + + ir_block *binit; + ir_block *bprecond; + ir_block *bpostcond; + ir_block *bincrement; + + (void)lvalue; + return false; } -- 2.39.5