aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorFrancois-Xavier Coudert <coudert@clipper.ens.fr>2005-04-28 13:56:08 +0200
committerFrançois-Xavier Coudert <fxcoudert@gcc.gnu.org>2005-04-28 11:56:08 +0000
commit781e1004f3eee23f946442b7829118a11212898c (patch)
treee7684f2fb95cd69baabcd6c4b5b7cddcd6583935 /gcc
parentedcd599b95b7d309f88bcd8de62c5e7bb50d861e (diff)
downloadgcc-781e1004f3eee23f946442b7829118a11212898c.zip
gcc-781e1004f3eee23f946442b7829118a11212898c.tar.gz
gcc-781e1004f3eee23f946442b7829118a11212898c.tar.bz2
re PR fortran/20865 (statement function shall not be supplied as procedure argument)
PR fortran/20865 * resolve.c (resolve_actual_arglist): Issue an error if a statement functions is used as actual argument. * gfortran.dg/pr20865.f90: New test. From-SVN: r98919
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog6
-rw-r--r--gcc/fortran/resolve.c6
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gfortran.dg/pr20865.f9010
4 files changed, 27 insertions, 0 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 822dcd0..d8cd706 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,9 @@
+2005-04-28 Francois-Xavier Coudert <coudert@clipper.ens.fr>
+
+ PR fortran/20865
+ * resolve.c (resolve_actual_arglist): Issue an error if a statement
+ functions is used as actual argument.
+
2005-04-27 Francois-Xavier Coudert <coudert@clipper.ens.fr>
PR fortran/21177
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c
index d75704b..a4667b7 100644
--- a/gcc/fortran/resolve.c
+++ b/gcc/fortran/resolve.c
@@ -604,6 +604,12 @@ resolve_actual_arglist (gfc_actual_arglist * arg)
|| sym->attr.external)
{
+ if (sym->attr.proc == PROC_ST_FUNCTION)
+ {
+ gfc_error ("Statement function '%s' at %L is not allowed as an "
+ "actual argument", sym->name, &e->where);
+ }
+
/* If the symbol is the function that names the current (or
parent) scope, then we really have a variable reference. */
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 1f7bc01..0d418527 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2005-04-28 Francois-Xavier Coudert <coudert@clipper.ens.fr>
+
+ PR fortran/20865
+ * gfortran.dg/pr20865.f90: New test.
+
2005-04-28 Joseph S. Myers <joseph@codesourcery.com>
* gcc.dg/void-cast-2.c: New test.
diff --git a/gcc/testsuite/gfortran.dg/pr20865.f90 b/gcc/testsuite/gfortran.dg/pr20865.f90
new file mode 100644
index 0000000..96d0d79
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/pr20865.f90
@@ -0,0 +1,10 @@
+! { dg-do compile }
+! PR fortran/20865
+ subroutine tt(j)
+ integer :: j
+ end subroutine
+
+ integer :: i, st
+ st(i) = (i*i+2)
+ call tt(st) ! { dg-error "Statement function .* is not allowed as an actual argument" }
+ end