diff options
Diffstat (limited to 'gcc/fortran/trans-decl.c')
-rw-r--r-- | gcc/fortran/trans-decl.c | 84 |
1 files changed, 15 insertions, 69 deletions
diff --git a/gcc/fortran/trans-decl.c b/gcc/fortran/trans-decl.c index 3a38973..84e7226 100644 --- a/gcc/fortran/trans-decl.c +++ b/gcc/fortran/trans-decl.c @@ -2893,80 +2893,26 @@ gfc_generate_contained_functions (gfc_namespace * parent) static void generate_local_decl (gfc_symbol *); -static void -generate_expr_decls (gfc_symbol *sym, gfc_expr *e) -{ - gfc_actual_arglist *arg; - gfc_ref *ref; - int i; - - if (e == NULL) - return; - - switch (e->expr_type) - { - case EXPR_FUNCTION: - for (arg = e->value.function.actual; arg; arg = arg->next) - generate_expr_decls (sym, arg->expr); - break; +/* Traverse expr, marking all EXPR_VARIABLE symbols referenced. */ - /* If the variable is not the same as the dependent, 'sym', and - it is not marked as being declared and it is in the same - namespace as 'sym', add it to the local declarations. */ - case EXPR_VARIABLE: - if (sym == e->symtree->n.sym +static bool +expr_decls (gfc_expr *e, gfc_symbol *sym, + int *f ATTRIBUTE_UNUSED) +{ + if (e->expr_type != EXPR_VARIABLE + || sym == e->symtree->n.sym || e->symtree->n.sym->mark || e->symtree->n.sym->ns != sym->ns) - return; - - generate_local_decl (e->symtree->n.sym); - break; - - case EXPR_OP: - generate_expr_decls (sym, e->value.op.op1); - generate_expr_decls (sym, e->value.op.op2); - break; - - default: - break; - } - - if (e->ref) - { - for (ref = e->ref; ref; ref = ref->next) - { - switch (ref->type) - { - case REF_ARRAY: - for (i = 0; i < ref->u.ar.dimen; i++) - { - generate_expr_decls (sym, ref->u.ar.start[i]); - generate_expr_decls (sym, ref->u.ar.end[i]); - generate_expr_decls (sym, ref->u.ar.stride[i]); - } - break; + return false; - case REF_SUBSTRING: - generate_expr_decls (sym, ref->u.ss.start); - generate_expr_decls (sym, ref->u.ss.end); - break; + generate_local_decl (e->symtree->n.sym); + return false; +} - case REF_COMPONENT: - if (ref->u.c.component->ts.type == BT_CHARACTER - && ref->u.c.component->ts.cl->length->expr_type - != EXPR_CONSTANT) - generate_expr_decls (sym, ref->u.c.component->ts.cl->length); - - if (ref->u.c.component->as) - for (i = 0; i < ref->u.c.component->as->rank; i++) - { - generate_expr_decls (sym, ref->u.c.component->as->lower[i]); - generate_expr_decls (sym, ref->u.c.component->as->upper[i]); - } - break; - } - } - } +static void +generate_expr_decls (gfc_symbol *sym, gfc_expr *e) +{ + gfc_traverse_expr (e, sym, expr_decls, 0); } |