diff options
Diffstat (limited to 'gcc/testsuite/gfortran.dg/generic_10.f90')
-rw-r--r-- | gcc/testsuite/gfortran.dg/generic_10.f90 | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/generic_10.f90 b/gcc/testsuite/gfortran.dg/generic_10.f90 new file mode 100644 index 000000000..8f9ff6fcb --- /dev/null +++ b/gcc/testsuite/gfortran.dg/generic_10.f90 @@ -0,0 +1,36 @@ +! { dg-do compile } +! Test the patch for PR30081 in which non-generic intrinsic +! procedures could not be overloaded by generic interfaces. +! +! Contributed by Harald Anlauf <anlauf@gmx.de> +! +module gfcbug46 + interface random_seed + module procedure put_seed + end interface + interface random_number + module procedure random_vector + end interface + type t_t + real :: x(2) + end type t_t +contains + subroutine put_seed (n, seed) + integer, intent(inout) :: n + integer, intent(in) :: seed + call random_seed (size=n) + end subroutine put_seed + subroutine random_vector (t) + type(t_t) :: t + call random_number (t% x) + end subroutine random_vector +end module gfcbug46 + + use gfcbug46 + type(t_t) :: z + integer :: n = 2, seed = 1 + call put_seed (n, seed) + call random_number (z) + print *, z +end +! { dg-final { cleanup-modules "gfcbug46" } } |