aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/interface.c
diff options
context:
space:
mode:
authorSteven G. Kargl <kargl@gcc.gnu.org>2018-02-23 18:57:41 +0000
committerSteven G. Kargl <kargl@gcc.gnu.org>2018-02-23 18:57:41 +0000
commit3453b6aa30c11a7c86cc91197f7ee97bc49cb273 (patch)
treef8e230476c8c74a7386dac604624b9f30d235704 /gcc/fortran/interface.c
parent55ebc31f3d521e66059e6f83b9884a0ae8d941ab (diff)
downloadgcc-3453b6aa30c11a7c86cc91197f7ee97bc49cb273.zip
gcc-3453b6aa30c11a7c86cc91197f7ee97bc49cb273.tar.gz
gcc-3453b6aa30c11a7c86cc91197f7ee97bc49cb273.tar.bz2
re PR fortran/84346 (Statement functions should not accept keywords)
2018-02-23 Steven G. Kargl <kargl@gcc.gnu.org> PR fortran/84346 * interface.c (compare_actual_formal): Issue error if keyword is used in a statement function. 2018-02-23 Steven G. Kargl <kargl@gcc.gnu.org> PR fortran/84346 * gfortran.dg/statement_function_1.f90: Update test. From-SVN: r257942
Diffstat (limited to 'gcc/fortran/interface.c')
-rw-r--r--gcc/fortran/interface.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/gcc/fortran/interface.c b/gcc/fortran/interface.c
index ad02928..cb326e5 100644
--- a/gcc/fortran/interface.c
+++ b/gcc/fortran/interface.c
@@ -2865,6 +2865,13 @@ compare_actual_formal (gfc_actual_arglist **ap, gfc_formal_arglist *formal,
for (a = actual; a; a = a->next, f = f->next)
{
+ if (a->name != NULL && in_statement_function)
+ {
+ gfc_error ("Keyword argument %qs at %L is invalid in "
+ "a statement function", a->name, &a->expr->where);
+ return false;
+ }
+
/* Look for keywords but ignore g77 extensions like %VAL. */
if (a->name != NULL && a->name[0] != '%')
{