summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/minval_char_2.f90
blob: b61fb6c433259942863414d9f636ed35c73d2beb (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
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
! { 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