OSDN Git Service

PR fortran/19478
authorfxcoudert <fxcoudert@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 11 May 2005 10:34:05 +0000 (10:34 +0000)
committerfxcoudert <fxcoudert@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 11 May 2005 10:34:05 +0000 (10:34 +0000)
* io/unix.c (fd_truncate): update positions when ftruncate
fails (like writing to /dev/null).
* gfortran.dg/dev_null.f90: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@99570 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/dev_null.f90 [new file with mode: 0644]
libgfortran/ChangeLog
libgfortran/io/unix.c

index d2ee0ca..33a1e02 100644 (file)
@@ -1,3 +1,7 @@
+2005-05-11  Bud Davis  <bdavis@gfortran.org>
+
+       * gfortran.dg/dev_null.f90: New test.
+
 2005-05-11  Richard Earnshaw  <richard.earnshaw@arm.com>
 
        * gcc.dg/arm-vfp1.c: Revert last change.
diff --git a/gcc/testsuite/gfortran.dg/dev_null.f90 b/gcc/testsuite/gfortran.dg/dev_null.f90
new file mode 100644 (file)
index 0000000..edf93db
--- /dev/null
@@ -0,0 +1,11 @@
+! { dg-do run }
+! pr19478 read from /dev/null
+! Thomas.Koenig@online.de
+      character*20 foo
+      open(10,file="/dev/null")
+      write(10,'(A)') "Hello"
+      rewind(10)
+      read(10,'(A)',end=100) foo
+      call abort
+ 100  continue
+      end
index fa866a1..eded92e 100644 (file)
@@ -1,3 +1,9 @@
+2005-05-11  Bud Davis  <bdavis@gfortran.org>
+
+       PR fortran/19478
+       * io/unix.c (fd_truncate): update positions when ftruncate
+       fails (like writing to /dev/null).
+
 2005-05-10  Francois-Xavier Coudert  <coudert@clipper.ens.fr>
 
        PR libfortran/21471
index 865eb68..92eea53 100644 (file)
@@ -515,13 +515,15 @@ fd_truncate (unix_stream * s)
 
 #ifdef HAVE_FTRUNCATE
   if (ftruncate (s->fd, s->logical_offset))
-    return FAILURE;
 #else
 #ifdef HAVE_CHSIZE
   if (chsize (s->fd, s->logical_offset))
-    return FAILURE;
 #endif
 #endif
+    {
+      s->physical_offset = s->file_length = 0;
+      return FAILURE;
+    }
 
   s->physical_offset = s->file_length = s->logical_offset;