Remove old autovect-branch by moving to "dead" directory.
[official-gcc.git] / old-autovect-branch / gcc / testsuite / ada / acats / tests / c4 / c43204c.ada
blob1db9f7f179e3af39602c8bd9071dcc5fe724380e
1 -- C43204C.ADA
3 -- Grant of Unlimited Rights
4 --
5 -- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
6 -- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
7 -- unlimited rights in the software and documentation contained herein.
8 -- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
9 -- this public release, the Government intends to confer upon all
10 -- recipients unlimited rights equal to those held by the Government.
11 -- These rights include rights to use, duplicate, release or disclose the
12 -- released technical data and computer software in whole or in part, in
13 -- any manner and for any purpose whatsoever, and to have or permit others
14 -- to do so.
16 -- DISCLAIMER
18 -- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
19 -- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
20 -- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
21 -- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
22 -- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
23 -- PARTICULAR PURPOSE OF SAID MATERIAL.
24 --*
25 -- OBJECTIVE:
26 -- CHECK THAT AN ARRAY AGGREGATE WITH AN OTHERS CHOICE CAN APPEAR
27 -- (AND BOUNDS ARE DETERMINED CORRECTLY) AS AN ACTUAL PARAMETER OF
28 -- A GENERIC INSTANTIATION WHEN THE GENERIC FORMAL PARAMETER IS
29 -- CONSTRAINED.
31 -- HISTORY:
32 -- JET 08/15/88 CREATED ORIGINAL TEST.
34 WITH REPORT; USE REPORT;
35 PROCEDURE C43204C IS
37 TYPE ARR10 IS ARRAY(IDENT_INT(1)..IDENT_INT(0)) OF INTEGER;
38 TYPE ARR11 IS ARRAY(INTEGER RANGE -3..3) OF INTEGER;
39 TYPE ARR12 IS ARRAY(IDENT_INT(-3)..IDENT_INT(3)) OF INTEGER;
41 TYPE ARR20 IS ARRAY(IDENT_INT(1)..IDENT_INT(0),
42 IDENT_INT(0)..IDENT_INT(-1)) OF INTEGER;
43 TYPE ARR21 IS ARRAY(INTEGER RANGE -1..1,
44 INTEGER RANGE -1..1) OF INTEGER;
45 TYPE ARR22 IS ARRAY(IDENT_INT(-1)..IDENT_INT(1),
46 IDENT_INT(-1)..IDENT_INT(1)) OF INTEGER;
47 TYPE ARR23 IS ARRAY(INTEGER'(-1)..1,
48 IDENT_INT(-1)..IDENT_INT(1)) OF INTEGER;
50 GENERIC
51 A : ARR10;
52 PROCEDURE GPROC10;
54 GENERIC
55 A : ARR11;
56 PROCEDURE GPROC11;
58 GENERIC
59 A : ARR12;
60 PROCEDURE GPROC12;
62 GENERIC
63 A : ARR20;
64 PROCEDURE GPROC20;
66 GENERIC
67 A : ARR21;
68 PROCEDURE GPROC21 (C : INTEGER);
70 GENERIC
71 A : ARR22;
72 PROCEDURE GPROC22;
74 GENERIC
75 A : ARR23;
76 PROCEDURE GPROC23;
78 PROCEDURE GPROC10 IS
79 BEGIN
80 IF A'LENGTH /= IDENT_INT(0) THEN
81 FAILED ("PROC10 ARRAY IS NOT NULL");
82 END IF;
83 END GPROC10;
85 PROCEDURE GPROC11 IS
86 BEGIN
87 IF A'LENGTH /= IDENT_INT(7) OR
88 A'FIRST /= IDENT_INT(-3) OR
89 A'LAST /= IDENT_INT(3) THEN
90 FAILED ("INCORRECT LENGTH IN PROC11");
91 END IF;
93 FOR I IN IDENT_INT(-3)..IDENT_INT(3) LOOP
94 IF IDENT_INT(A(I)) /= 1 THEN
95 FAILED ("INCORRECT VALUE OF COMPONENT " &
96 INTEGER'IMAGE(I) & ", PROC11");
97 END IF;
98 END LOOP;
99 END GPROC11;
101 PROCEDURE GPROC12 IS
102 BEGIN
103 IF A'LENGTH /= IDENT_INT(7) THEN
104 FAILED ("INCORRECT LENGTH IN PROC12");
105 END IF;
107 FOR I IN IDENT_INT(-3)..IDENT_INT(3) LOOP
108 IF IDENT_INT(A(I)) /= 2 THEN
109 FAILED ("INCORRECT VALUE OF COMPONENT " &
110 INTEGER'IMAGE(I) & ", PROC12");
111 END IF;
112 END LOOP;
113 END GPROC12;
115 PROCEDURE GPROC20 IS
116 BEGIN
117 IF A'LENGTH(1) /= IDENT_INT(0) OR
118 A'LENGTH(2) /= IDENT_INT(0) THEN
119 FAILED ("GPROC20 ARRAY IS NOT NULL");
120 END IF;
121 END GPROC20;
123 PROCEDURE GPROC21 (C : INTEGER) IS
124 BEGIN
125 FOR I IN INTEGER'(-1)..1 LOOP
126 FOR J IN INTEGER'(-1)..1 LOOP
127 IF IDENT_INT(A(I,J)) /= C THEN
128 FAILED ("INCORRECT VALUE OF COMPONENT (" &
129 INTEGER'IMAGE(I) & "," &
130 INTEGER'IMAGE(J) & "), GPROC21 CALL " &
131 "NUMBER" & INTEGER'IMAGE(C));
132 END IF;
133 END LOOP;
134 END LOOP;
135 END GPROC21;
137 PROCEDURE GPROC22 IS
138 BEGIN
139 FOR I IN INTEGER'(-1)..1 LOOP
140 FOR J IN INTEGER'(-1)..1 LOOP
141 IF IDENT_INT(A(I,J)) /= 3 THEN
142 FAILED ("INCORRECT VALUE OF COMPONENT (" &
143 INTEGER'IMAGE(I) & "," &
144 INTEGER'IMAGE(J) & "), GPROC22");
145 END IF;
146 END LOOP;
147 END LOOP;
148 END GPROC22;
150 PROCEDURE GPROC23 IS
151 BEGIN
152 FOR I IN INTEGER'(-1)..1 LOOP
153 FOR J IN INTEGER'(-1)..1 LOOP
154 IF IDENT_INT(A(I,J)) /= 4 THEN
155 FAILED ("INCORRECT VALUE OF COMPONENT (" &
156 INTEGER'IMAGE(I) & "," &
157 INTEGER'IMAGE(J) & "), GPROC23");
158 END IF;
159 END LOOP;
160 END LOOP;
161 END GPROC23;
163 PROCEDURE PROC11 IS NEW GPROC11((1,1,1, OTHERS => 1));
164 PROCEDURE PROC12 IS NEW GPROC12((OTHERS => 2));
165 PROCEDURE PROC10 IS NEW GPROC10((OTHERS => 3));
167 PROCEDURE PROC21 IS NEW GPROC21(((1,1,1), OTHERS => (1,1,1)));
168 PROCEDURE PROC22 IS NEW GPROC21(((2,OTHERS => 2), (2,OTHERS => 2),
169 (2,2,OTHERS => 2)));
170 PROCEDURE PROC23 IS NEW GPROC22((OTHERS => (OTHERS => 3)));
171 PROCEDURE PROC24 IS NEW GPROC23((OTHERS => (4,4,4)));
172 PROCEDURE PROC20 IS NEW GPROC20((OTHERS => (OTHERS => 5)));
174 BEGIN
175 TEST ("C43204C", "CHECK THAT AN ARRAY AGGREGATE WITH AN OTHERS " &
176 "CHOICE CAN APPEAR (AND BOUNDS ARE DETERMINED " &
177 "CORRECTLY) AS AN ACTUAL PARAMETER OF A " &
178 "SUBPROGRAM CALL WHEN THE FORMAL PARAMETER IS " &
179 "CONSTRAINED");
181 PROC11;
182 PROC12;
183 PROC10;
185 PROC21(1);
186 PROC22(2);
187 PROC23;
188 PROC24;
189 PROC20;
191 RESULT;
192 END C43204C;