From 805c1bd2427b3e97b97cbc0908e9ae9f3636f485 Mon Sep 17 00:00:00 2001 From: Bill Currie Date: Fri, 24 Aug 2001 23:22:02 +0000 Subject: [PATCH] foo (snafu, bar (baz)) no longer uses a temp for bar's return value --- tools/qfcc/source/expr.c | 22 ++++++++++++++-------- 1 file changed, 14 insertions(+), 8 deletions(-) diff --git a/tools/qfcc/source/expr.c b/tools/qfcc/source/expr.c index 816a4ce88..8b05ea87c 100644 --- a/tools/qfcc/source/expr.c +++ b/tools/qfcc/source/expr.c @@ -1046,6 +1046,8 @@ function_expr (expr_t *e1, expr_t *e2) int i; expr_t *args = 0, **a = &args; type_t *arg_types[MAX_PARMS]; + expr_t *arg_exprs[MAX_PARMS][2]; + int arg_expr_count = 0; expr_t *call; expr_t *err = 0; @@ -1121,19 +1123,23 @@ function_expr (expr_t *e1, expr_t *e2) for (e = e2, i = 0; e; e = e->next, i++) { if (has_function_call (e)) { *a = new_temp_def_expr (arg_types[i]); - if (e->next) { - if (i) // compensate for new_binary_expr and the first arg - inc_users(*a); - append_expr (call, binary_expr ('=', *a, e)); - } else { - e = new_binary_expr ('b', e, *a); - append_expr (call, e); - } + arg_exprs[arg_expr_count][0] = e; + arg_exprs[arg_expr_count][1] = *a; + arg_expr_count++; } else { *a = e; } a = &(*a)->next; } + for (i = 0; i < arg_expr_count - 1; i++) { + append_expr (call, binary_expr ('=', arg_exprs[i][1], + arg_exprs[i][0])); + } + if (arg_expr_count) { + e = new_binary_expr ('b', arg_exprs[arg_expr_count - 1][0], + arg_exprs[arg_expr_count - 1][1]); + append_expr (call, e); + } e = new_binary_expr ('c', e1, args); e->e.expr.type = ftype->aux_type; append_expr (call, e);