From: Steven G. Kargl Date: Mon, 3 May 2010 17:57:14 +0000 (+0000) Subject: re PR fortran/43592 (Unexpected INTERFACE statement in INTERFACE block at (1)) X-Git-Tag: releases/gcc-4.6.0~7522 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=431f5969d1c519380d06981f330c8ca8f9cbe2bc;p=thirdparty%2Fgcc.git re PR fortran/43592 (Unexpected INTERFACE statement in INTERFACE block at (1)) 2010-05-03 Steven G. Kargl PR fortran/43592 * fortran/parse.c (parse_interface): Do not dereference a NULL pointer. 2010-05-03 Steven G. Kargl PR fortran/43592 * gfortran.dg/unexpected_interface.f90: New test. From-SVN: r158998 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 085e9fa51c6b..e61c7371110b 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,8 @@ +2010-05-03 Steven G. Kargl + + PR fortran/43592 + * fortran/parse.c (parse_interface): Do not dereference a NULL pointer. + 2010-05-02 Tobias Burnus PR fortran/18918 diff --git a/gcc/fortran/parse.c b/gcc/fortran/parse.c index 8ad52d28efb6..932006947430 100644 --- a/gcc/fortran/parse.c +++ b/gcc/fortran/parse.c @@ -2264,9 +2264,9 @@ loop: { if (current_state == COMP_NONE) { - if (new_state == COMP_FUNCTION) + if (new_state == COMP_FUNCTION && sym) gfc_add_function (&sym->attr, sym->name, NULL); - else if (new_state == COMP_SUBROUTINE) + else if (new_state == COMP_SUBROUTINE && sym) gfc_add_subroutine (&sym->attr, sym->name, NULL); current_state = new_state; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index fb25dc4f1101..a7876f92527c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2010-05-03 Steven G. Kargl + + PR fortran/43592 + * gfortran.dg/unexpected_interface.f90: New test. + 2010-05-03 Rainer Orth * ada/acats/run_acats (which): New function. diff --git a/gcc/testsuite/gfortran.dg/unexpected_interface.f90 b/gcc/testsuite/gfortran.dg/unexpected_interface.f90 new file mode 100644 index 000000000000..87c73c850508 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/unexpected_interface.f90 @@ -0,0 +1,9 @@ +! { dg-do compile } +! PR fortran/43592 +! Original code submitted by Joost VandeVondele +! Dejagnu-ification by Steven G. Kargl +! + interface assignment (=) + interface pseudo_scalar ! { dg-error "Unexpected INTERFACE statement" } + pure function double_tensor2odd (x, t2) result (xt2) +! { dg-error "Unexpected end of file" "" { target "*-*-*" } 0 }