Commit d1d919c3 by Janus Weil

re PR fortran/40176 (Fortran 2003: Procedure pointers with array return value)

2009-06-12  Janus Weil  <janus@gcc.gnu.org>

	PR fortran/40176
	* resolve.c (resolve_symbol): Additional error check, preventing an
	infinite loop.


2009-06-12  Janus Weil  <janus@gcc.gnu.org>

	PR fortran/40176
	* gfortran.dg/proc_decl_1.f90: Extended.

From-SVN: r148440
parent 3d8b2a98
2009-06-12 Janus Weil <janus@gcc.gnu.org>
PR fortran/40176
* resolve.c (resolve_symbol): Additional error check, preventing an
infinite loop.
2009-06-11 Paul Thomas <pault@gcc.gnu.org> 2009-06-11 Paul Thomas <pault@gcc.gnu.org>
PR fortran/40402 PR fortran/40402
......
...@@ -9406,10 +9406,19 @@ resolve_symbol (gfc_symbol *sym) ...@@ -9406,10 +9406,19 @@ resolve_symbol (gfc_symbol *sym)
if (sym->attr.procedure && sym->ts.interface if (sym->attr.procedure && sym->ts.interface
&& sym->attr.if_source != IFSRC_DECL) && sym->attr.if_source != IFSRC_DECL)
{ {
if (sym->ts.interface == sym)
{
gfc_error ("PROCEDURE '%s' at %L may not be used as its own "
"interface", sym->name, &sym->declared_at);
return;
}
if (sym->ts.interface->attr.procedure) if (sym->ts.interface->attr.procedure)
gfc_error ("Interface '%s', used by procedure '%s' at %L, is declared " {
"in a later PROCEDURE statement", sym->ts.interface->name, gfc_error ("Interface '%s', used by procedure '%s' at %L, is declared"
" in a later PROCEDURE statement", sym->ts.interface->name,
sym->name,&sym->declared_at); sym->name,&sym->declared_at);
return;
}
/* Get the attributes from the interface (now resolved). */ /* Get the attributes from the interface (now resolved). */
if (sym->ts.interface->attr.if_source if (sym->ts.interface->attr.if_source
......
2009-06-12 Janus Weil <janus@gcc.gnu.org>
PR fortran/40176
* gfortran.dg/proc_decl_1.f90: Extended.
2009-06-12 Ian Lance Taylor <iant@google.com> 2009-06-12 Ian Lance Taylor <iant@google.com>
* gcc.dg/Wcxx-compat-13.c: New testcase. * gcc.dg/Wcxx-compat-13.c: New testcase.
......
...@@ -57,6 +57,8 @@ program prog ...@@ -57,6 +57,8 @@ program prog
procedure ( ) :: r procedure ( ) :: r
procedure ( up ) :: s ! { dg-error "must be explicit" } procedure ( up ) :: s ! { dg-error "must be explicit" }
procedure(t) :: t ! { dg-error "may not be used as its own interface" }
call s call s
contains contains
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment