summaryrefslogtreecommitdiff
path: root/gcc/fortran/trans-expr.c
diff options
context:
space:
mode:
authorTobias Schlüter <tobias.schlueter@physik.uni-muenchen.de>2004-08-26 00:07:32 +0200
committerTobias Schlüter <tobi@gcc.gnu.org>2004-08-26 00:07:32 +0200
commit6d1c50cce40910b7015fefa7ce6c632c750bda22 (patch)
tree964405ed0e0f03edc6848c42f8c9cc13a1404f4e /gcc/fortran/trans-expr.c
parent4c124b4c6f4e9017f5682cede57bd84c1129da2a (diff)
downloadgcc-6d1c50cce40910b7015fefa7ce6c632c750bda22.tar.gz
expr.c (gfc_check_assign): Add comment.
fortran/ * expr.c (gfc_check_assign): Add comment. Add new warning. * trans-expr.c (gfc_conv_function_call): Correctly dereference result of pointer valued function when not in pointer assignment. testsuite/ * gfortran.dg/assignment_1.f90: New test. From-SVN: r86585
Diffstat (limited to 'gcc/fortran/trans-expr.c')
-rw-r--r--gcc/fortran/trans-expr.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/gcc/fortran/trans-expr.c b/gcc/fortran/trans-expr.c
index cbf2dd1fb67..b39aed9b50a 100644
--- a/gcc/fortran/trans-expr.c
+++ b/gcc/fortran/trans-expr.c
@@ -1170,6 +1170,13 @@ gfc_conv_function_call (gfc_se * se, gfc_symbol * sym,
se->expr = build3 (CALL_EXPR, TREE_TYPE (fntype), se->expr,
arglist, NULL_TREE);
+ /* If we have a pointer function, but we don't want a pointer, e.g.
+ something like
+ x = f()
+ where f is pointer valued, we have to dereference the result. */
+ if (sym->attr.pointer && !se->want_pointer && !byref)
+ se->expr = gfc_build_indirect_ref (se->expr);
+
/* A pure function may still have side-effects - it may modify its
parameters. */
TREE_SIDE_EFFECTS (se->expr) = 1;