1! { dg-do run }
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
7      str = '(1pd24.15e6)'
8      line = "initial string"
9      x = 555.25
10
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
14
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
18
19      str = '(1pd0.15)'
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
25
26      write (line,'(1pd24.15e11.3)') 1.0d0, 1.234
27      if (line.ne."   1.000000000000000D+00  1.234E+00") call abort
28
29      end
30