diff options
Diffstat (limited to 'gcc/testsuite/gfortran.dg/transpose_intrinsic_func_call_1.f90')
-rw-r--r-- | gcc/testsuite/gfortran.dg/transpose_intrinsic_func_call_1.f90 | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/transpose_intrinsic_func_call_1.f90 b/gcc/testsuite/gfortran.dg/transpose_intrinsic_func_call_1.f90 new file mode 100644 index 000000000..53d727d9b --- /dev/null +++ b/gcc/testsuite/gfortran.dg/transpose_intrinsic_func_call_1.f90 @@ -0,0 +1,26 @@ +! { dg-do run } +! +! PR fortran/46978 +! The coor assignment was using the wrong loop bounds if the argument to +! transpose was an intrinsic function call +! +! Original testcase by Martien Huelsen <m.a.hulsen@tue.nl> +! Reduced by Tobias Burnus <burnus@net-b.de> + +program elastic2 + implicit none + real, allocatable, dimension(:,:) :: coor + real, allocatable, dimension(:) :: a + integer :: nno + nno = 3 + allocate(a(2*nno)) + call two() + coor = transpose ( reshape ( a, (/2,nno/) ) ) + if (any(coor /= 12)) call abort +contains + subroutine two() + allocate(coor(3,2)) + coor = 99 + a = 12 + end subroutine +end program elastic2 |