decl.c (Gigi_Equivalent_Type): New case.
authorEric Botcazou <ebotcazou@adacore.com>
Fri, 11 Oct 2019 08:33:03 +0000 (08:33 +0000)
committerEric Botcazou <ebotcazou@gcc.gnu.org>
Fri, 11 Oct 2019 08:33:03 +0000 (08:33 +0000)
* gcc-interface/decl.c (Gigi_Equivalent_Type) <E_Array_Subtype>: New
case.  Return the base type if the subtype is not constrained.

From-SVN: r276865

gcc/ada/ChangeLog
gcc/ada/gcc-interface/decl.c
gcc/testsuite/ChangeLog
gcc/testsuite/gnat.dg/array38.adb [new file with mode: 0644]
gcc/testsuite/gnat.dg/array38_pkg.adb [new file with mode: 0644]
gcc/testsuite/gnat.dg/array38_pkg.ads [new file with mode: 0644]

index 896efda0e88b75e5bef682351e4b365719c54780..8e11108c4fc526423ec942b1660b7305eacd7505 100644 (file)
@@ -1,3 +1,8 @@
+2019-10-11  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * gcc-interface/decl.c (Gigi_Equivalent_Type) <E_Array_Subtype>: New
+       case.  Return the base type if the subtype is not constrained.
+
 2019-10-11  Eric Botcazou  <ebotcazou@adacore.com>
 
        * gcc-interface/decl.c (gnat_to_gnu_entity) <E_Named_{Integer|Real}>:
index 4878f5e3f9f5ef1a352af0103ddb30508d8decd5..25298241ebacc7d30ef1da876483372526646074 100644 (file)
@@ -5026,6 +5026,11 @@ Gigi_Equivalent_Type (Entity_Id gnat_entity)
       gnat_equiv = Etype (gnat_entity);
       break;
 
+    case E_Array_Subtype:
+      if (!Is_Constrained (gnat_entity))
+       gnat_equiv = Etype (gnat_entity);
+      break;
+
     case E_Class_Wide_Type:
       gnat_equiv = Root_Type (gnat_entity);
       break;
index 0f55eecfff46c815a4447558c1b8616e7f54927b..612b22b9243c7935398ea0a8481eeeb8e6882b0c 100644 (file)
@@ -1,3 +1,8 @@
+2019-10-11  Eric Botcazou  <ebotcazou@adacore.com>
+
+       * gnat.dg/array38.adb: New test.
+       * gnat.dg/array38_pkg.ad[sb]: New helper.
+
 2019-10-11  Jakub Jelinek  <jakub@redhat.com>
 
        PR c++/91987
diff --git a/gcc/testsuite/gnat.dg/array38.adb b/gcc/testsuite/gnat.dg/array38.adb
new file mode 100644 (file)
index 0000000..fe37b65
--- /dev/null
@@ -0,0 +1,11 @@
+-- { dg-do compile }
+
+with Array38_Pkg; use Array38_Pkg;
+
+procedure Array38 is
+
+  function My_F is new F (Index, Byte, Bytes, Integer);
+
+begin
+  null;
+end;
diff --git a/gcc/testsuite/gnat.dg/array38_pkg.adb b/gcc/testsuite/gnat.dg/array38_pkg.adb
new file mode 100644 (file)
index 0000000..ebaa66e
--- /dev/null
@@ -0,0 +1,8 @@
+package body Array38_Pkg is
+
+   function F (Data : Array_Type) return Value_Type is
+   begin
+      return Value_Type'First;
+   end;
+
+end Array38_Pkg;
diff --git a/gcc/testsuite/gnat.dg/array38_pkg.ads b/gcc/testsuite/gnat.dg/array38_pkg.ads
new file mode 100644 (file)
index 0000000..17c3ef4
--- /dev/null
@@ -0,0 +1,18 @@
+package Array38_Pkg is
+
+   type Byte is mod 2**8;
+
+   type Length is new Natural;
+   subtype Index is Length range 1 .. Length'Last;
+
+   type Bytes is array (Index range <>) of Byte with
+     Predicate => Bytes'Length > 0;
+
+   generic
+      type Index_Type   is (<>);
+      type Element_Type is (<>);
+      type Array_Type   is array (Index_Type range <>) of Element_Type;
+      type Value_Type   is (<>);
+   function F (Data : Array_Type) return Value_Type;
+
+end Array38_Pkg;