From: Steven G. Kargl Date: Fri, 25 May 2018 19:45:57 +0000 (+0000) Subject: re PR fortran/85779 (ICE in gfc_typename, at fortran/misc.c:156) X-Git-Tag: releases/gcc-6.5.0~304 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=ec2d7c500a71f4c9c28c43654556531726bea928;p=thirdparty%2Fgcc.git re PR fortran/85779 (ICE in gfc_typename, at fortran/misc.c:156) 2018-05-25 Steven G. Kargl PR fortran/85779 Backport from trunk * decl.c (gfc_match_derived_decl): Fix NULL pointer dereference. 2018-05-25 Steven G. Kargl PR fortran/85779 Backport from trunk * gfortran.dg/pr85779_1.f90: New test. * gfortran.dg/pr85779_2.f90: Ditto. * gfortran.dg/pr85779_3.f90: Ditto. From-SVN: r260776 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index caffbd21a157..116750cc641d 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2018-05-25 Steven G. Kargl + + PR fortran/85779 + Backport from trunk + * decl.c (gfc_match_derived_decl): Fix NULL pointer dereference. + 2018-05-25 Steven G. Kargl PR fortran/85543 diff --git a/gcc/fortran/decl.c b/gcc/fortran/decl.c index 917b89f0a482..139f083589be 100644 --- a/gcc/fortran/decl.c +++ b/gcc/fortran/decl.c @@ -8755,8 +8755,12 @@ gfc_match_derived_decl (void) if (!gensym->attr.generic && gensym->ts.type != BT_UNKNOWN) { - gfc_error ("Derived type name %qs at %C already has a basic type " - "of %s", gensym->name, gfc_typename (&gensym->ts)); + if (gensym->ts.u.derived) + gfc_error ("Derived type name %qs at %C already has a basic type " + "of %s", gensym->name, gfc_typename (&gensym->ts)); + else + gfc_error ("Derived type name %qs at %C already has a basic type", + gensym->name); return MATCH_ERROR; } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index d15a73cc2033..e80ae13e58e6 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,11 @@ +2018-05-25 Steven G. Kargl + + PR fortran/85779 + Backport from trunk + * gfortran.dg/pr85779_1.f90: New test. + * gfortran.dg/pr85779_2.f90: Ditto. + * gfortran.dg/pr85779_3.f90: Ditto. + 2018-05-25 Steven G. Kargl PR fortran/85543 diff --git a/gcc/testsuite/gfortran.dg/pr85779_1.f90 b/gcc/testsuite/gfortran.dg/pr85779_1.f90 new file mode 100644 index 000000000000..186568ff1249 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/pr85779_1.f90 @@ -0,0 +1,6 @@ +! { dg-do compile } +! PR fortran/85779 +type(t) function f() ! { dg-error "is not accessible" } + type f ! { dg-error "already has a basic type" } + end type ! { dg-error "END FUNCTION statement" } +end diff --git a/gcc/testsuite/gfortran.dg/pr85779_2.f90 b/gcc/testsuite/gfortran.dg/pr85779_2.f90 new file mode 100644 index 000000000000..4cc3c62979c0 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/pr85779_2.f90 @@ -0,0 +1,7 @@ +! { dg-do compile } +! PR fortran/85779 +type(t) function f() result(z) ! { dg-error "is not accessible" } + type z ! { dg-error "already has a basic type" } + end type ! { dg-error "END FUNCTION statement" } +end + diff --git a/gcc/testsuite/gfortran.dg/pr85779_3.f90 b/gcc/testsuite/gfortran.dg/pr85779_3.f90 new file mode 100644 index 000000000000..fba1133b3ea7 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/pr85779_3.f90 @@ -0,0 +1,7 @@ +! { dg-do compile } +! PR fortran/85779 +class(t) function f() ! { dg-error "must be dummy, allocatable or pointer" } + type f ! { dg-error "already has a basic type" } + end type ! { dg-error "END FUNCTION statement" } +end +