summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/transpose_intrinsic_func_call_1.f90
diff options
context:
space:
mode:
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.f9026
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