diff options
author | jvdelisle <jvdelisle@138bc75d-0d04-0410-961f-82ee72b054a4> | 2006-11-09 03:32:19 +0000 |
---|---|---|
committer | jvdelisle <jvdelisle@138bc75d-0d04-0410-961f-82ee72b054a4> | 2006-11-09 03:32:19 +0000 |
commit | 6451ad929afd8e75e676316b5b130bf2055cb573 (patch) | |
tree | 94b92fd3989a84a0ca22756bd2446b084d2fc949 /libgfortran/io | |
parent | 83bf83739ba59fd97a365b2bedb77bf6249c8e03 (diff) | |
download | gcc-6451ad929afd8e75e676316b5b130bf2055cb573.tar.gz |
2006-11-08 Jerry DeLisle <jvdelisle@gcc.gnu.org>
PR libgfortran/29752
* io/transfer.c (finalize_transfer): Flush on ADVANCE_NO.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/branches/gcc-4_2-branch@118612 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libgfortran/io')
-rw-r--r-- | libgfortran/io/transfer.c | 9 |
1 files changed, 6 insertions, 3 deletions
diff --git a/libgfortran/io/transfer.c b/libgfortran/io/transfer.c index 066e38e1bc9..c5c2e1655e9 100644 --- a/libgfortran/io/transfer.c +++ b/libgfortran/io/transfer.c @@ -2349,9 +2349,6 @@ finalize_transfer (st_parameter_dt *dtp) dtp->u.p.current_unit->current_record = 0; - if (dtp->u.p.advance_status == ADVANCE_NO) - return; - if (!is_internal_unit (dtp) && dtp->u.p.seen_dollar) { dtp->u.p.seen_dollar = 0; @@ -2359,6 +2356,12 @@ finalize_transfer (st_parameter_dt *dtp) return; } + if (dtp->u.p.advance_status == ADVANCE_NO) + { + flush (dtp->u.p.current_unit->s); + return; + } + next_record (dtp, 1); sfree (dtp->u.p.current_unit->s); } |