From 09e7f68631c07f882a1294d4f00c5cf19498786e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tobias=20Schl=C3=BCter?= <tobias.schlueter@physik.uni-muenchen.de> Date: Wed, 11 May 2005 16:52:51 +0200 Subject: [PATCH] resolve.c (resolve_symbol): Copy 'pointer' and 'dimension' attribute from result symbol to function symbol. fortran/ * resolve.c (resolve_symbol): Copy 'pointer' and 'dimension' attribute from result symbol to function symbol. testsuite/ * gfortran.dg/func_result_2.f90: New test. From-SVN: r99580 --- gcc/fortran/ChangeLog | 5 +++++ gcc/fortran/resolve.c | 2 ++ gcc/fortran/trans-expr.c | 2 +- gcc/testsuite/ChangeLog | 4 ++++ gcc/testsuite/gfortran.dg/func_result_2.f90 | 10 ++++++++++ 5 files changed, 22 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/gfortran.dg/func_result_2.f90 diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index ee08d1fffb51..c5ae3929d48b 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,8 @@ +2005-05-11 Tobias Schl"uter <tobias.schlueter@physik.uni-muenchen.de> + + * resolve.c (resolve_symbol): Copy 'pointer' and 'dimension' + attribute from result symbol to function symbol. + 2005-05-10 Tobias Schl"uter <tobias.schlueter@physik.uni-muenchen.de> PR fortran/20178 diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c index 9b097fe9a15b..5f7a76a57a47 100644 --- a/gcc/fortran/resolve.c +++ b/gcc/fortran/resolve.c @@ -4061,6 +4061,8 @@ resolve_symbol (gfc_symbol * sym) sym->ts = sym->result->ts; sym->as = gfc_copy_array_spec (sym->result->as); + sym->attr.dimension = sym->result->attr.dimension; + sym->attr.pointer = sym->result->attr.pointer; } } } diff --git a/gcc/fortran/trans-expr.c b/gcc/fortran/trans-expr.c index 35c3f12883df..52a532d2408e 100644 --- a/gcc/fortran/trans-expr.c +++ b/gcc/fortran/trans-expr.c @@ -1288,7 +1288,7 @@ gfc_conv_function_call (gfc_se * se, gfc_symbol * sym, if (!se->direct_byref) { - if (sym->result->attr.dimension) + if (sym->attr.dimension) { if (flag_bounds_check) { diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 33a1e02c39b4..6e3cae14cc9e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2005-05-11 Tobias Schl"uter <tobias.schlueter@physik.uni-muenchen.de> + + * gfortran.dg/func_result_2.f90: New test. + 2005-05-11 Bud Davis <bdavis@gfortran.org> * gfortran.dg/dev_null.f90: New test. diff --git a/gcc/testsuite/gfortran.dg/func_result_2.f90 b/gcc/testsuite/gfortran.dg/func_result_2.f90 new file mode 100644 index 000000000000..2b457d9d44f6 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/func_result_2.f90 @@ -0,0 +1,10 @@ +! { dg-do run } +! Character functions with a result clause were broken +program testch + if (ch().ne."hello ") call abort() +contains + function ch result(str) + character(len = 10) :: str + str ="hello" + end function ch +end program testch -- GitLab