diff options
Diffstat (limited to 'gcc/testsuite/gfortran.dg/allocatable_function_3.f90')
-rw-r--r-- | gcc/testsuite/gfortran.dg/allocatable_function_3.f90 | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/allocatable_function_3.f90 b/gcc/testsuite/gfortran.dg/allocatable_function_3.f90 new file mode 100644 index 000000000..538924f67 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/allocatable_function_3.f90 @@ -0,0 +1,24 @@ +! { dg-do run } +! Tests the fix for PR33986, in which the call to scram would call +! an ICE because allocatable result actuals had not been catered for. +! +! Contributed by Damian Rouson <damian@rouson.net> +! +function transform_to_spectral_from() result(spectral) + integer, allocatable :: spectral(:) + allocate(spectral(2)) + call scram(spectral) +end function transform_to_spectral_from + +subroutine scram (x) + integer x(2) + x = (/1,2/) +end subroutine + + interface + function transform_to_spectral_from() result(spectral) + integer, allocatable :: spectral(:) + end function transform_to_spectral_from + end interface + if (any (transform_to_spectral_from () .ne. (/1,2/))) call abort () +end |