summaryrefslogtreecommitdiff
path: root/libgfortran/io
diff options
context:
space:
mode:
authorjvdelisle <jvdelisle@138bc75d-0d04-0410-961f-82ee72b054a4>2007-04-01 17:32:20 +0000
committerjvdelisle <jvdelisle@138bc75d-0d04-0410-961f-82ee72b054a4>2007-04-01 17:32:20 +0000
commit49b5b3850ef5af1b34e93d46c788ac77be1259bc (patch)
tree33215bd612d3c257ba2f81ab28d1449710cbb577 /libgfortran/io
parentccfa609a4ed2efc76539be2d9a31bd9c581f8500 (diff)
downloadgcc-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.h3
-rw-r--r--libgfortran/io/open.c22
-rw-r--r--libgfortran/io/transfer.c7
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: