diff options
author | Tobias Schlüter <tobias.schlueter@physik.uni-muenchen.de> | 2005-05-11 16:52:51 +0200 |
---|---|---|
committer | Tobias Schlüter <tobi@gcc.gnu.org> | 2005-05-11 16:52:51 +0200 |
commit | 09e7f68631c07f882a1294d4f00c5cf19498786e (patch) | |
tree | 93b690b02e38975caed6d3a50fc5044c5bb9879b /gcc/fortran | |
parent | 9d48ad93c63357e68bdc7ac9fdf23d470eee6ee2 (diff) | |
download | gcc-09e7f68631c07f882a1294d4f00c5cf19498786e.zip gcc-09e7f68631c07f882a1294d4f00c5cf19498786e.tar.gz gcc-09e7f68631c07f882a1294d4f00c5cf19498786e.tar.bz2 |
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
Diffstat (limited to 'gcc/fortran')
-rw-r--r-- | gcc/fortran/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/fortran/resolve.c | 2 | ||||
-rw-r--r-- | gcc/fortran/trans-expr.c | 2 |
3 files changed, 8 insertions, 1 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index ee08d1f..c5ae392 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 9b097fe..5f7a76a 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 35c3f12..52a532d 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) { |