rewind.c (st_rewind): Reset unit to read mode.
authorPaul Brook <paul@codesourcery.com>
Fri, 27 Aug 2004 13:44:52 +0000 (13:44 +0000)
committerPaul Brook <pbrook@gcc.gnu.org>
Fri, 27 Aug 2004 13:44:52 +0000 (13:44 +0000)
* io/rewind.c (st_rewind): Reset unit to read mode.
testsuite/
* gfortran.dg/rewind_1.f90: New test.

From-SVN: r86659

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

index 18f803758a67f3be07661a2aaffd686866d4c416..20b62678e285aa839c68fd5a33ddfd6ac7123e31 100644 (file)
@@ -1,3 +1,7 @@
+2004-08-27  Paul Brook  <paul@codesourcery.com>
+
+       * gfortran.dg/rewind_1.f90: New test.
+
 2004-08-27  Bud Davis  <bdavis9659@comcast.net>
 
        PR fortran/16597
diff --git a/gcc/testsuite/gfortran.dg/rewind_1.f90 b/gcc/testsuite/gfortran.dg/rewind_1.f90
new file mode 100644 (file)
index 0000000..cbd2ef1
--- /dev/null
@@ -0,0 +1,18 @@
+! { dg-do run }
+! Check that rewind doesn't delete a file.
+! Writing to the file truncates it at the end of the current record.  Out
+! IO library was defering the actual truncation until the file was rewound.
+! A second rewind would then (incorrectly) think the file had just been
+! written to, and truncate the file to zero length.
+program foo
+  character*11 s
+  open(unit=11, status="SCRATCH")
+  write(11, '(a11)') "Hello World"
+  rewind(11)
+  rewind(11)
+  s = ""
+  read(11, '(a11)') s
+  close(11)
+  if (s .ne. "Hello World") call abort
+end program
+
index e0039ec0ac98f4b17574cb0ee4511115b8ef7f9b..7f1bff2fef1bae7f0ae5e389bf884a901222d8d1 100644 (file)
@@ -1,3 +1,7 @@
+2004-08-27  Paul Brook  <paul@codesourcery.com>
+
+       * io/rewind.c (st_rewind): Reset unit to read mode.
+
 2004-08-27  Bud Davis  <bdavis9659@comcast.net>
 
        PR fortran/16597
index d9758a6d5ec8c6b4921ee0b77c0c3d3ab646d215..7be2328037cf72534e3997e9f6109692b35288af 100644 (file)
@@ -40,8 +40,13 @@ st_rewind (void)
                        "Cannot REWIND a file opened for DIRECT access");
       else
        {
+         /* If we have been writing to the file, the last written record
+            is the last record in the file, so trincate the file now.
+            Reset to read mode so two consecutive rewind statements
+            don't delete the file contents.  */
           if (u->mode==WRITING)
             struncate(u->s);
+         u->mode = READING;
          u->last_record = 0;
          if (sseek (u->s, 0) == FAILURE)
            generate_error (ERROR_OS, NULL);