aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/match.c
diff options
context:
space:
mode:
authorSteven G. Kargl <kargl@gcc.gnu.org>2015-06-08 15:55:16 +0000
committerSteven G. Kargl <kargl@gcc.gnu.org>2015-06-08 15:55:16 +0000
commitef701bbe50402a6b44f73bc3913ac8c85b1d5b9e (patch)
treefd6d439ac0a513dbb2abe336673638a486ae4437 /gcc/fortran/match.c
parenta1661b90dcbaed222e647bda75540e8a87f250ed (diff)
downloadgcc-ef701bbe50402a6b44f73bc3913ac8c85b1d5b9e.zip
gcc-ef701bbe50402a6b44f73bc3913ac8c85b1d5b9e.tar.gz
gcc-ef701bbe50402a6b44f73bc3913ac8c85b1d5b9e.tar.bz2
re PR fortran/66245 (ICE on select type with empty type spec)
2015-06-08 Steven G. Kargl <kargl@gcc.gnu.org> PR fortran/66245 * match.c (gfc_match_type_is, gfc_match_class_is): Check if the return type spec or derived type spec is validate. 2015-06-08 Steven G. Kargl <kargl@gcc.gnu.org> PR fortran/66245 * gfortran.dg/class_is_1.f90: New test. * gfortran.dg/type_is_1.f90: Ditto. From-SVN: r224237
Diffstat (limited to 'gcc/fortran/match.c')
-rw-r--r--gcc/fortran/match.c10
1 files changed, 8 insertions, 2 deletions
diff --git a/gcc/fortran/match.c b/gcc/fortran/match.c
index b51d18a..c064135 100644
--- a/gcc/fortran/match.c
+++ b/gcc/fortran/match.c
@@ -5456,7 +5456,10 @@ gfc_match_type_is (void)
c = gfc_get_case ();
c->where = gfc_current_locus;
- if (gfc_match_type_spec (&c->ts) == MATCH_ERROR)
+ m = gfc_match_type_spec (&c->ts);
+ if (m == MATCH_NO)
+ goto syntax;
+ if (m == MATCH_ERROR)
goto cleanup;
if (gfc_match_char (')') != MATCH_YES)
@@ -5536,7 +5539,10 @@ gfc_match_class_is (void)
c = gfc_get_case ();
c->where = gfc_current_locus;
- if (match_derived_type_spec (&c->ts) == MATCH_ERROR)
+ m = match_derived_type_spec (&c->ts);
+ if (m == MATCH_NO)
+ goto syntax;
+ if (m == MATCH_ERROR)
goto cleanup;
if (c->ts.type == BT_DERIVED)