From 8e785b78e82d299c1fae5815833f3a4e74d8b728 Mon Sep 17 00:00:00 2001 From: Francois-Xavier Coudert Date: Wed, 10 May 2006 16:51:26 +0200 Subject: [PATCH] re PR fortran/24549 ([4.1 only] ICE with invalid pseudo-declaration statement) PR fortran/24549 * parse.c (reject_statement): Clear gfc_new_block. * gfortran.dg/error_recovery_1.f90: New test. From-SVN: r113671 --- gcc/fortran/ChangeLog | 5 +++++ gcc/fortran/parse.c | 2 +- gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/gfortran.dg/error_recovery_1.f90 | 15 +++++++++++++++ 4 files changed, 26 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/gfortran.dg/error_recovery_1.f90 diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 1b456cd..05b5531 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,8 @@ +2006-05-10 Francois-Xavier Coudert + + PR fortran/24549 + * parse.c (reject_statement): Clear gfc_new_block. + 2006-05-09 Steven G. Kargl * invoke.texi: Missed file in previous commit. Update diff --git a/gcc/fortran/parse.c b/gcc/fortran/parse.c index 2b04904..2f358e8 100644 --- a/gcc/fortran/parse.c +++ b/gcc/fortran/parse.c @@ -1292,7 +1292,7 @@ accept_statement (gfc_statement st) static void reject_statement (void) { - + gfc_new_block = NULL; gfc_undo_symbols (); gfc_clear_warning (); undo_new_statement (); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 7e7c9982..6bcb53e 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2006-05-10 Francois-Xavier Coudert + + PR fortran/24549 + * gfortran.dg/error_recovery_1.f90: New test. + 2006-05-10 Richard Guenther PR tree-optimization/27302 diff --git a/gcc/testsuite/gfortran.dg/error_recovery_1.f90 b/gcc/testsuite/gfortran.dg/error_recovery_1.f90 new file mode 100644 index 0000000..8d4f65b --- /dev/null +++ b/gcc/testsuite/gfortran.dg/error_recovery_1.f90 @@ -0,0 +1,15 @@ +! { dg-do compile } +! PR fortran/24549 (and duplicate PR fortran/27487) +module gfcbug29_import + interface + subroutine foo (x) + something :: dp ! { dg-error "Unclassifiable statement" } + real (kind=dp) :: x ! { dg-error "has not been declared or is a variable, which does not reduce to a constant expression" } + end subroutine foo + end interface +end module gfcbug29_import + +subroutine FOO + X :: I ! { dg-error "Unclassifiable statement" } + equivalence (I,I) +end -- 2.7.4