From b21a544bb1a94f29adc4fc812cda0766b9a048e9 Mon Sep 17 00:00:00 2001 From: Janus Weil Date: Tue, 19 Jul 2011 14:38:59 +0200 Subject: [PATCH] re PR fortran/49708 (ICE with allocate and no dimensions) 2011-07-19 Janus Weil PR fortran/49708 * resolve.c (resolve_allocate_expr): Fix diagnostics for pointers. 2011-07-19 Janus Weil PR fortran/49708 * gfortran.dg/allocate_error_3.f90: New. From-SVN: r176447 --- gcc/fortran/ChangeLog | 5 +++++ gcc/fortran/resolve.c | 2 +- gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/gfortran.dg/allocate_error_3.f90 | 9 +++++++++ 4 files changed, 20 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/gfortran.dg/allocate_error_3.f90 diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index a469ac9aa57..5d8cc6476c1 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,8 @@ +2011-07-19 Janus Weil + + PR fortran/49708 + * resolve.c (resolve_allocate_expr): Fix diagnostics for pointers. + 2011-07-18 Tobias Burnus * trans-decl.c (gfc_build_qualified_array): Make coarray's diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c index 53f45e85b8d..71e0ba062f5 100644 --- a/gcc/fortran/resolve.c +++ b/gcc/fortran/resolve.c @@ -6886,7 +6886,7 @@ resolve_allocate_expr (gfc_expr *e, gfc_code *code) gfc_find_derived_vtab (ts.u.derived); } - if (pointer || (dimension == 0 && codimension == 0)) + if (dimension == 0 && codimension == 0) goto success; /* Make sure the last reference node is an array specifiction. */ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index d87ce8d7464..4e77decb5b4 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2011-07-19 Janus Weil + + PR fortran/49708 + * gfortran.dg/allocate_error_3.f90: New. + 2011-07-19 Richard Guenther * gcc.dg/tree-ssa/bool-10.c: Adjust expected pattern. diff --git a/gcc/testsuite/gfortran.dg/allocate_error_3.f90 b/gcc/testsuite/gfortran.dg/allocate_error_3.f90 new file mode 100644 index 00000000000..7616caad380 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/allocate_error_3.f90 @@ -0,0 +1,9 @@ +! { dg-do compile } +! +! PR 49708: [4.5/4.6/4.7 Regression] ICE with allocate and no dimensions +! +! Contributed by + + real, pointer :: x(:) + allocate(x) ! { dg-error "Array specification required" } +end -- 2.30.2