aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorTobias Burnus <burnus@net-b.de>2007-11-08 16:28:30 +0100
committerTobias Burnus <burnus@gcc.gnu.org>2007-11-08 16:28:30 +0100
commitabf86978b36f9c71aa5a66a9b8539c8ba9cffab9 (patch)
treef7ef7d479f14e519ab0db3529cf60639b796d6b0 /gcc
parentce796131e113b8a07e03c50c0d922fc8e4d2776e (diff)
downloadgcc-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')
-rw-r--r--gcc/fortran/ChangeLog7
-rw-r--r--gcc/fortran/decl.c2
-rw-r--r--gcc/fortran/interface.c4
-rw-r--r--gcc/testsuite/ChangeLog6
-rw-r--r--gcc/testsuite/gfortran.dg/proc_decl_5.f9028
-rw-r--r--gcc/testsuite/gfortran.dg/proc_decl_6.f9017
6 files changed, 61 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);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 676fb88..b07ada0 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,9 @@
+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.
+
2007-11-08 Jakub Jelinek <jakub@redhat.com>
PR tree-optimization/32575
diff --git a/gcc/testsuite/gfortran.dg/proc_decl_5.f90 b/gcc/testsuite/gfortran.dg/proc_decl_5.f90
new file mode 100644
index 0000000..b327d5c
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/proc_decl_5.f90
@@ -0,0 +1,28 @@
+! { dg-do run }
+! PR fortran/33945
+!
+! PROCEDURE in the interface was wrongly rejected
+module modproc
+ implicit none
+ interface bar
+ procedure x
+ end interface bar
+ procedure(sub) :: x
+ interface
+ integer function sub()
+ end function sub
+ end interface
+end module modproc
+
+integer function x()
+ implicit none
+ x = -5
+end function x
+
+program test
+ use modproc
+ implicit none
+ if(x() /= -5) call abort()
+end program test
+
+! { dg-final { cleanup-modules "modproc" } }
diff --git a/gcc/testsuite/gfortran.dg/proc_decl_6.f90 b/gcc/testsuite/gfortran.dg/proc_decl_6.f90
new file mode 100644
index 0000000..d2a6a1d
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/proc_decl_6.f90
@@ -0,0 +1,17 @@
+! { dg-do compile }
+! PR fortran/33945
+!
+! MODULE PROCEDURE in the interface was wrongly accepted
+module modproc2
+ implicit none
+ interface
+ subroutine x
+ end subroutine x
+ end interface
+ procedure(x) :: y
+ interface bar
+ module procedure y ! { dg-error "not a module procedure" }
+ end interface bar
+end module modproc2
+
+end