| ! { 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 |