aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorTobias Schlüter <tobias.schlueter@physik.uni-muenchen.de>2004-05-14 15:46:05 +0200
committerTobias Schlüter <tobi@gcc.gnu.org>2004-05-14 15:46:05 +0200
commit9b089e0545b2b8f6455c91584714e5ab918dfac6 (patch)
treece92f466c8f898b945fa790d876142e9a39ff6cb /gcc
parentee17cbda2e69d9d19d4664cef4f96ff180ca8c5b (diff)
downloadgcc-9b089e0545b2b8f6455c91584714e5ab918dfac6.zip
gcc-9b089e0545b2b8f6455c91584714e5ab918dfac6.tar.gz
gcc-9b089e0545b2b8f6455c91584714e5ab918dfac6.tar.bz2
re PR fortran/14066 (Infinite DO loops not recognized.)
fortran: PR fortran/14066 * match.c (gfc_match_do): Allow infinite loops with label-do-stmt. Do not enforce space after comma. testsuite: PR fortran/14066 * gfortran.fortran-torture/compile/do_1.f90: New test. Also fixed date on previous ChangeLog entries. From-SVN: r81842
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog12
-rw-r--r--gcc/fortran/match.c14
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gfortran.fortran-torture/compile/do_1.f9028
4 files changed, 49 insertions, 10 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index ab9f8ba..9e3741a 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,10 +1,16 @@
-2004-05-08 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
+2004-05-14 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
+
+ PR fortran/14066
+ * match.c (gfc_match_do): Allow infinite loops with
+ label-do-stmt. Do not enforce space after comma.
+
+2004-05-14 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
PR fortran/15051
* parse.c (parse_interface): Allow empty INTERFACE, remove
seen_body.
-2004-05-08 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
+2004-05-14 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
* Make-lang.in, arith.c, arith.h, array.c, bbt.c, check.c,
decl.c, dependency.c, dependency.h, dump-parse-tree.c, error.c,
@@ -20,7 +26,7 @@
* data.c: Likewise, also removed two whitespace-only lines.
* gfortranspec.c, lang.opt: Update copyright years.
-2004-04-22 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
+2004-05-14 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
PR fortran/14568
* trans-decl.c (generate_local_decl): Don't warn for unused
diff --git a/gcc/fortran/match.c b/gcc/fortran/match.c
index 28fe7a6..fc5afbf 100644
--- a/gcc/fortran/match.c
+++ b/gcc/fortran/match.c
@@ -1203,6 +1203,10 @@ gfc_match_do (void)
if (gfc_match (" do") != MATCH_YES)
return MATCH_NO;
+ m = gfc_match_st_label (&label, 0);
+ if (m == MATCH_ERROR)
+ goto cleanup;
+
/* Match an infinite DO, make it like a DO WHILE(.TRUE.) */
if (gfc_match_eos () == MATCH_YES)
@@ -1212,13 +1216,9 @@ gfc_match_do (void)
goto done;
}
- m = gfc_match_st_label (&label, 0);
- if (m == MATCH_ERROR)
- goto cleanup;
-
- gfc_match_char (',');
-
- if (gfc_match ("% ") != MATCH_YES)
+ /* match an optional comma, if no comma is found a space is obligatory. */
+ if (gfc_match_char(',') != MATCH_YES
+ && gfc_match ("% ") != MATCH_YES)
return MATCH_NO;
/* See if we have a DO WHILE. */
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 6baf19a..216d3e8 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,10 @@
2004-05-14 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
+ PR fortran/14066
+ * gfortran.fortran-torture/compile/do_1.f90: New test.
+
+2004-05-14 Tobias Schlueter <tobias.schlueter@physik.uni-muenchen.de>
+
PR fortran/15051
* gfortran.fortran-torture/compile/empty_interface_1.f90: New
test.
diff --git a/gcc/testsuite/gfortran.fortran-torture/compile/do_1.f90 b/gcc/testsuite/gfortran.fortran-torture/compile/do_1.f90
new file mode 100644
index 0000000..396592c
--- /dev/null
+++ b/gcc/testsuite/gfortran.fortran-torture/compile/do_1.f90
@@ -0,0 +1,28 @@
+! test various forms of the DO statement
+! inspired by PR14066
+LOGICAL L
+DO i=1,10
+END DO
+DO 10 i=1,20
+ DO 20,j=1,10,2
+20 CONTINUE
+10 END DO
+L = .TRUE.
+DO WHILE(L)
+ L = .FALSE.
+END DO
+DO 50 WHILE(.NOT.L)
+ L = .TRUE.
+50 CONTINUE
+DO
+ DO 30
+ DO 40
+40 CONTINUE
+30 END DO
+END DO
+outer: DO i=1,20
+ inner: DO,j=i,30
+ IF (j.EQ.2*i) CYCLE outer
+ END DO inner
+END DO outer
+END