aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorTobias Burnus <burnus@net-b.de>2008-01-13 22:29:49 +0100
committerTobias Burnus <burnus@gcc.gnu.org>2008-01-13 22:29:49 +0100
commit083de129c8dd26ae3dcd5f24c77a3f424763e69f (patch)
treedee17b4bb562c6f86a2a0f98c471c03ba7f79193 /gcc
parent86288ff05fb23823f76c64f2c1f310283c74f822 (diff)
downloadgcc-083de129c8dd26ae3dcd5f24c77a3f424763e69f.zip
gcc-083de129c8dd26ae3dcd5f24c77a3f424763e69f.tar.gz
gcc-083de129c8dd26ae3dcd5f24c77a3f424763e69f.tar.bz2
re PR fortran/34763 (bare END not allowed in an interface block in a module procedure)
2008-01-13 Tobias Burnus <burnus@net-b.de> PR fortran/34763 * decl.c (contained_procedure): Only check directly preceeding * state. 2008-01-13 Tobias Burnus <burnus@net-b.de> PR fortran/34763 * gfortran.dg/interface_proc_end.f90: New. From-SVN: r131512
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog5
-rw-r--r--gcc/fortran/decl.c9
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gfortran.dg/interface_proc_end.f9019
4 files changed, 33 insertions, 5 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 5f94e76..683d66b 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,5 +1,10 @@
2008-01-13 Tobias Burnus <burnus@net-b.de>
+ PR fortran/34763
+ * decl.c (contained_procedure): Only check directly preceeding state.
+
+2008-01-13 Tobias Burnus <burnus@net-b.de>
+
PR fortran/34759
* check.c (gfc_check_shape): Accept array ranges of
assumed-size arrays.
diff --git a/gcc/fortran/decl.c b/gcc/fortran/decl.c
index dd8eb35..74d0962 100644
--- a/gcc/fortran/decl.c
+++ b/gcc/fortran/decl.c
@@ -4870,12 +4870,11 @@ gfc_match_bind_c (gfc_symbol *sym, bool allow_binding_name)
static int
contained_procedure (void)
{
- gfc_state_data *s;
+ gfc_state_data *s = gfc_state_stack;
- for (s=gfc_state_stack; s; s=s->previous)
- if ((s->state == COMP_SUBROUTINE || s->state == COMP_FUNCTION)
- && s->previous != NULL && s->previous->state == COMP_CONTAINS)
- return 1;
+ if ((s->state == COMP_SUBROUTINE || s->state == COMP_FUNCTION)
+ && s->previous != NULL && s->previous->state == COMP_CONTAINS)
+ return 1;
return 0;
}
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 98557e6..09b233e 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,10 @@
2008-01-13 Tobias Burnus <burnus@net-b.de>
+ PR fortran/34763
+ * gfortran.dg/interface_proc_end.f90: New.
+
+2008-01-13 Tobias Burnus <burnus@net-b.de>
+
PR fortran/34759
* gfortran.dg/assumed_size_refs_4.f90: New.
diff --git a/gcc/testsuite/gfortran.dg/interface_proc_end.f90 b/gcc/testsuite/gfortran.dg/interface_proc_end.f90
new file mode 100644
index 0000000..d037de6
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/interface_proc_end.f90
@@ -0,0 +1,19 @@
+! { dg-do compile}
+!
+! PR fortran/34763
+! Before, gfortran did not allow for the "END" in
+! the interface, which is no module procedure.
+!
+! Test case contributed by Dick Hendrickson
+!
+ module n
+ contains
+ subroutine n_interface
+ INTERFACE
+ SUBROUTINE NGSXDY(TLS1,TLS2)
+ REAL :: TLS1,TLS2
+ END ! OK
+ END INTERFACE
+ end ! { dg-error "END SUBROUTINE statement" }
+ end module ! { dg-error "END SUBROUTINE statement" }
+! { dg-excess-errors "Unexpected end of file" }