aboutsummaryrefslogtreecommitdiff
path: root/gdb/testsuite/gdb.ada/arrayidx/p.adb
diff options
context:
space:
mode:
authorJoel Brobecker <brobecker@gnat.com>2005-10-10 01:14:36 +0000
committerJoel Brobecker <brobecker@gnat.com>2005-10-10 01:14:36 +0000
commit2336bb5846e37f77a40ab8d3f565c8c7bd6b05f7 (patch)
tree0e19950eb47d46df5eacbe8f23f136e5ac503a39 /gdb/testsuite/gdb.ada/arrayidx/p.adb
parent1495de3fd3a10998220fcba6e31c6a5002bb4271 (diff)
downloadbinutils-2336bb5846e37f77a40ab8d3f565c8c7bd6b05f7.zip
binutils-2336bb5846e37f77a40ab8d3f565c8c7bd6b05f7.tar.gz
binutils-2336bb5846e37f77a40ab8d3f565c8c7bd6b05f7.tar.bz2
* gdb.ada/arrayidx/p.adb: New file.
* gdb.ada/arrayidx.exp: New testcase
Diffstat (limited to 'gdb/testsuite/gdb.ada/arrayidx/p.adb')
-rw-r--r--gdb/testsuite/gdb.ada/arrayidx/p.adb56
1 files changed, 56 insertions, 0 deletions
diff --git a/gdb/testsuite/gdb.ada/arrayidx/p.adb b/gdb/testsuite/gdb.ada/arrayidx/p.adb
new file mode 100644
index 0000000..398e34d
--- /dev/null
+++ b/gdb/testsuite/gdb.ada/arrayidx/p.adb
@@ -0,0 +1,56 @@
+-- Copyright 2005 Free Software Foundation, Inc.
+--
+-- This program is free software; you can redistribute it and/or modify
+-- it under the terms of the GNU General Public License as published by
+-- the Free Software Foundation; either version 2 of the License, or
+-- (at your option) any later version.
+--
+-- This program is distributed in the hope that it will be useful,
+-- but WITHOUT ANY WARRANTY; without even the implied warranty of
+-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+-- GNU General Public License for more details.
+--
+-- You should have received a copy of the GNU General Public License
+-- along with this program; if not, write to the Free Software
+-- Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
+-- MA 02110-1301, USA
+
+procedure P is
+ type Index is (One, Two, Three);
+
+ type Table is array (Integer range 1 .. 3) of Integer;
+ type ETable is array (Index) of Integer;
+ type RTable is array (Index range Two .. Three) of Integer;
+ type UTable is array (Positive range <>) of Integer;
+
+ type PTable is array (Index) of Boolean;
+ pragma Pack (PTable);
+
+ function Get_UTable (I : Integer) return UTable is
+ begin
+ return Utable'(1 => I, 2 => 2, 3 => 3);
+ end Get_UTable;
+
+ One_Two_Three : Table := (1, 2, 3);
+ E_One_Two_Three : ETable := (1, 2, 3);
+ R_Two_Three : RTable := (2, 3);
+ U_One_Two_Three : UTable := Get_UTable (1);
+ P_One_Two_Three : PTable := (False, True, True);
+
+ Few_Reps : UTable := (1, 2, 3, 3, 3, 3, 3, 4, 5);
+ Many_Reps : UTable := (1, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 4, 5);
+
+ Empty : array (1 .. 0) of Integer := (others => 0);
+
+begin
+ One_Two_Three (1) := 4; -- START
+ E_One_Two_Three (One) := 4;
+ R_Two_Three (Two) := 4;
+ U_One_Two_Three (U_One_Two_Three'First) := 4;
+ P_One_Two_Three (One) := True;
+
+ Few_Reps (Few_Reps'First) := 2;
+ Many_Reps (Many_Reps'First) := 2;
+
+ Empty := (others => 1);
+end P;