summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/list_read_5.f90
blob: 14b0d1648a4da07628ae1e49c5a4ab6ff4317cea (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
! { dg-do run }
! PR25307 Check handling of end-of-file conditions for list directed reads.
! Prepared by Jerry DeLisle  <jvdelisle@gcc.gnu.org>
program pr25307
   character(len=10) :: str
   character(len=10) :: a(5)
   a=""
   a(1)="123"
   a(3)="234"
   str = '123'
! Check internal unit
   i = 0
   j = 0
   read( str, *, end=10 ) i,j
   call abort()
10 continue
   if (i.ne.123) call abort()
   if (j.ne.0) call abort()
! Check file unit
   i = 0
   open(10, status="scratch")
   write(10,'(a)') "123"
   rewind(10)
   read(10, *, end=20) i,j
   call abort()
20 continue
   if (i.ne.123) call abort()
   if (j.ne.0) call abort()
! Check internal array unit
   i = 0
   j = 0
   k = 0
   read(a(1:5:2),*, end=30)i,j,k
   call abort()
30 continue
   if (i.ne.123) call abort()
   if (j.ne.234) call abort()
   if (k.ne.0) call abort()
end program pr25307