projects
/
uebersetzerbau-ss10.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
gesamt: variablen und calls 'mitzaehlen'
[uebersetzerbau-ss10.git]
/
gesamt
/
code.bfe
diff --git
a/gesamt/code.bfe
b/gesamt/code.bfe
index 8615fab3d1222133a0a14eda3fcf0f270bf71415..15eb808460cc8514a40a7b70e769c88cafad0885 100644
(file)
--- a/
gesamt/code.bfe
+++ b/
gesamt/code.bfe
@@
-185,7
+185,7
@@
void assign_var(struct treenode *bnode)
%}
%start begin
%}
%start begin
-%term O_RET=1 O_NULL=2 O_SUB=3 O_MUL=4 O_OR=5 O_LESS=6 O_EQ=7 O_ID=8 O_ADD=9 O_NUM=10 O_FIELD=11 O_MTWO=12 O_MFOUR=13 O_MEIGHT=14 O_MONE=15 O_ASSIGN=16 O_IF=17 O_BOOL=18
+%term O_RET=1 O_NULL=2 O_SUB=3 O_MUL=4 O_OR=5 O_LESS=6 O_EQ=7 O_ID=8 O_ADD=9 O_NUM=10 O_FIELD=11 O_MTWO=12 O_MFOUR=13 O_MEIGHT=14 O_MONE=15 O_ASSIGN=16 O_IF=17 O_BOOL=18
O_CALL=19
%%
%%
@@
-209,7
+209,7
@@
ifstat: O_IF(expr) # 2 # /* iburg beschummeln :/ */ printf("\ttest $-1, %%rax\n"
ifstat: O_IF(O_BOOL(expr)) # 1 # /* dann braucht man kein test */
ifstat: O_IF(O_BOOL(expr)) # 1 # /* dann braucht man kein test */
-ret: O_RET(retexpr) # 2 # printf("\t//o_ret(expr)\n"); move(BN_REG, "rax");
func_footer();
+ret: O_RET(retexpr) # 2 # printf("\t//o_ret(expr)\n"); move(BN_REG, "rax");
retexpr: O_ID # 1 # printf("\t//retexpr\n"); if(bnode->param_index > -1) move(param_reg(bnode->param_index), BN_REG);
retexpr: expr
retexpr: O_ID # 1 # printf("\t//retexpr\n"); if(bnode->param_index > -1) move(param_reg(bnode->param_index), BN_REG);
retexpr: expr
@@
-219,6
+219,8
@@
expr: O_ID # 0 #
expr: imm # 1 # moveimm(BN_VAL, BN_REG);
expr: O_BOOL(expr) # 0 #
expr: imm # 1 # moveimm(BN_VAL, BN_REG);
expr: O_BOOL(expr) # 0 #
+expr: O_CALL # 0 # printf("\tcall %s\n", bnode->name);
+
expr: O_SUB(expr,expr) # 2 # gen_e_eno(bnode, "subq");
expr: O_SUB(expr,O_FIELD(expr)) # 2 # gen_e_field(bnode, "subq");
expr: O_SUB(expr,expr) # 2 # gen_e_eno(bnode, "subq");
expr: O_SUB(expr,O_FIELD(expr)) # 2 # gen_e_field(bnode, "subq");