From 78579b601d74b339eadbc08bb3cf1a4c48a70f69 Mon Sep 17 00:00:00 2001 From: Bud Davis Date: Thu, 2 Dec 2004 04:29:00 +0000 Subject: re PR libfortran/18284 (BACKSPACE broken) 2004-12-02 Bud Davis PR libfortran/18284 * io/unix.c (fd_alloc_w_at): Update file_length when extending. * io/backspace.c (formatted_backspace): Reset endfile after backspace. PR fortran/18284 * gfortran.dg/backspace.f90 From-SVN: r91612 --- libgfortran/ChangeLog | 6 ++++++ libgfortran/io/backspace.c | 1 + libgfortran/io/unix.c | 3 +++ 3 files changed, 10 insertions(+) (limited to 'libgfortran') diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index e90c0fa..a0b3ec1 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,5 +1,11 @@ 2004-12-02 Bud Davis + PR libfortran/18284 + * io/unix.c (fd_alloc_w_at): Update file_length when extending. + * io/backspace.c (formatted_backspace): Reset endfile after backspace. + +2004-12-02 Bud Davis + * io/inquire.c (inquire_via_unit): do not allow a direct access file to be opened for sequential I/O. diff --git a/libgfortran/io/backspace.c b/libgfortran/io/backspace.c index c40e506..e378adf 100644 --- a/libgfortran/io/backspace.c +++ b/libgfortran/io/backspace.c @@ -77,6 +77,7 @@ done: if (sseek (current_unit->s, base) == FAILURE) goto io_error; current_unit->last_record--; + current_unit->endfile = NO_ENDFILE; return; diff --git a/libgfortran/io/unix.c b/libgfortran/io/unix.c index 5be631a..8e3afbd 100644 --- a/libgfortran/io/unix.c +++ b/libgfortran/io/unix.c @@ -462,6 +462,9 @@ fd_alloc_w_at (unix_stream * s, int *len, gfc_offset where) s->logical_offset = where + *len; + if (where + *len > s->file_length) + s->file_length = where + *len; + n = s->logical_offset - s->buffer_offset; if (n > s->active) s->active = n; -- cgit v1.1