diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 281539573bb07338e7950bed737c45119a1c4852..dc4cab9aa5fccf56682f2221b20af27e3939fc54 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2006-11-18 Francois-Xavier Coudert <coudert@clipper.ens.fr> + + PR fortran/24285 + * io.c (check_format): Allow dollars everywhere in format, and + issue a warning. + 2006-11-17 Francois-Xavier Coudert <coudert@clipper.ens.fr> * gfortran.h (gfc_add_intrinsic_modules_path, diff --git a/gcc/fortran/io.c b/gcc/fortran/io.c index 24a92090f9e49a019a339da93fa5ae0b32157875..adf274ee118949ef301c87dc15c9f41fbc1c6e8d 100644 --- a/gcc/fortran/io.c +++ b/gcc/fortran/io.c @@ -510,8 +510,8 @@ format_item_1: return FAILURE; if (t != FMT_RPAREN || level > 0) { - error = _("$ must be the last specifier"); - goto syntax; + gfc_warning ("$ should be the last specifier in format at %C"); + goto optional_comma_1; } goto finished; @@ -755,8 +755,9 @@ between_desc: optional_comma: /* Optional comma is a weird between state where we've just finished - reading a colon, slash or P descriptor. */ + reading a colon, slash, dollar or P descriptor. */ t = format_lex (); +optional_comma_1: switch (t) { case FMT_COMMA: diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 02089e5e012bc5225b3b1e8e756ba286a64c8b42..2eff1c87b7e77fcb482a09880735e0cfe1b7090e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,9 @@ -2006-11-17 Francois-Xavier Coudert <coudert@clipper.ens.fr> +2006-11-18 Francois-Xavier Coudert <coudert@clipper.ens.fr> + + PR fortran/24285 + * gfortran.dg/dollar_edit_descriptor-3.f: New test. +2006-11-17 Francois-Xavier Coudert <coudert@clipper.ens.fr> * gfortran.dg/use_1.f90: New test. * gfortran.dg/use_1.f90: New test. * gfortran.dg/use_1.f90: New test. diff --git a/gcc/testsuite/gfortran.dg/dollar_edit_descriptor-3.f b/gcc/testsuite/gfortran.dg/dollar_edit_descriptor-3.f new file mode 100644 index 0000000000000000000000000000000000000000..6e5bf6890f22daf767b737f86b609774ed829363 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/dollar_edit_descriptor-3.f @@ -0,0 +1,8 @@ +! { dg-do run } +! { dg-options "-std=gnu" } +! Test for dollar descriptor in the middle of a format +300 format(1000(a,$)) ! { dg-warning "should be the last specifier" } + write(*,300) "gee", "gee" + write(*,"(1000(a,$))") "foo", "bar" ! { dg-warning "should be the last specifier" } + end +! { dg-output "^geegeefoobar$" }