aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/trans-array.c
diff options
context:
space:
mode:
authorTobias Burnus <tobias@codesourcery.com>2019-10-30 20:01:36 +0000
committerTobias Burnus <burnus@gcc.gnu.org>2019-10-30 21:01:36 +0100
commit6b7a9826d737254eb70ab5a600ce5f334a7f922b (patch)
treef36fd636c12258dbdebe9b7c154303f2dbaaf6ad /gcc/fortran/trans-array.c
parentc766762429d045b575853539e019746fde6ef076 (diff)
downloadgcc-6b7a9826d737254eb70ab5a600ce5f334a7f922b.zip
gcc-6b7a9826d737254eb70ab5a600ce5f334a7f922b.tar.gz
gcc-6b7a9826d737254eb70ab5a600ce5f334a7f922b.tar.bz2
Fortran] PR 92208 don't use function-result dummy variable as actual argument
PR fortran/92208 * trans-array.c (gfc_conv_array_parameter): Only copy string-length backend_decl if expression is not a function. PR fortran/92208 * gfortran.dg/pr92208.f90: New. From-SVN: r277639
Diffstat (limited to 'gcc/fortran/trans-array.c')
-rw-r--r--gcc/fortran/trans-array.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/gcc/fortran/trans-array.c b/gcc/fortran/trans-array.c
index 437892a..2d85bf7 100644
--- a/gcc/fortran/trans-array.c
+++ b/gcc/fortran/trans-array.c
@@ -8049,7 +8049,7 @@ gfc_conv_array_parameter (gfc_se * se, gfc_expr * expr, bool g77,
/* The components shall be deallocated before their containing entity. */
gfc_prepend_expr_to_block (&se->post, tmp);
}
- if (expr->ts.type == BT_CHARACTER)
+ if (expr->ts.type == BT_CHARACTER && expr->expr_type != EXPR_FUNCTION)
se->string_length = expr->ts.u.cl->backend_decl;
if (size)
array_parameter_size (se->expr, expr, size);