From 26bda00088e819ebd7d90b562d21c33ffd6a97a5 Mon Sep 17 00:00:00 2001 From: Jerry DeLisle Date: Sat, 6 Feb 2010 14:39:51 +0000 Subject: [PATCH] PR libfortran 2010-02-06 Jerry DeLisle PR libfortran * io/transfer.c (read_sf): Handle EOR and EOF conditions for ADVANCE="no" with PAD="yes" or PAD="no". From-SVN: r156540 --- libgfortran/ChangeLog | 6 ++++++ libgfortran/io/transfer.c | 15 ++++++++++++++- 2 files changed, 20 insertions(+), 1 deletion(-) diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index c77b018e8dd..be54763e96f 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,3 +1,9 @@ +2010-02-06 Jerry DeLisle + + PR libfortran + * io/transfer.c (read_sf): Handle EOR and EOF conditions for + ADVANCE="no" with PAD="yes" or PAD="no". + 2010-02-03 Jerry DeLisle PR libfortran/42901 diff --git a/libgfortran/io/transfer.c b/libgfortran/io/transfer.c index a110c6529ff..e627a1c7590 100644 --- a/libgfortran/io/transfer.c +++ b/libgfortran/io/transfer.c @@ -305,7 +305,20 @@ read_sf (st_parameter_dt *dtp, int * length, int no_error) if (lorig > *length && !dtp->u.p.sf_seen_eor && !seen_comma) { if (n > 0 || no_error) - dtp->u.p.at_eof = 1; + { + if (dtp->u.p.advance_status == ADVANCE_NO) + { + if (dtp->u.p.current_unit->pad_status == PAD_NO) + { + hit_eof (dtp); + return NULL; + } + else + dtp->u.p.eor_condition = 1; + } + else + dtp->u.p.at_eof = 1; + } else { hit_eof (dtp);