re PR libfortran/35862 ([F2003] Implement new rounding modes for run time)
authorJerry DeLisle <jvdelisle@gcc.gnu.org>
Tue, 29 Sep 2009 02:50:48 +0000 (02:50 +0000)
committerJerry DeLisle <jvdelisle@gcc.gnu.org>
Tue, 29 Sep 2009 02:50:48 +0000 (02:50 +0000)
2009-09-28  Jerry DeLisle  <jvdelisle@gcc.gnu.org>

PR libgfortran/35862
* gfortran.dg/round_1.f03: New test.
* gfortran.dg/f2003_io_3.f03: Update test.

From-SVN: r152264

gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/f2003_io_3.f03
gcc/testsuite/gfortran.dg/round_1.f03 [new file with mode: 0644]

index c5f4438fd50585144c5151953c198e93000051c6..5a9245ea3815ebf3bdf1f5dc2eebfabaf5c8b51e 100644 (file)
@@ -1,3 +1,9 @@
+2009-09-28  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
+
+       PR libgfortran/35862
+       * gfortran.dg/round_1.f03: New test.
+       * gfortran.dg/f2003_io_3.f03: Update test.
+
 2009-09-28  Easwaran Raman  <eraman@google.com>
 
        * gcc.target/i386/ifcvt-onecmpl-abs-1.c: New file.
index 5b3fb59b0d7622a9053d0a9ec421896d76b700cd..37c07e3f190b1fde26f933a6c9b72e2cc4c2651c 100644 (file)
@@ -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 (file)
index 0000000..db5d6ec
--- /dev/null
@@ -0,0 +1,28 @@
+! { dg-do run }
+! PR35962 Implement F2003 rounding modes.
+! Test case prepared by Jerry DeLisle  <jvdelisle@gcc.gnu.org>
+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