diff options
Diffstat (limited to 'gcc/fortran/trans-array.c')
| -rw-r--r-- | gcc/fortran/trans-array.c | 40 |
1 files changed, 25 insertions, 15 deletions
diff --git a/gcc/fortran/trans-array.c b/gcc/fortran/trans-array.c index 5ebec62..4bdc784 100644 --- a/gcc/fortran/trans-array.c +++ b/gcc/fortran/trans-array.c @@ -3973,23 +3973,32 @@ gfc_conv_expr_descriptor (gfc_se * se, gfc_expr * expr, gfc_ss * ss) loop.temp_ss->next = gfc_ss_terminator; if (expr->ts.type == BT_CHARACTER) { - gcc_assert (expr->ts.cl && expr->ts.cl->length - && expr->ts.cl->length->expr_type == EXPR_CONSTANT); - loop.temp_ss->string_length = gfc_conv_mpz_to_tree - (expr->ts.cl->length->value.integer, - expr->ts.cl->length->ts.kind); - expr->ts.cl->backend_decl = loop.temp_ss->string_length; - } - loop.temp_ss->data.temp.type = gfc_typenode_for_spec (&expr->ts); - - /* ... which can hold our string, if present. */ - if (expr->ts.type == BT_CHARACTER) - { - loop.temp_ss->string_length = TYPE_SIZE_UNIT (loop.temp_ss->data.temp.type); + if (expr->ts.cl + && expr->ts.cl->length + && expr->ts.cl->length->expr_type == EXPR_CONSTANT) + { + expr->ts.cl->backend_decl + = gfc_conv_mpz_to_tree (expr->ts.cl->length->value.integer, + expr->ts.cl->length->ts.kind); + loop.temp_ss->data.temp.type + = gfc_typenode_for_spec (&expr->ts); + loop.temp_ss->string_length + = TYPE_SIZE_UNIT (loop.temp_ss->data.temp.type); + } + else + { + loop.temp_ss->data.temp.type + = gfc_typenode_for_spec (&expr->ts); + loop.temp_ss->string_length = expr->ts.cl->backend_decl; + } se->string_length = loop.temp_ss->string_length; } else - loop.temp_ss->string_length = NULL; + { + loop.temp_ss->data.temp.type + = gfc_typenode_for_spec (&expr->ts); + loop.temp_ss->string_length = NULL; + } loop.temp_ss->data.temp.dimen = loop.dimen; gfc_add_ss_to_loop (&loop, loop.temp_ss); } @@ -4022,7 +4031,8 @@ gfc_conv_expr_descriptor (gfc_se * se, gfc_expr * expr, gfc_ss * ss) if (expr->ts.type == BT_CHARACTER) { gfc_conv_expr (&rse, expr); - rse.expr = build_fold_indirect_ref (rse.expr); + if (POINTER_TYPE_P (TREE_TYPE (rse.expr))) + rse.expr = build_fold_indirect_ref (rse.expr); } else gfc_conv_expr_val (&rse, expr); |
