@reg @Statement.node@->reg = @Expr.node@->reg = next_reg((char *)NULL, @Expr.gparamges@);
@gen {
- printf("%s_ifstart_%d:\n", get_func_name(), @Statement.lblcnt_in@);
+ printf(".%s_ifstart_%d:\n", get_func_name(), @Statement.lblcnt_in@);
write_tree(@Statement.node@, 0); burm_label(@Statement.node@); burm_reduce(@Statement.node@, 1);
/* TODO: kann ich mir das test wirklich wegan and davor sparen? */
- printf("\ttest %s-1, %%rax\n\tjz %s_ifend_%d\n", "$", get_func_name(), @Statement.lblcnt_in@);
+ printf("\tjz .%s_ifend_%d\n", get_func_name(), @Statement.lblcnt_in@);
}
- @gen @revorder(1) printf("%s_ifend_%d:\n", get_func_name(), @Statement.lblcnt_in@);
+ @gen @revorder(1) printf(".%s_ifend_%d:\n", get_func_name(), @Statement.lblcnt_in@);
@}
| IF Expr THEN Statseq Elsestat END
@reg @Statement.node@->reg = @Expr.node@->reg = next_reg((char *)NULL, @Expr.gparamges@);
@gen {
- printf("%s_ifstart_%d:\n", get_func_name(), @Statement.lblcnt_in@);
+ printf(".%s_ifstart_%d:\n", get_func_name(), @Statement.lblcnt_in@);
write_tree(@Statement.node@, 0); burm_label(@Statement.node@); burm_reduce(@Statement.node@, 1);
/* TODO: kann ich mir das test wirklich wegan and davor sparen? */
- printf("\ttest %s-1, %%rax\n\tjz %s_ifelse_%d\n", "$", get_func_name(), @Statement.lblcnt_in@);
+ printf("\tjz .%s_ifelse_%d\n", get_func_name(), @Statement.lblcnt_in@);
}
- @gen @revorder(1) printf("%s_ifend_%d:\n", get_func_name(), @Statement.lblcnt_in@);
+ @gen @revorder(1) printf(".%s_ifend_%d:\n", get_func_name(), @Statement.lblcnt_in@);
@}
| WHILE Expr DO Statseq END
@reg @Statement.node@->reg = @Expr.node@->reg = next_reg((char *)NULL, @Expr.gparamges@);
@gen {
- printf("%s_whilestart_%d:\n", get_func_name(), @Statement.lblcnt_in@);
+ printf(".%s_whilestart_%d:\n", get_func_name(), @Statement.lblcnt_in@);
write_tree(@Statement.node@, 0); burm_label(@Statement.node@); burm_reduce(@Statement.node@, 1);
/* TODO: kann ich mir das test wirklich wegan and davor sparen? */
- printf("\ttest %s-1, %%rax\n\tjz %s_whileend_%d\n", "$", get_func_name(), @Statement.lblcnt_in@);
+ printf("\tjz .%s_whileend_%d\n", get_func_name(), @Statement.lblcnt_in@);
}
- @gen @revorder(1) printf("\tjmp %s_whilestart_%d\n%s_whileend_%d:\n", get_func_name(), @Statement.lblcnt_in@, get_func_name(), @Statement.lblcnt_in@);
+ @gen @revorder(1) printf("\tjmp .%s_whilestart_%d\n.%s_whileend_%d:\n", get_func_name(), @Statement.lblcnt_in@, get_func_name(), @Statement.lblcnt_in@);
@}
| RETURN Expr
@i @Statseq.lblcnt_in@ = @Elsestat.lblcnt_in@;
@i @Elsestat.lblcnt_out@ = @Statseq.lblcnt_out@;
- @gen printf("\tjmp %s_ifend_%d\n%s_ifelse_%d:\n", get_func_name(), @Elsestat.reallblcnt@, get_func_name(), @Elsestat.reallblcnt@);
+ @gen printf("\tjmp .%s_ifend_%d\n.%s_ifelse_%d:\n", get_func_name(), @Elsestat.reallblcnt@, get_func_name(), @Elsestat.reallblcnt@);
@}
Lexpr:
| NOT Term
@{
- @i @Expr.node@ = new_node(O_EQ, @Term.node@, new_node(O_NULL, TREENULL, TREENULL));
+ @i @Expr.node@ = new_node(O_BOOL, new_node(O_EQ, @Term.node@, new_node(O_NULL, TREENULL, TREENULL)), TREENULL);
- @reg @Term.node@->reg = @Expr.node@->reg;
+ @reg @Term.node@->reg = @Expr.node@->kids[0]->reg = @Expr.node@->reg;
@}
| Term Minusterm
| Term '<' Term
@{
- @i @Expr.node@ = new_node(O_LESS, @Term.0.node@, @Term.1.node@);
+ @i @Expr.node@ = new_node(O_BOOL, new_node(O_LESS, @Term.0.node@, @Term.1.node@), TREENULL);
@i @Expr.imm@ = @Term.0.imm@ && @Term.0.imm@;
@reg {
- @Term.0.node@->reg = @Expr.node@->reg;
+ @Term.0.node@->reg = @Expr.node@->kids[0]->reg = @Expr.node@->reg;
@Term.1.node@->reg = next_reg(@Term.0.node@->reg, @Expr.gparamges@);
}
@}
| Term '=' Term
@{
- @i @Expr.node@ = new_node(O_EQ, @Term.0.node@, @Term.1.node@);
+ @i @Expr.node@ = new_node(O_BOOL, new_node(O_EQ, @Term.0.node@, @Term.1.node@), TREENULL);
@i @Expr.imm@ = @Term.0.imm@ && @Term.0.imm@;
@reg {
- @Term.0.node@->reg = @Expr.node@->reg;
+ @Term.0.node@->reg = @Expr.node@->kids[0]->reg = @Expr.node@->reg;
@Term.1.node@->reg = next_reg(@Term.0.node@->reg, @Expr.gparamges@);
}
@}