From: Jerry DeLisle Date: Sun, 20 Apr 2008 21:11:22 +0000 (+0000) Subject: re PR fortran/35882 (Miscounted continuation lines when interspersed with data) X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=f449022dca52d61f2f57cb40e6fc4b9b69049314;p=gcc.git re PR fortran/35882 (Miscounted continuation lines when interspersed with data) 2008-04-20 Jerry DeLisle PR fortran/35882 * scanner.c (skip_fixed_comments): Update continue_line when comment is detected. (gfc_next_char_literal): Likewise. PR fortran/35882 * gfortran.dg/continuation_5.f: Add some comment lines. * gfortran.dg/continuation_3.f90: Add some comment lines. From-SVN: r134493 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index abcc336e4d1..78d9359c9b2 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2008-04-20 Jerry DeLisle + + PR fortran/35882 + * scanner.c (skip_fixed_comments): Update continue_line when comment is + detected. (gfc_next_char_literal): Likewise. + 2008-04-19 Paul Thomas PR fortran/35944 diff --git a/gcc/fortran/scanner.c b/gcc/fortran/scanner.c index dcdac64e725..1aa52f5d576 100644 --- a/gcc/fortran/scanner.c +++ b/gcc/fortran/scanner.c @@ -615,6 +615,10 @@ skip_fixed_comments (void) !$|c$|*$ should be treated as 2 spaces if the characters in columns 3 to 6 are valid fixed form label columns characters. */ + if (gfc_current_locus.lb != NULL + && continue_line < gfc_linebuf_linenum (gfc_current_locus.lb)) + continue_line = gfc_linebuf_linenum (gfc_current_locus.lb); + if (gfc_option.flag_openmp) { if (next_char () == '$') @@ -700,6 +704,9 @@ skip_fixed_comments (void) if (col != 6 && c == '!') { + if (gfc_current_locus.lb != NULL + && continue_line < gfc_linebuf_linenum (gfc_current_locus.lb)) + continue_line = gfc_linebuf_linenum (gfc_current_locus.lb); skip_comment_line (); continue; } @@ -821,12 +828,14 @@ restart: "statement at %C", gfc_option.max_continue_free); } } - if (continue_line < gfc_linebuf_linenum (gfc_current_locus.lb)) - continue_line = gfc_linebuf_linenum (gfc_current_locus.lb); /* Now find where it continues. First eat any comment lines. */ openmp_cond_flag = skip_free_comments (); + if (gfc_current_locus.lb != NULL + && continue_line < gfc_linebuf_linenum (gfc_current_locus.lb)) + continue_line = gfc_linebuf_linenum (gfc_current_locus.lb); + if (prev_openmp_flag != openmp_flag) { gfc_current_locus = old_loc; @@ -945,7 +954,8 @@ restart: } } - if (continue_line < gfc_linebuf_linenum (gfc_current_locus.lb)) + if (gfc_current_locus.lb != NULL + && continue_line < gfc_linebuf_linenum (gfc_current_locus.lb)) continue_line = gfc_linebuf_linenum (gfc_current_locus.lb); } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index d2435caaa72..a62ea30fa9c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,9 @@ +2008-04-20 Jerry DeLisle + + PR fortran/35882 + * gfortran.dg/continuation_5.f: Add some comment lines. + * gfortran.dg/continuation_3.f90: Add some comment lines. + 2008-04-20 Thomas Koenig PR libfortran/35960 diff --git a/gcc/testsuite/gfortran.dg/continuation_3.f90 b/gcc/testsuite/gfortran.dg/continuation_3.f90 index 238f8cc7b8f..169f06f65a3 100644 --- a/gcc/testsuite/gfortran.dg/continuation_3.f90 +++ b/gcc/testsuite/gfortran.dg/continuation_3.f90 @@ -72,8 +72,12 @@ print *, & "7" // & ! 27 "8" // & ! 28 "9" // & ! 29 +! + ! "0" // & ! 30 "1" // & ! 31 +! +! "2" // & ! 32 "3" // & ! 33 "4" // & ! 34 diff --git a/gcc/testsuite/gfortran.dg/continuation_5.f b/gcc/testsuite/gfortran.dg/continuation_5.f index 15e06077ff3..aeb240368cb 100644 --- a/gcc/testsuite/gfortran.dg/continuation_5.f +++ b/gcc/testsuite/gfortran.dg/continuation_5.f @@ -32,11 +32,19 @@ c "7" // ! 7 c "8" // ! 8 c "9" // ! 9 +! +c +* +C c "0" // ! 10 c "1" // ! 11 c "2" // ! 12 c "3" // ! 13 c "4" // ! 14 +c + + ! + ! c "5" // ! 15 c "6" // ! 16 c "7" // ! 17