diff options
author | Steven G. Kargl <kargl@gcc.gnu.org> | 2015-06-08 15:55:16 +0000 |
---|---|---|
committer | Steven G. Kargl <kargl@gcc.gnu.org> | 2015-06-08 15:55:16 +0000 |
commit | ef701bbe50402a6b44f73bc3913ac8c85b1d5b9e (patch) | |
tree | fd6d439ac0a513dbb2abe336673638a486ae4437 /gcc/fortran/match.c | |
parent | a1661b90dcbaed222e647bda75540e8a87f250ed (diff) | |
download | gcc-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.c | 10 |
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) |