blob: b61fb6c433259942863414d9f636ed35c73d2beb [file] [log] [blame]
 ! { dg-do run } program main implicit none integer, parameter :: n=5, m=3 character(kind=4,len=5), dimension(n) :: a character(kind=4,len=5), dimension(n,m) :: b character(kind=4,len=5) :: res integer, dimension(n,m) :: v real, dimension(n,m) :: r integer :: i,j logical, dimension(n,m) :: mask character(kind=4,len=5), dimension(:,:), allocatable :: empty integer(kind=4), dimension(5) :: kmin = [-1, -1, -1, -1, -1] character(kind=4,len=5) :: all_full logical :: smask all_full = transfer(kmin,all_full) write (unit=a,fmt='(I5.5)') (21-i*i+6*i,i=1,n) res = minval(a) if (res /= 4_'00026') STOP 1 do call random_number(r) v = int(r * 100) if (count(v<30) > 1) exit end do write (unit=b,fmt='(I5.5)') v write (unit=res,fmt='(I5.5)') minval(v) if (res /= minval(b)) STOP 2 smask = .true. if (res /= minval(b, smask)) STOP 3 smask = .false. if (all_full /= minval(b, smask)) STOP 4 mask = v < 30 write (unit=res,fmt='(I5.5)') minval(v,mask) if (res /= minval(b, mask)) STOP 5 mask = .false. if (minval(b, mask) /= all_full) STOP 6 allocate (empty(0:3,0)) res = minval(empty) if (res /= all_full) STOP 7 end program main