diff options
author | Paul Thomas <pault@gcc.gnu.org> | 2011-01-31 19:13:13 +0000 |
---|---|---|
committer | Paul Thomas <pault@gcc.gnu.org> | 2011-01-31 19:13:13 +0000 |
commit | fabb6f8ea12176a06d181f26a6f3b824955b57e9 (patch) | |
tree | 05fa8bedfa01cd41411713a530eb7ef6c57e85ae /gcc/fortran/iresolve.c | |
parent | b6c77bcb57974ccbb49f5651f9ba0e443b864d1d (diff) | |
download | gcc-fabb6f8ea12176a06d181f26a6f3b824955b57e9.zip gcc-fabb6f8ea12176a06d181f26a6f3b824955b57e9.tar.gz gcc-fabb6f8ea12176a06d181f26a6f3b824955b57e9.tar.bz2 |
re PR fortran/47519 (Deferred-length string wrong results with character intrinsic functions)
2011-01-31 Paul Thomas <pault@gcc.gnu.org>
PR fortran/47519
* trans-stmt.c (gfc_trans_allocate): Improve handling of
deferred character lengths with SOURCE.
* iresolve.c (gfc_resolve_repeat): Calculate character
length from source length and ncopies.
* dump-parse-tree.c (show_code_node): Show MOLD and SOURCE
expressions for ALLOCATE.
2011-01-31 Paul Thomas <pault@gcc.gnu.org>
PR fortran/47519
* gfortran.dg/allocate_deferred_char_scalar_2.f03: New test.
From-SVN: r169444
Diffstat (limited to 'gcc/fortran/iresolve.c')
-rw-r--r-- | gcc/fortran/iresolve.c | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/gcc/fortran/iresolve.c b/gcc/fortran/iresolve.c index ec9dd42..d8309d2 100644 --- a/gcc/fortran/iresolve.c +++ b/gcc/fortran/iresolve.c @@ -35,6 +35,7 @@ along with GCC; see the file COPYING3. If not see #include "gfortran.h" #include "intrinsic.h" #include "constructor.h" +#include "arith.h" /* Given printf-like arguments, return a stable version of the result string. @@ -2044,11 +2045,31 @@ gfc_resolve_rename (gfc_expr *f, gfc_expr *p1 ATTRIBUTE_UNUSED, void gfc_resolve_repeat (gfc_expr *f, gfc_expr *string, - gfc_expr *ncopies ATTRIBUTE_UNUSED) + gfc_expr *ncopies) { + int len; + gfc_expr *tmp; f->ts.type = BT_CHARACTER; f->ts.kind = string->ts.kind; f->value.function.name = gfc_get_string ("__repeat_%d", string->ts.kind); + + /* If possible, generate a character length. */ + if (f->ts.u.cl == NULL) + f->ts.u.cl = gfc_new_charlen (gfc_current_ns, NULL); + + tmp = NULL; + if (string->expr_type == EXPR_CONSTANT) + { + len = string->value.character.length; + tmp = gfc_get_int_expr (gfc_default_integer_kind, NULL , len); + } + else if (string->ts.u.cl && string->ts.u.cl->length) + { + tmp = gfc_copy_expr (string->ts.u.cl->length); + } + + if (tmp) + f->ts.u.cl->length = gfc_multiply (tmp, gfc_copy_expr (ncopies)); } |