summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/implied_do_io_3.f90
blob: 2f90d57ffaa1e7e1b7cfee4a2f8443f0a7e0c3ed (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
! { dg-do run }
! { dg-options "-ffrontend-optimize" }
! PR 80988 - implied do loops with diagonal elements
! were not written correctly
program main
  implicit none
  integer :: i,j,k
  integer, dimension(3,3) :: a
  integer, dimension(3,3,3) :: b
  character(len=40) :: line
  a = reshape([(((i*10+j),i=1,3),j=1,3)], shape(a))
  i = 2147483548
  write (unit=line,fmt='(10I3)') (a(i,i),i=1,3)
  if (line /= ' 11 22 33') STOP 1
  write (unit=line,fmt='(10I3)') (a(i+1,i+1),i=1,2)
  if (line /= ' 22 33') STOP 2
  do k=1,3
     do j=1,3
        do i=1,3
           b(i,j,k) = i*100 + j*10 + k
        end do
     end do
  end do
  i = -2147483548
  write (unit=line,fmt='(10I4)') ((b(i,j,i),i=1,3),j=1,3)
  if (line /= ' 111 212 313 121 222 323 131 232 333') STOP 3
end program main