Blame SOURCES/0014-Fill-in-missing-array-dimensions-using-the-lower-bou.patch

ac4b94
From 60b2e0b9ad2057f256591f56d5433e9ca54bf56f Mon Sep 17 00:00:00 2001
ac4b94
From: Jim MacArthur <jim.macarthur@codethink.co.uk>
ac4b94
Date: Fri, 26 Aug 2016 17:46:05 +0100
ac4b94
Subject: [PATCH 14/16] Fill in missing array dimensions using the lower bound
ac4b94
ac4b94
Use -fdec-add-missing-indexes to enable feature. Also enabled by fdec.
ac4b94
---
ac4b94
 gcc/fortran/lang.opt                  |  8 ++++++++
ac4b94
 gcc/fortran/options.c                 |  1 +
ac4b94
 gcc/fortran/resolve.c                 | 24 ++++++++++++++++++++++++
ac4b94
 gcc/testsuite/gfortran.dg/array_6.f90 | 23 +++++++++++++++++++++++
ac4b94
 gcc/testsuite/gfortran.dg/array_7.f90 | 23 +++++++++++++++++++++++
ac4b94
 gcc/testsuite/gfortran.dg/array_8.f90 | 23 +++++++++++++++++++++++
ac4b94
 6 files changed, 102 insertions(+)
ac4b94
 create mode 100644 gcc/testsuite/gfortran.dg/array_6.f90
ac4b94
 create mode 100644 gcc/testsuite/gfortran.dg/array_7.f90
ac4b94
 create mode 100644 gcc/testsuite/gfortran.dg/array_8.f90
ac4b94
ac4b94
diff --git a/gcc/fortran/lang.opt b/gcc/fortran/lang.opt
ac4b94
index ffd9ce6f270..dca3fd27aa3 100644
ac4b94
--- a/gcc/fortran/lang.opt
ac4b94
+++ b/gcc/fortran/lang.opt
ac4b94
@@ -281,6 +281,10 @@ Wmissing-include-dirs
ac4b94
 Fortran
ac4b94
 ; Documented in C/C++
ac4b94
 
ac4b94
+Wmissing-index
ac4b94
+Fortran Var(warn_missing_index) Warning LangEnabledBy(Fortran,Wall)
ac4b94
+Warn that the lower bound of a missing index will be used.
ac4b94
+
ac4b94
 Wuse-without-only
ac4b94
 Fortran Var(warn_use_without_only) Warning
ac4b94
 Warn about USE statements that have no ONLY qualifier.
ac4b94
@@ -440,6 +444,10 @@ fdec
ac4b94
 Fortran Var(flag_dec)
ac4b94
 Enable all DEC language extensions.
ac4b94
 
ac4b94
+fdec-add-missing-indexes
ac4b94
+Fortran Var(flag_dec_add_missing_indexes)
ac4b94
+Enable the addition of missing indexes using their lower bounds.
ac4b94
+
ac4b94
 fdec-blank-format-item
ac4b94
 Fortran Var(flag_dec_blank_format_item)
ac4b94
 Enable the use of blank format items in format strings.
ac4b94
diff --git a/gcc/fortran/options.c b/gcc/fortran/options.c
ac4b94
index b6fd327d057..f417f48f6a7 100644
ac4b94
--- a/gcc/fortran/options.c
ac4b94
+++ b/gcc/fortran/options.c
ac4b94
@@ -85,6 +85,7 @@ set_dec_flags (int value)
ac4b94
   SET_BITFLAG (flag_dec_non_logical_if, value, value);
ac4b94
   SET_BITFLAG (flag_dec_promotion, value, value);
ac4b94
   SET_BITFLAG (flag_dec_sequence, value, value);
ac4b94
+  SET_BITFLAG (flag_dec_add_missing_indexes, value, value);
ac4b94
 }
ac4b94
 
ac4b94
 /* Finalize DEC flags.  */
ac4b94
diff --git a/gcc/fortran/resolve.c b/gcc/fortran/resolve.c
ac4b94
index 08627866c9c..70093c952f6 100644
ac4b94
--- a/gcc/fortran/resolve.c
ac4b94
+++ b/gcc/fortran/resolve.c
ac4b94
@@ -4676,6 +4676,30 @@ compare_spec_to_ref (gfc_array_ref *ar)
ac4b94
   if (ar->type == AR_FULL)
ac4b94
     return true;
ac4b94
 
ac4b94
+  if (flag_dec_add_missing_indexes && as->rank > ar->dimen)
ac4b94
+    {
ac4b94
+      /* Add in the missing dimensions, assuming they are the lower bound
ac4b94
+         of that dimension if not specified.  */
ac4b94
+      int j;
ac4b94
+      if (warn_missing_index)
ac4b94
+	{
ac4b94
+          gfc_warning (OPT_Wmissing_index, "Using the lower bound for "
ac4b94
+		       "unspecified dimensions in array reference at %L",
ac4b94
+		       &ar->where);
ac4b94
+	}
ac4b94
+      /* Other parts of the code iterate ar->start and ar->end from 0 to
ac4b94
+	 ar->dimen, so it is safe to assume slots from ar->dimen upwards
ac4b94
+	 are unused (i.e. there are no gaps; the specified indexes are
ac4b94
+	 contiguous and start at zero.  */
ac4b94
+      for(j = ar->dimen; j <= as->rank; j++)
ac4b94
+        {
ac4b94
+	  ar->start[j] = gfc_copy_expr (as->lower[j]);
ac4b94
+	  ar->end[j]   = gfc_copy_expr (as->lower[j]);
ac4b94
+	  ar->dimen_type[j] = DIMEN_ELEMENT;
ac4b94
+        }
ac4b94
+      ar->dimen = as->rank;
ac4b94
+    }
ac4b94
+
ac4b94
   if (as->rank != ar->dimen)
ac4b94
     {
ac4b94
       gfc_error ("Rank mismatch in array reference at %L (%d/%d)",
ac4b94
diff --git a/gcc/testsuite/gfortran.dg/array_6.f90 b/gcc/testsuite/gfortran.dg/array_6.f90
ac4b94
new file mode 100644
ac4b94
index 00000000000..5c26e18ab3e
ac4b94
--- /dev/null
ac4b94
+++ b/gcc/testsuite/gfortran.dg/array_6.f90
ac4b94
@@ -0,0 +1,23 @@
ac4b94
+! { dg-do run }
ac4b94
+! { dg-options "-fdec -Wmissing-index" }!
ac4b94
+! Checks that under-specified arrays (referencing arrays with fewer
ac4b94
+! dimensions than the array spec) generates a warning.
ac4b94
+!
ac4b94
+! Contributed by Jim MacArthur <jim.macarthur@codethink.co.uk>
ac4b94
+! Updated by Mark Eggleston <mark.eggleston@codethink.co.uk>
ac4b94
+!
ac4b94
+
ac4b94
+program under_specified_array
ac4b94
+    integer chessboard(8,8)
ac4b94
+    integer chessboard3d(8,8,3:5)
ac4b94
+    chessboard(3,1) = 5
ac4b94
+    chessboard(3,2) = 55
ac4b94
+    chessboard3d(4,1,3) = 6
ac4b94
+    chessboard3d(4,1,4) = 66
ac4b94
+    chessboard3d(4,4,3) = 7
ac4b94
+    chessboard3d(4,4,4) = 77
ac4b94
+  
ac4b94
+    if (chessboard(3).ne.5) stop 1  ! { dg-warning "Using the lower bound for unspecified dimensions in array reference" }
ac4b94
+    if (chessboard3d(4).ne.6) stop 2  ! { dg-warning "Using the lower bound for unspecified dimensions in array reference" }
ac4b94
+    if (chessboard3d(4,4).ne.7) stop 3  ! { dg-warning "Using the lower bound for unspecified dimensions in array reference" }
ac4b94
+end program
ac4b94
diff --git a/gcc/testsuite/gfortran.dg/array_7.f90 b/gcc/testsuite/gfortran.dg/array_7.f90
ac4b94
new file mode 100644
ac4b94
index 00000000000..5588a5bd02d
ac4b94
--- /dev/null
ac4b94
+++ b/gcc/testsuite/gfortran.dg/array_7.f90
ac4b94
@@ -0,0 +1,23 @@
ac4b94
+! { dg-do run }
ac4b94
+! { dg-options "-fdec-add-missing-indexes -Wmissing-index" }!
ac4b94
+! Checks that under-specified arrays (referencing arrays with fewer
ac4b94
+! dimensions than the array spec) generates a warning.
ac4b94
+!
ac4b94
+! Contributed by Jim MacArthur <jim.macarthur@codethink.co.uk>
ac4b94
+! Updated by Mark Eggleston <mark.eggleston@codethink.co.uk>
ac4b94
+!
ac4b94
+
ac4b94
+program under_specified_array
ac4b94
+    integer chessboard(8,8)
ac4b94
+    integer chessboard3d(8,8,3:5)
ac4b94
+    chessboard(3,1) = 5
ac4b94
+    chessboard(3,2) = 55
ac4b94
+    chessboard3d(4,1,3) = 6
ac4b94
+    chessboard3d(4,1,4) = 66
ac4b94
+    chessboard3d(4,4,3) = 7
ac4b94
+    chessboard3d(4,4,4) = 77
ac4b94
+  
ac4b94
+    if (chessboard(3).ne.5) stop 1  ! { dg-warning "Using the lower bound for unspecified dimensions in array reference" }
ac4b94
+    if (chessboard3d(4).ne.6) stop 2  ! { dg-warning "Using the lower bound for unspecified dimensions in array reference" }
ac4b94
+    if (chessboard3d(4,4).ne.7) stop 3  ! { dg-warning "Using the lower bound for unspecified dimensions in array reference" }
ac4b94
+end program
ac4b94
diff --git a/gcc/testsuite/gfortran.dg/array_8.f90 b/gcc/testsuite/gfortran.dg/array_8.f90
ac4b94
new file mode 100644
ac4b94
index 00000000000..f0d2ef5e37d
ac4b94
--- /dev/null
ac4b94
+++ b/gcc/testsuite/gfortran.dg/array_8.f90
ac4b94
@@ -0,0 +1,23 @@
ac4b94
+! { dg-do compile }
ac4b94
+! { dg-options "-fdec -fno-dec-add-missing-indexes" }!
ac4b94
+! Checks that under-specified arrays (referencing arrays with fewer
ac4b94
+! dimensions than the array spec) generates a warning.
ac4b94
+!
ac4b94
+! Contributed by Jim MacArthur <jim.macarthur@codethink.co.uk>
ac4b94
+! Updated by Mark Eggleston <mark.eggleston@codethink.co.uk>
ac4b94
+!
ac4b94
+
ac4b94
+program under_specified_array
ac4b94
+    integer chessboard(8,8)
ac4b94
+    integer chessboard3d(8,8,3:5)
ac4b94
+    chessboard(3,1) = 5
ac4b94
+    chessboard(3,2) = 55
ac4b94
+    chessboard3d(4,1,3) = 6
ac4b94
+    chessboard3d(4,1,4) = 66
ac4b94
+    chessboard3d(4,4,3) = 7
ac4b94
+    chessboard3d(4,4,4) = 77
ac4b94
+  
ac4b94
+    if (chessboard(3).ne.5) stop 1  ! { dg-error "Rank mismatch" }
ac4b94
+    if (chessboard3d(4).ne.6) stop 2  ! { dg-error "Rank mismatch" }
ac4b94
+    if (chessboard3d(4,4).ne.7) stop 3  ! { dg-error "Rank mismatch" }
ac4b94
+end program
ac4b94
-- 
ac4b94
2.11.0
ac4b94