diff options
author | Tobias Burnus <burnus@net-b.de> | 2007-11-08 16:28:30 +0100 |
---|---|---|
committer | Tobias Burnus <burnus@gcc.gnu.org> | 2007-11-08 16:28:30 +0100 |
commit | abf86978b36f9c71aa5a66a9b8539c8ba9cffab9 (patch) | |
tree | f7ef7d479f14e519ab0db3529cf60639b796d6b0 /gcc/fortran | |
parent | ce796131e113b8a07e03c50c0d922fc8e4d2776e (diff) | |
download | gcc-abf86978b36f9c71aa5a66a9b8539c8ba9cffab9.zip gcc-abf86978b36f9c71aa5a66a9b8539c8ba9cffab9.tar.gz gcc-abf86978b36f9c71aa5a66a9b8539c8ba9cffab9.tar.bz2 |
re PR fortran/33917 (Rejects valid PROCEDURE declarations)
2007-11-08 Tobias Burnus <burnus@net-b.de>
PR fortran/33917
* interface.c (check_sym_interfaces): Disallow PROCEDURE-declared
procedures for MODULE PROCEDURE.
* decl.c (match_procedure_in_interface): Do not mark as procedure.
2007-11-08 Tobias Burnus <burnus@net-b.de>
PR fortran/33917
* gfortran.dg/proc_decl_5.f90: New.
* gfortran.dg/proc_decl_6.f90: New.
From-SVN: r130002
Diffstat (limited to 'gcc/fortran')
-rw-r--r-- | gcc/fortran/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/fortran/decl.c | 2 | ||||
-rw-r--r-- | gcc/fortran/interface.c | 4 |
3 files changed, 10 insertions, 3 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 42c726c..8103821 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,10 @@ +2007-11-08 Tobias Burnus <burnus@net-b.de> + + PR fortran/33917 + * interface.c (check_sym_interfaces): Disallow PROCEDURE-declared + procedures for MODULE PROCEDURE. + * decl.c (match_procedure_in_interface): Do not mark as procedure. + 2007-11-03 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org> PR fortran/33881 diff --git a/gcc/fortran/decl.c b/gcc/fortran/decl.c index dacfe4a..74c655d 100644 --- a/gcc/fortran/decl.c +++ b/gcc/fortran/decl.c @@ -4091,8 +4091,6 @@ match_procedure_in_interface (void) if (gfc_add_interface (sym) == FAILURE) return MATCH_ERROR; - sym->attr.procedure = 1; - if (gfc_match_eos () == MATCH_YES) break; if (gfc_match_char (',') != MATCH_YES) diff --git a/gcc/fortran/interface.c b/gcc/fortran/interface.c index 39f4e92..7f6406a 100644 --- a/gcc/fortran/interface.c +++ b/gcc/fortran/interface.c @@ -1137,7 +1137,9 @@ check_sym_interfaces (gfc_symbol *sym) for (p = sym->generic; p; p = p->next) { - if (p->sym->attr.mod_proc && p->sym->attr.if_source != IFSRC_DECL) + if (p->sym->attr.mod_proc + && (p->sym->attr.if_source != IFSRC_DECL + || p->sym->attr.procedure)) { gfc_error ("'%s' at %L is not a module procedure", p->sym->name, &p->where); |