2 ! { dg
-options
"-std=legacy" }
3 ! PR38439 I
/O PD edit descriptor inconsistency
4 ! Test case prepared by Jerry DeLisle
<jvdelisle@gcc
.gnu
.org
>
5 character(len
=25) :: str
6 character(len
=132) :: msg
, line
8 line
= "initial string"
11 write (line
,str
,iostat
=istat
, iomsg
=msg
) 1.0d0
, 1.234
12 if (istat
.ne
.0) call abort
13 if (line
.ne
." 1.000000000000000D+001.E+00") call abort
15 write (line
,'(1pd24.15e6)',iostat
=istat
, iomsg
=msg
) 1.0d0
, 1.234 ! { dg
-warning
"Period required" }
16 if (istat
.ne
.0) call abort
17 if (line
.ne
." 1.000000000000000D+001.E+00") call abort
20 write (line
,str
,iostat
=istat
, iomsg
=msg
) 1.0d0
21 if (istat
.ne
.5006 .or
. msg
(1:15).ne
."Positive width ") call abort
22 read (*,str
,iostat
=istat
, iomsg
=msg
) x
23 if (istat
.ne
.5006 .or
. msg
(1:15).ne
."Positive width ") call abort
24 if (x
.ne
.555.25) call abort
26 write (line
,'(1pd24.15e11.3)') 1.0d0
, 1.234
27 if (line
.ne
." 1.000000000000000D+00 1.234E+00") call abort