summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/interface_19.f90
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/gfortran.dg/interface_19.f90')
-rw-r--r--gcc/testsuite/gfortran.dg/interface_19.f9032
1 files changed, 32 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/interface_19.f90 b/gcc/testsuite/gfortran.dg/interface_19.f90
new file mode 100644
index 000000000..7a88fc91b
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/interface_19.f90
@@ -0,0 +1,32 @@
+! { dg-do run }
+! PR33162 INTRINSIC functions as ACTUAL argument
+! Test case adapted from PR by Jerry DeLisle <jvdelisle@gcc.gnu.org>
+module m
+implicit none
+contains
+ subroutine sub(a)
+ optional :: a
+ character(25) :: temp
+ interface
+ function a(x)
+ real(kind=8):: a
+ real(kind=8):: x
+ intent(in) :: x
+ end function a
+ end interface
+ if(present(a)) then
+ write(temp,'(f16.10)')a(4.0d0)
+ if (trim(temp) /= ' -0.6536436209') call abort
+ endif
+ end subroutine sub
+end module m
+
+use m
+implicit none
+intrinsic dcos
+call sub()
+call sub(dcos)
+end
+
+! { dg-final { cleanup-modules "m" } }
+