From: jvdelisle Date: Mon, 23 Nov 2015 00:40:51 +0000 (+0000) Subject: 2015-11-22 Jerry DeLisle X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=14b5bae1fd51987b27a755138c7155f54591dbf2;p=thirdparty%2Fgcc.git 2015-11-22 Jerry DeLisle PR libfortran/52251 * io/transfer.c (formatted_transfer_scalar_write): Reset skips count. (finalize_transfer): For ADVANCE_NO, emit pending spaces and reset the skip count. 2015-11-22 Jerry DeLisle * gfortran.dg/fmt_t_8.f90: New test. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@230734 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 3074642b2475..5c670114c74d 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2015-11-22 Jerry DeLisle + + * gfortran.dg/fmt_t_8.f90: New test. + 2015-11-23 Kugan Vivekanandarajah PR target/68390 diff --git a/gcc/testsuite/gfortran.dg/fmt_t_8.f90 b/gcc/testsuite/gfortran.dg/fmt_t_8.f90 new file mode 100644 index 000000000000..d56d19bb3648 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/fmt_t_8.f90 @@ -0,0 +1,6 @@ +! { dg-do run } +! PR52251 Tabs with advance = 'no' +write( *, '( t25 )', advance = 'no' ) +write( *, '( "hello" )' ) ! { dg-output " hello(\n|\r\n|\r)" } +end + diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index f90d5301df85..48db71b8df7d 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,3 +1,10 @@ +2015-11-22 Jerry DeLisle + + PR libfortran/52251 + * io/transfer.c (formatted_transfer_scalar_write): Reset skips count. + (finalize_transfer): For ADVANCE_NO, emit pending spaces and reset the + skip count. + 2015-11-22 Jerry DeLisle * io/write_float.def (output_float): Move block determining diff --git a/libgfortran/io/transfer.c b/libgfortran/io/transfer.c index 746bb6dcc6cc..94f1edaa6797 100644 --- a/libgfortran/io/transfer.c +++ b/libgfortran/io/transfer.c @@ -1641,6 +1641,7 @@ formatted_transfer_scalar_write (st_parameter_dt *dtp, bt type, void *p, int kin - dtp->u.p.current_unit->bytes_left); dtp->u.p.max_pos = dtp->u.p.max_pos > tmp ? dtp->u.p.max_pos : tmp; + dtp->u.p.skips = 0; } if (dtp->u.p.skips < 0) { @@ -3600,6 +3601,16 @@ finalize_transfer (st_parameter_dt *dtp) next I/O operation if needed. */ if (dtp->u.p.advance_status == ADVANCE_NO) { + if (dtp->u.p.skips > 0) + { + int tmp; + write_x (dtp, dtp->u.p.skips, dtp->u.p.pending_spaces); + tmp = (int)(dtp->u.p.current_unit->recl + - dtp->u.p.current_unit->bytes_left); + dtp->u.p.max_pos = + dtp->u.p.max_pos > tmp ? dtp->u.p.max_pos : tmp; + dtp->u.p.skips = 0; + } int bytes_written = (int) (dtp->u.p.current_unit->recl - dtp->u.p.current_unit->bytes_left); dtp->u.p.current_unit->saved_pos =