(root)/
gcc-13.2.0/
gcc/
testsuite/
gfortran.dg/
fmt_f0_1.f90
! { dg-do run }
! PR39304 write of  0.0 with F0.3 gives  **
! PR47567 Small absolute values.
! Test case developed from case provided by reporter.
 REAL :: x
 CHARACTER(80) :: str
 x = 0.0
 write (str,'(f0.0)') x
 if (str.ne."0.") STOP 1
 write (str,'(f0.1)') x
 if (str.ne.".0") STOP 2
 write (str,'(f0.2)') x
 if (str.ne.".00") STOP 3
 write (str,'(f0.3)') x
 if (str.ne.".000") STOP 4
 write (str,'(f0.4)') x
 if (str.ne.".0000") STOP 5
 write (str,'(F0.0)') 0.0
 if (str.ne."0.") STOP 6
 write (str,'(F0.0)') 0.001
 if (str.ne."0.") STOP 7
 write (str,'(F0.0)') 0.01
 if (str.ne."0.") STOP 8
 write (str,'(F0.0)') 0.1
 if (str.ne."0.") STOP 9
 write (str,'(F1.0)') -0.0
 if (str.ne."*") STOP 10
 write (str,'(F1.0)') 0.001
 if (str.ne."*") STOP 11
 write (str,'(F1.0)') 0.01
 if (str.ne."*") STOP 12
 write (str,'(F1.0)') 0.1
 if (str.ne."*") STOP 13
 write (str,'(F2.0)') -0.001
 if (str.ne."**") STOP 14
 write (str,'(F2.0)') -0.01
 if (str.ne."**") STOP 15
 write (str,'(F2.0)') -0.1
 if (str.ne."**") STOP 16
 write (str,'(F0.2)') 0.0
 if (str.ne.".00") STOP 17
 write (str,'(F0.0)') -0.0
 if (str.ne."-0.") STOP 18
 write (str,'(F0.1)') -0.0
 if (str.ne."-.0") STOP 19
 write (str,'(F0.2)') -0.0
 if (str.ne."-.00") STOP 20
 write (str,'(F0.3)') -0.0
 if (str.ne."-.000") STOP 21
 write (str,'(F3.0)') -0.0
 if (str.ne."-0.") STOP 22
 write (str,'(F2.0)') -0.0
 if (str.ne."**") STOP 23
 write (str,'(F1.0)') -0.0
 if (str.ne."*") STOP 24
 write (str,'(F0.1)') -0.0
 if (str.ne."-.0") STOP 25
 write (str,'(F3.1)') -0.0
 if (str.ne."-.0") STOP 26
 write (str,'(F2.1)') -0.0
 if (str.ne."**") STOP 27
 write (str,'(F1.1)') -0.0
 if (str.ne."*") STOP 28
 END