diff options
author | Steven G. Kargl <kargl@gcc.gnu.org> | 2018-01-10 23:26:15 +0000 |
---|---|---|
committer | Steven G. Kargl <kargl@gcc.gnu.org> | 2018-01-10 23:26:15 +0000 |
commit | bdd82c9b9975a8bca850b99cd5cee75e6ed3c127 (patch) | |
tree | f4a5914f6c206ced8e44b8db873a905434bccc68 /gcc | |
parent | 68dc87c3600fe0b6b629b45e5efc058c32b7bccc (diff) | |
download | gcc-bdd82c9b9975a8bca850b99cd5cee75e6ed3c127.zip gcc-bdd82c9b9975a8bca850b99cd5cee75e6ed3c127.tar.gz gcc-bdd82c9b9975a8bca850b99cd5cee75e6ed3c127.tar.bz2 |
re PR fortran/82367 (ICE with deferred length string allocate on non-deferred length argument)
2018-01-10 Steven G. Kargl <kargl@gcc.gnu.org>
PR fortran/82367
* resolve.c (resolve_allocate_expr): Check for NULL pointer.
2018-01-10 Steven G. Kargl <kargl@gcc.gnu.org>
PR fortran/82367
* gfortran.dg/deferred_character_18.f90: New test.
From-SVN: r256464
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/fortran/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/fortran/resolve.c | 9 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/deferred_character_18.f90 | 29 |
4 files changed, 46 insertions, 2 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 6bad1a6..f428934 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,5 +1,10 @@ 2018-01-10 Steven G. Kargl <kargl@gcc.gnu.org> + PR fortran/82367 + * resolve.c (resolve_allocate_expr): Check for NULL pointer. + +2018-01-10 Steven G. Kargl <kargl@gcc.gnu.org> + PR fortran/83093 * resolve.c (resolve_charlen): Check the type of cl->length after resolution. diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c index 1950483..e9f91d8 100644 --- a/gcc/fortran/resolve.c +++ b/gcc/fortran/resolve.c @@ -7484,8 +7484,13 @@ resolve_allocate_expr (gfc_expr *e, gfc_code *code, bool *array_alloc_wo_spec) if (code->ext.alloc.ts.type == BT_CHARACTER && !e->ts.deferred && !UNLIMITED_POLY (e)) { - int cmp = gfc_dep_compare_expr (e->ts.u.cl->length, - code->ext.alloc.ts.u.cl->length); + int cmp; + + if (!e->ts.u.cl->length) + goto failure; + + cmp = gfc_dep_compare_expr (e->ts.u.cl->length, + code->ext.alloc.ts.u.cl->length); if (cmp == 1 || cmp == -1 || cmp == -3) { gfc_error ("Allocating %s at %L with type-spec requires the same " diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 10273a9..4ac9461 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2018-01-10 Steven G. Kargl <kargl@gcc.gnu.org> + + PR fortran/82367 + * gfortran.dg/deferred_character_18.f90: New test. + 2018-01-10 Martin Sebor <msebor@redhat.com> PR tree-optimization/83671 diff --git a/gcc/testsuite/gfortran.dg/deferred_character_18.f90 b/gcc/testsuite/gfortran.dg/deferred_character_18.f90 new file mode 100644 index 0000000..1b1457f --- /dev/null +++ b/gcc/testsuite/gfortran.dg/deferred_character_18.f90 @@ -0,0 +1,29 @@ +! { dg-do compile } +! PR Fortran/82367 +! Contributed by Walter Spector <w6ws at earthlink dot net> +module cls_allocmod + implicit none + +contains + + subroutine cls_alloc (n, str) + integer, intent(in) :: n + character(*), allocatable, intent(out) :: str +! Note: Star ^ should have been a colon (:) + + allocate (character(n)::str) + + end subroutine + +end module + +program cls + use cls_allocmod + implicit none + + character(:), allocatable :: s + + call cls_alloc(42, s) ! { dg-error "allocatable or pointer dummy argument" } + print *, 'string len =', len(s) + +end program |