diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 8e73d94f797..d92bf93d94e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2005-05-10 Francois-Xavier Coudert + + PR libfortran/21471 + * gfortran.dg/append-1.f90: New test. + 2005-05-10 Diego Novillo * gcc.dg/pr18501.c: XFAIL. diff --git a/gcc/testsuite/gfortran.dg/append-1.f90 b/gcc/testsuite/gfortran.dg/append-1.f90 new file mode 100644 index 00000000000..8b81bc38484 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/append-1.f90 @@ -0,0 +1,36 @@ +! PR libfortran/21471 +! Testing POSITION="APPEND" +! +! { dg-do run } + subroutine failed + close (10,status='delete') + call abort + end subroutine failed + + integer,parameter :: n = 13 + integer :: i, j, error + + open (10, file='foo') + close (10) + + do i = 1, n + open (10, file='foo',position='append') + write (10,*) i + close (10) + end do + + open (10,file='foo',status='old') + error = 0 + i = -1 + do while (error == 0) + i = i + 1 + read (10,*,iostat=error) j + if (error == 0) then + if (i + 1 /= j) call failed + end if + if (i > n + 1) call failed + end do + if (i /= n) call failed + close (10,status='delete') + end + diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index 95884c1891c..fa866a1091f 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,3 +1,9 @@ +2005-05-10 Francois-Xavier Coudert + + PR libfortran/21471 + * open.c (new_unit): Take care of the case where POSITION_APPEND + is specified (sseek to the end, and set u>-endfile). + 2005-05-10 Tobias Schl"uter PR fortran/20178 diff --git a/libgfortran/io/open.c b/libgfortran/io/open.c index 82a862b7c47..97bf6e4cc3d 100644 --- a/libgfortran/io/open.c +++ b/libgfortran/io/open.c @@ -356,6 +356,13 @@ new_unit (unit_flags * flags) u->s = s; u->flags = *flags; + if (flags->position == POSITION_APPEND) + { + if (sseek (u->s, file_length (u->s)) == FAILURE) + generate_error (ERROR_OS, NULL); + u->endfile = AT_ENDFILE; + } + /* Unspecified recl ends up with a processor dependent value. */ u->recl = (ioparm.recl_in != 0) ? ioparm.recl_in : g.max_offset;