diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index 3ee00936037ede4839c332c5cd5388a846d88079..8a816fc9e5adeda2397f61162dcd84f1b7f241f7 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,3 +1,11 @@ +2009-11-18 Jerry DeLisle <jvdelisle@gcc.gnu.org> + + PR libgfortran/42090 + * io/transfer.c (skip_record): Set bytes_left_subrecord to zero after + skipping the remaining bytes in the record. + (next_record_r): Call skip_record with the number of bytes_left to be + skipped. + 2009-11-02 Janne Blomqvist <jb@gcc.gnu.org> * Makefile.am (gfor_io_headers): Add fbuf.h, format.h, unix.h. diff --git a/libgfortran/io/transfer.c b/libgfortran/io/transfer.c index b5f52b1ccf38811f7025d4c79a0a24daff6461ab..a110c6529ffe0275c6b62e9435d899adb14d4d40 100644 --- a/libgfortran/io/transfer.c +++ b/libgfortran/io/transfer.c @@ -2661,6 +2661,8 @@ skip_record (st_parameter_dt *dtp, ssize_t bytes) if (sseek (dtp->u.p.current_unit->s, dtp->u.p.current_unit->bytes_left_subrecord, SEEK_CUR) < 0) generate_error (&dtp->common, LIBERROR_OS, NULL); + + dtp->u.p.current_unit->bytes_left_subrecord = 0; } else { /* Seek by reading data. */ @@ -2741,7 +2743,7 @@ next_record_r (st_parameter_dt *dtp) case FORMATTED_DIRECT: case UNFORMATTED_DIRECT: - skip_record (dtp, 0); + skip_record (dtp, dtp->u.p.current_unit->bytes_left); break; case FORMATTED_STREAM: