]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
2016-04-09 Jerry DeLisle <jvdelisle@gcc.gnu.org>
authorjvdelisle <jvdelisle@138bc75d-0d04-0410-961f-82ee72b054a4>
Sat, 9 Apr 2016 19:09:02 +0000 (19:09 +0000)
committerjvdelisle <jvdelisle@138bc75d-0d04-0410-961f-82ee72b054a4>
Sat, 9 Apr 2016 19:09:02 +0000 (19:09 +0000)
PR fortran/68566
* array.c (match_array_element_spec): Add check for non-integer.
* simplify.c (gfc_simplify_reshape): If source shape is NULL return.

PR fortran/68566
* gfortran.dg/pr36192.f90: Update test.
* gfortran.dg/pr36192_1.f90: Update test.
* gfortran.dg/real_dimension_1.f: Update test.
* gfortran.dg/parameter_array_init_7.f90: New test.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@234864 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/fortran/ChangeLog
gcc/fortran/array.c
gcc/fortran/simplify.c
gcc/testsuite/ChangeLog
gcc/testsuite/gfortran.dg/parameter_array_init_7.f90 [new file with mode: 0644]
gcc/testsuite/gfortran.dg/pr36192.f90
gcc/testsuite/gfortran.dg/pr36192_1.f90
gcc/testsuite/gfortran.dg/real_dimension_1.f

index c300145af478100703f2a560b629ce34b6641403..961167b01292cd857e7f4a6f52ad122826fe69b2 100644 (file)
@@ -1,3 +1,9 @@
+2016-04-09  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
+
+       PR fortran/68566
+       * array.c (match_array_element_spec): Add check for non-integer.
+       * simplify.c (gfc_simplify_reshape): If source shape is NULL return.
+
 2016-04-06  Patrick Palka  <ppalka@gcc.gnu.org>
 
        PR c/70436
index 2fc9dfaffdbdef28ba658ee08b818598b75c78a5..1430e80251d66368dabadefec905279710ad0c9e 100644 (file)
@@ -421,10 +421,15 @@ match_array_element_spec (gfc_array_spec *as)
   if (!gfc_expr_check_typed (*upper, gfc_current_ns, false))
     return AS_UNKNOWN;
 
-  if ((*upper)->expr_type == EXPR_FUNCTION && (*upper)->ts.type == BT_UNKNOWN
-      && (*upper)->symtree && strcmp ((*upper)->symtree->name, "null") == 0)
-    {
-      gfc_error ("Expecting a scalar INTEGER expression at %C");
+  if (((*upper)->expr_type == EXPR_CONSTANT
+       && (*upper)->ts.type != BT_INTEGER) ||
+      ((*upper)->expr_type == EXPR_FUNCTION
+       && (*upper)->ts.type == BT_UNKNOWN
+       && (*upper)->symtree
+       && strcmp ((*upper)->symtree->name, "null") == 0))
+    {
+      gfc_error ("Expecting a scalar INTEGER expression at %C, found %s",
+                gfc_basic_typename ((*upper)->ts.type));
       return AS_UNKNOWN;
     }
 
@@ -448,10 +453,15 @@ match_array_element_spec (gfc_array_spec *as)
   if (!gfc_expr_check_typed (*upper, gfc_current_ns, false))
     return AS_UNKNOWN;
 
-  if ((*upper)->expr_type == EXPR_FUNCTION && (*upper)->ts.type == BT_UNKNOWN
-      && (*upper)->symtree && strcmp ((*upper)->symtree->name, "null") == 0)
+  if (((*upper)->expr_type == EXPR_CONSTANT
+       && (*upper)->ts.type != BT_INTEGER) ||
+      ((*upper)->expr_type == EXPR_FUNCTION
+       && (*upper)->ts.type == BT_UNKNOWN
+       && (*upper)->symtree
+       && strcmp ((*upper)->symtree->name, "null") == 0))
     {
-      gfc_error ("Expecting a scalar INTEGER expression at %C");
+      gfc_error ("Expecting a scalar INTEGER expression at %C, found %s",
+                gfc_basic_typename ((*upper)->ts.type));
       return AS_UNKNOWN;
     }
 
index 12a8f32ea01d68e9e174c40b1c049da51670fceb..a63101072f1389ab72d59a32d6dc217a51daa000 100644 (file)
@@ -5163,6 +5163,9 @@ gfc_simplify_reshape (gfc_expr *source, gfc_expr *shape_exp,
       || !is_constant_array_expr (order_exp))
     return NULL;
 
+  if (source->shape == NULL)
+    return NULL;
+
   /* Proceed with simplification, unpacking the array.  */
 
   mpz_init (index);
index 3d2537b2e040a111b2aa8587b9360f51db620ee5..9784a4b6f054d1e4a194e827a873613e58b53d9e 100644 (file)
@@ -1,3 +1,11 @@
+2016-04-09  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
+
+       PR fortran/68566
+       * gfortran.dg/pr36192.f90: Update test.
+       * gfortran.dg/pr36192_1.f90: Update test.
+       * gfortran.dg/real_dimension_1.f: Update test.
+       * gfortran.dg/parameter_array_init_7.f90: New test.
+
 2016-04-09  John David Anglin  <danglin@gcc.gnu.org>
 
        PR testsuite/64039
diff --git a/gcc/testsuite/gfortran.dg/parameter_array_init_7.f90 b/gcc/testsuite/gfortran.dg/parameter_array_init_7.f90
new file mode 100644 (file)
index 0000000..890da35
--- /dev/null
@@ -0,0 +1,8 @@
+! { dg-do compile }
+! PR68566  ICE on using unusable array in reshape
+program p
+   integer, parameter :: n = 2
+   integer, parameter :: a(:) = 0  !{ dg-error "automatic or of deferred shape" }
+   integer, parameter :: b(n, n) = reshape([a, 1+a], [n, n])
+end
+
index df3bfd75f2434d94c9f0526ebb47a38e7e718f4e..ebf95e35bfecad138eaca38bb9f1a499bf8ae540 100644 (file)
@@ -3,7 +3,6 @@
 !
 program three_body
   real, parameter :: n = 2, d = 2
-  real, dimension(n,d) :: x      ! { dg-error "of INTEGER type|of INTEGER type" }
-  x(1,:) = (/ 1.0, 0.0 /)
+  real, dimension(n,d) :: x  ! { dg-error "Expecting a scalar INTEGER" }
+  x(1,:) = (/ 1.0, 0.0 /)    ! { dg-error "Unclassifiable" }
 end program three_body
-! { dg-prune-output "have constant shape" }
index 77df31765ac8b6626e9b625f409834a3f5c9e9c9..687a465f8c08e63ce97487afc7f780dcfd309ae7 100644 (file)
@@ -2,11 +2,11 @@
 ! PR fortran/36192
 program three_body
    real, parameter ::  n = 2, d = 2
-   real, dimension(n,d) :: x_hq ! { dg-error "of INTEGER type|of INTEGER type" }
+   real, dimension(n,d) :: x_hq ! { dg-error "Expecting a scalar INTEGER" }
    call step(x_hq)
    contains
    subroutine step(x)
       real, dimension(:,:), intent(in) :: x
    end subroutine step
 end program three_body
-! { dg-prune-output "must have constant shape" }
+! { dg-prune-output "Rank mismatch in argument" }
index 73e9131aaee49bb355d825b17e234eb7bc293925..3dd1a5afc36334b3df124835f076894e82add3a8 100644 (file)
@@ -1,7 +1,7 @@
 ! { dg-do compile }
-! PR 34305 - make sure there's an error message for specifying a
+! PR 34305 - Test for specifying a real as dimension
       program test
-      parameter (datasize = 1000) 
-      dimension idata (datasize)  ! { dg-error "must be of INTEGER type|must have constant shape" }
-      idata (1) = -1
+      real , parameter :: dsize = 1000
+      dimension idata (dsize) ! { dg-error "scalar INTEGER expression" }
+      idata (1) = -1    ! { dg-error "must have the pointer attribute" }
       end