aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJanus Weil <janus@gcc.gnu.org>2016-11-09 18:22:02 +0100
committerJanus Weil <janus@gcc.gnu.org>2016-11-09 18:22:02 +0100
commitb349a81aa03c74c0d39fb5ac847c308ab63be76e (patch)
tree32a1321fa05b9167e353ebb55bc85f5f3ffe838d /gcc
parent4f3535815e039b0593297e17ce03715b6afa93b1 (diff)
downloadgcc-b349a81aa03c74c0d39fb5ac847c308ab63be76e.zip
gcc-b349a81aa03c74c0d39fb5ac847c308ab63be76e.tar.gz
gcc-b349a81aa03c74c0d39fb5ac847c308ab63be76e.tar.bz2
[multiple changes]
2016-11-09 Steve Kargl <kargl@gcc.gnu.org> Janus Weil <janus@gcc.gnu.org> PR fortran/60777 * expr.c (external_spec_function): Allow recursive specification functions in F03. 2016-11-09 Janus Weil <janus@gcc.gnu.org> PR fortran/60777 * gfortran.dg/spec_expr_7.f90: New test. From-SVN: r242009
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog7
-rw-r--r--gcc/fortran/expr.c10
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gfortran.dg/spec_expr_7.f9034
4 files changed, 51 insertions, 5 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index bb0beb7..615ade0 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,10 @@
+2016-11-09 Steve Kargl <kargl@gcc.gnu.org>
+ Janus Weil <janus@gcc.gnu.org>
+
+ PR fortran/60777
+ * expr.c (external_spec_function): Allow recursive specification
+ functions in F03.
+
2016-11-09 Paul Thomas <pault@gcc.gnu.org>
* check.c (gfc_check_move_alloc): Prevent error that avoids
diff --git a/gcc/fortran/expr.c b/gcc/fortran/expr.c
index b2ffaae..e2d1311 100644
--- a/gcc/fortran/expr.c
+++ b/gcc/fortran/expr.c
@@ -2794,12 +2794,12 @@ external_spec_function (gfc_expr *e)
return false;
}
- if (f->attr.recursive)
- {
- gfc_error ("Specification function %qs at %L cannot be RECURSIVE",
- f->name, &e->where);
+ /* F08:7.1.11.6. */
+ if (f->attr.recursive
+ && !gfc_notify_std (GFC_STD_F2003,
+ "Specification function '%s' "
+ "at %L cannot be RECURSIVE", f->name, &e->where))
return false;
- }
function_allowed:
return restricted_args (e->value.function.actual);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 7a3b6c5..749c7d6 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2016-11-09 Janus Weil <janus@gcc.gnu.org>
+
+ PR fortran/60777
+ * gfortran.dg/spec_expr_7.f90: New test.
+
2016-11-09 Jakub Jelinek <jakub@redhat.com>
PR target/77718
diff --git a/gcc/testsuite/gfortran.dg/spec_expr_7.f90 b/gcc/testsuite/gfortran.dg/spec_expr_7.f90
new file mode 100644
index 0000000..0680d12
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/spec_expr_7.f90
@@ -0,0 +1,34 @@
+! { dg-do run }
+!
+! PR 60777: [F03] RECURSIVE function rejected in specification expression
+!
+! Contributed by Vladimir Fuka <vladimir.fuka@gmail.com>
+
+module recur
+ implicit none
+contains
+
+ pure recursive function f(n) result(answer)
+ integer, intent(in) :: n
+ integer :: answer
+ if (n<2) then
+ answer = 1
+ else
+ answer = f(n-1)*n
+ end if
+ end function
+
+ pure function usef(n)
+ integer,intent(in) :: n
+ character(f(n)) :: usef
+ usef = repeat('*',f(n))
+ end function
+end module
+
+program testspecexpr
+ use recur
+ implicit none
+ if (usef(1) /= '*') call abort()
+ if (usef(2) /= '**') call abort()
+ if (usef(3) /= '******') call abort()
+end