diff options
author | pault <pault@138bc75d-0d04-0410-961f-82ee72b054a4> | 2006-11-24 22:22:40 +0000 |
---|---|---|
committer | pault <pault@138bc75d-0d04-0410-961f-82ee72b054a4> | 2006-11-24 22:22:40 +0000 |
commit | c5a2108d69b2f24ed6cc1d4d996b7bd056d46958 (patch) | |
tree | e7282ffa93de4569b618b2f353edc62bd74a97eb /gcc/fortran/resolve.c | |
parent | fc5212f328b4002c83b4437bae5446d465fd69a6 (diff) | |
download | ppe42-gcc-c5a2108d69b2f24ed6cc1d4d996b7bd056d46958.tar.gz ppe42-gcc-c5a2108d69b2f24ed6cc1d4d996b7bd056d46958.zip |
2006-11-24 Paul Thomas <pault@gcc.gnu.org>
PR fortran/20880
* parse.c (parse_interface): Error if procedure name is that of
encompassing scope.
* resolve.c (resolve_fl_procedure): Error if procedure is
ambiguous.
PR fortran/29387
* interface.c (compare_actual_formal): Add missing condition
that 'where' be present for error that asserts that actual
arguments be definable.
2006-11-24 Paul Thomas <pault@gcc.gnu.org>
PR fortran/20880
* gfortran.dg/interface_3.f90: New test.
PR fortran/29387
* gfortran.dg/generic_8.f90: New test.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@119173 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/fortran/resolve.c')
-rw-r--r-- | gcc/fortran/resolve.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c index 44ca7d9a22a..a4d220ae744 100644 --- a/gcc/fortran/resolve.c +++ b/gcc/fortran/resolve.c @@ -5516,11 +5516,20 @@ static try resolve_fl_procedure (gfc_symbol *sym, int mp_flag) { gfc_formal_arglist *arg; + gfc_symtree *st; if (sym->attr.function && resolve_fl_var_and_proc (sym, mp_flag) == FAILURE) return FAILURE; + st = gfc_find_symtree (gfc_current_ns->sym_root, sym->name); + if (st && st->ambiguous && !sym->attr.generic) + { + gfc_error ("Procedure %s at %L is ambiguous", + sym->name, &sym->declared_at); + return FAILURE; + } + if (sym->ts.type == BT_CHARACTER) { gfc_charlen *cl = sym->ts.cl; |