diff options
author | jvdelisle <jvdelisle@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-04-01 17:32:20 +0000 |
---|---|---|
committer | jvdelisle <jvdelisle@138bc75d-0d04-0410-961f-82ee72b054a4> | 2007-04-01 17:32:20 +0000 |
commit | 49b5b3850ef5af1b34e93d46c788ac77be1259bc (patch) | |
tree | 33215bd612d3c257ba2f81ab28d1449710cbb577 /libgfortran/io | |
parent | ccfa609a4ed2efc76539be2d9a31bd9c581f8500 (diff) | |
download | gcc-49b5b3850ef5af1b34e93d46c788ac77be1259bc.tar.gz |
2007-04-01 Jerry DeLisle <jvdelisle@gcc.gnu.org>
PR libgfortran/31052
* io/open.c (test_endfile): Delete this function.
(edit_modes): Delete call to test_endfile.
(new_unit): Likewise.
* io/io.h: Delete prototype for test_endfile.
* io/transfer.c (next_record_r): Remove use of test_endfile.
(st_read): Add test for end file condition and adjust status.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@123403 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libgfortran/io')
-rw-r--r-- | libgfortran/io/io.h | 3 | ||||
-rw-r--r-- | libgfortran/io/open.c | 22 | ||||
-rw-r--r-- | libgfortran/io/transfer.c | 7 |
3 files changed, 3 insertions, 29 deletions
diff --git a/libgfortran/io/io.h b/libgfortran/io/io.h index ef1a287a184..df006693b28 100644 --- a/libgfortran/io/io.h +++ b/libgfortran/io/io.h @@ -695,9 +695,6 @@ internal_proto(unlock_unit); /* open.c */ -extern void test_endfile (gfc_unit *); -internal_proto(test_endfile); - extern gfc_unit *new_unit (st_parameter_open *, gfc_unit *, unit_flags *); internal_proto(new_unit); diff --git a/libgfortran/io/open.c b/libgfortran/io/open.c index 44ff69d68db..742610a3ef6 100644 --- a/libgfortran/io/open.c +++ b/libgfortran/io/open.c @@ -109,19 +109,6 @@ static const st_option convert_opt[] = { NULL, 0} }; -/* Given a unit, test to see if the file is positioned at the terminal - point, and if so, change state from NO_ENDFILE flag to AT_ENDFILE. - This prevents us from changing the state from AFTER_ENDFILE to - AT_ENDFILE. */ - -void -test_endfile (gfc_unit * u) -{ - if (u->endfile == NO_ENDFILE && file_length (u->s) == file_position (u->s)) - u->endfile = AT_ENDFILE; -} - - /* Change the modes of a file, those that are allowed * to be changed. */ @@ -208,8 +195,6 @@ edit_modes (st_parameter_open *opp, gfc_unit * u, unit_flags * flags) u->current_record = 0; u->last_record = 0; - - test_endfile (u); /* We might be at the end. */ break; case POSITION_APPEND: @@ -487,13 +472,6 @@ new_unit (st_parameter_open *opp, gfc_unit *u, unit_flags * flags) memmove (u->file, opp->file, opp->file_len); u->file_len = opp->file_len; - /* Curiously, the standard requires that the - position specifier be ignored for new files so a newly connected - file starts out at the initial point. We still need to figure - out if the file is at the end or not. */ - - test_endfile (u); - if (flags->status == STATUS_SCRATCH && opp->file != NULL) free_mem (opp->file); return u; diff --git a/libgfortran/io/transfer.c b/libgfortran/io/transfer.c index 3c6deb4998c..65d83ef465c 100644 --- a/libgfortran/io/transfer.c +++ b/libgfortran/io/transfer.c @@ -2226,10 +2226,6 @@ next_record_r (st_parameter_dt *dtp) break; } - - if (dtp->u.p.current_unit->flags.access == ACCESS_SEQUENTIAL - && !dtp->u.p.namelist_mode) - test_endfile (dtp->u.p.current_unit); } @@ -2702,6 +2698,9 @@ st_read (st_parameter_dt *dtp) switch (dtp->u.p.current_unit->endfile) { case NO_ENDFILE: + if (file_length (dtp->u.p.current_unit->s) + == file_position (dtp->u.p.current_unit->s)) + dtp->u.p.current_unit->endfile = AT_ENDFILE; break; case AT_ENDFILE: |