aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSteven G. Kargl <kargl@gcc.gnu.org>2018-01-10 23:26:15 +0000
committerSteven G. Kargl <kargl@gcc.gnu.org>2018-01-10 23:26:15 +0000
commitbdd82c9b9975a8bca850b99cd5cee75e6ed3c127 (patch)
treef4a5914f6c206ced8e44b8db873a905434bccc68
parent68dc87c3600fe0b6b629b45e5efc058c32b7bccc (diff)
downloadgcc-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
-rw-r--r--gcc/fortran/ChangeLog5
-rw-r--r--gcc/fortran/resolve.c9
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gfortran.dg/deferred_character_18.f9029
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