From cd0a387eb20d8d4505cd3f66a3b9d01f641bb42e Mon Sep 17 00:00:00 2001 From: jvdelisle Date: Tue, 29 Sep 2009 02:50:48 +0000 Subject: [PATCH] 2009-09-28 Jerry DeLisle PR libgfortran/35862 * gfortran.dg/round_1.f03: New test. * gfortran.dg/f2003_io_3.f03: Update test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@152264 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/testsuite/ChangeLog | 6 ++++++ gcc/testsuite/gfortran.dg/f2003_io_3.f03 | 2 +- gcc/testsuite/gfortran.dg/round_1.f03 | 28 ++++++++++++++++++++++++++++ 3 files changed, 35 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/gfortran.dg/round_1.f03 diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index c5f4438fd50..5a9245ea381 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2009-09-28 Jerry DeLisle + + PR libgfortran/35862 + * gfortran.dg/round_1.f03: New test. + * gfortran.dg/f2003_io_3.f03: Update test. + 2009-09-28 Easwaran Raman * gcc.target/i386/ifcvt-onecmpl-abs-1.c: New file. diff --git a/gcc/testsuite/gfortran.dg/f2003_io_3.f03 b/gcc/testsuite/gfortran.dg/f2003_io_3.f03 index 5b3fb59b0d7..37c07e3f190 100644 --- a/gcc/testsuite/gfortran.dg/f2003_io_3.f03 +++ b/gcc/testsuite/gfortran.dg/f2003_io_3.f03 @@ -11,7 +11,7 @@ a = 43.21 WRITE(99,'(10f8.3)',decimal="comma") a rewind(99) read(99,'(dc,10f8.3)',blank=msg) b -write(99,'(dp,10f8.3)',round="up") ! { dg-error "not implemented" } +write(99,'(dp,10f8.3)',round="up") rewind(99) read(99,'(10f8.3)',pad="yes") msg="suppress" diff --git a/gcc/testsuite/gfortran.dg/round_1.f03 b/gcc/testsuite/gfortran.dg/round_1.f03 new file mode 100644 index 00000000000..db5d6ec9269 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/round_1.f03 @@ -0,0 +1,28 @@ +! { dg-do run } +! PR35962 Implement F2003 rounding modes. +! Test case prepared by Jerry DeLisle +character(11) :: fmt(7) +character(80) :: line +integer :: i +fmt = (/'(RU,6F10.1)', '(RD,6F10.1)', '(RZ,6F10.1)', & + '(RN,6F10.2)', '(RC,6F10.2)', '(RP,6F10.1)', & + '(SP,6F10.1)' /) +do i = 1, 7 + !print fmt(i), 1.20, 1.22, 1.25, 1.27, 1.30, 1.125 +end do +write(line, fmt(1)) 1.20, 1.22, 1.25, 1.27, 1.30, 1.125 +if (line.ne." 1.3 1.3 1.3 1.3 1.3 1.2") call abort +write(line, fmt(2)) 1.20, 1.22, 1.25, 1.27, 1.30, 1.125 +if (line.ne." 1.2 1.2 1.2 1.2 1.2 1.1") call abort +write(line, fmt(3)) 1.20, 1.22, 1.25, 1.27, 1.30, 1.125 +if (line.ne." 1.2 1.2 1.2 1.2 1.2 1.1") call abort +write(line, fmt(4)) 1.20, 1.22, 1.25, 1.27, 1.30, 1.125 +if (line.ne." 1.20 1.22 1.25 1.27 1.30 1.12") call abort +write(line, fmt(5)) 1.20, 1.22, 1.25, 1.27, 1.30, 1.125 +if (line.ne." 1.20 1.22 1.25 1.27 1.30 1.13") call abort +write(line, fmt(6)) 1.20, 1.22, 1.25, 1.27, 1.30, 1.125 +if (line.ne." 1.2 1.2 1.3 1.3 1.3 1.1") call abort +write(line, fmt(7)) 1.20, 1.22, 1.25, 1.27, 1.30, 1.125 +if (line.ne." +1.2 +1.2 +1.3 +1.3 +1.3 +1.1") call abort + +end -- 2.11.0