annotate gcc/testsuite/ada/acats/tests/c3/c37213l.ada @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 -- C37213L.ADA
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 -- Grant of Unlimited Rights
kono
parents:
diff changeset
4 --
kono
parents:
diff changeset
5 -- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
kono
parents:
diff changeset
6 -- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
kono
parents:
diff changeset
7 -- unlimited rights in the software and documentation contained herein.
kono
parents:
diff changeset
8 -- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
kono
parents:
diff changeset
9 -- this public release, the Government intends to confer upon all
kono
parents:
diff changeset
10 -- recipients unlimited rights equal to those held by the Government.
kono
parents:
diff changeset
11 -- These rights include rights to use, duplicate, release or disclose the
kono
parents:
diff changeset
12 -- released technical data and computer software in whole or in part, in
kono
parents:
diff changeset
13 -- any manner and for any purpose whatsoever, and to have or permit others
kono
parents:
diff changeset
14 -- to do so.
kono
parents:
diff changeset
15 --
kono
parents:
diff changeset
16 -- DISCLAIMER
kono
parents:
diff changeset
17 --
kono
parents:
diff changeset
18 -- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
kono
parents:
diff changeset
19 -- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
kono
parents:
diff changeset
20 -- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
kono
parents:
diff changeset
21 -- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
kono
parents:
diff changeset
22 -- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
kono
parents:
diff changeset
23 -- PARTICULAR PURPOSE OF SAID MATERIAL.
kono
parents:
diff changeset
24 --*
kono
parents:
diff changeset
25 -- OBJECTIVE:
kono
parents:
diff changeset
26 -- CHECK, FOR A GENERIC FORMAL TYPE - WHERE A DISCRIMINANT OR AN
kono
parents:
diff changeset
27 -- INDEX CONSTRAINT DEPENDS ON A RECORD DISCRIMINANT AND THE
kono
parents:
diff changeset
28 -- RECORD TYPE IS CONSTRAINED BY DEFAULT - USED TO DECLARE A
kono
parents:
diff changeset
29 -- DERIVED OR AN ACCESS TYPE, THAT THE NON-DISCRIMINANT EXPRESSIONS
kono
parents:
diff changeset
30 -- OF THE CONSTRAINT ARE CHECKED FOR COMPATIBILITY:
kono
parents:
diff changeset
31 -- 1) ONLY IN AN OBJECT DECLARATION OR ALLOCATOR, AND
kono
parents:
diff changeset
32 -- 2) ONLY IF THE DISCRIMINANT-DEPENDENT COMPONENT IS PRESENT
kono
parents:
diff changeset
33 -- IN THE SUBTYPE.
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 -- HISTORY:
kono
parents:
diff changeset
36 -- VCL 10/23/88 CREATED ORIGINAL TEST BY SPLITTING FROM C37213J.
kono
parents:
diff changeset
37 -- VCL 03/30/88 MODIFIED THE TEST DISCRIPTION TO MORE ACCURATELY
kono
parents:
diff changeset
38 -- DESCRIBE THE OBJECTIVE; CHANGED THE FORMAL
kono
parents:
diff changeset
39 -- PARAMETERS TO THE GENERIC UNITS AND THE
kono
parents:
diff changeset
40 -- CORRESPONDING ACTUAL PARAMETERS; REORGANIZED THE
kono
parents:
diff changeset
41 -- TEST SO THAT ALL OPERATIONS ON A SPECIFIC TYPE
kono
parents:
diff changeset
42 -- ARE TOGETHER; REWROTE ONE OF THE GENERIC
kono
parents:
diff changeset
43 -- PACKAGES AS A GENERIC PROCEDURE TO BROADEN
kono
parents:
diff changeset
44 -- COVERAGE OF TEST.
kono
parents:
diff changeset
45
kono
parents:
diff changeset
46 WITH REPORT; USE REPORT;
kono
parents:
diff changeset
47 PROCEDURE C37213L IS
kono
parents:
diff changeset
48 BEGIN
kono
parents:
diff changeset
49 TEST ("C37213L", "THE NON-DISCRIMINANT VALUES OF A DISCRIMINANT " &
kono
parents:
diff changeset
50 "OR AN INDEX CONSTRAINT THAT DEPEND ON A " &
kono
parents:
diff changeset
51 "DISCRIMINANT ARE PROPERLY CHECKED WHEN THE " &
kono
parents:
diff changeset
52 "RECORD TYPE IS CONSTRAINED BY DEFAULT AND " &
kono
parents:
diff changeset
53 "USED AS THE ACTUAL PARAMETER TO A GENERIC " &
kono
parents:
diff changeset
54 "FORMAL TYPE USED TO DECLARE A DERIVED OR AN " &
kono
parents:
diff changeset
55 "ACCESS TYPE");
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 DECLARE
kono
parents:
diff changeset
58 SUBTYPE SM IS INTEGER RANGE 1..10;
kono
parents:
diff changeset
59 TYPE REC (D1, D2 : SM) IS
kono
parents:
diff changeset
60 RECORD NULL; END RECORD;
kono
parents:
diff changeset
61 TYPE MY_ARR IS ARRAY (SM RANGE <>) OF INTEGER;
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 SEQUENCE_NUMBER : INTEGER;
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 GENERIC
kono
parents:
diff changeset
66 TYPE CONS IS PRIVATE;
kono
parents:
diff changeset
67 OBJ_XCP : BOOLEAN;
kono
parents:
diff changeset
68 TAG : STRING;
kono
parents:
diff changeset
69 PACKAGE DER_CHK IS END DER_CHK;
kono
parents:
diff changeset
70
kono
parents:
diff changeset
71 PACKAGE BODY DER_CHK IS
kono
parents:
diff changeset
72 BEGIN
kono
parents:
diff changeset
73 DECLARE
kono
parents:
diff changeset
74 TYPE DREC IS NEW CONS;
kono
parents:
diff changeset
75 BEGIN
kono
parents:
diff changeset
76 DECLARE
kono
parents:
diff changeset
77 X : DREC;
kono
parents:
diff changeset
78
kono
parents:
diff changeset
79 FUNCTION VALUE RETURN DREC IS
kono
parents:
diff changeset
80 BEGIN
kono
parents:
diff changeset
81 IF EQUAL (3,3) THEN
kono
parents:
diff changeset
82 RETURN X;
kono
parents:
diff changeset
83 ELSE
kono
parents:
diff changeset
84 RETURN X;
kono
parents:
diff changeset
85 END IF;
kono
parents:
diff changeset
86 END VALUE;
kono
parents:
diff changeset
87 BEGIN
kono
parents:
diff changeset
88 IF OBJ_XCP THEN
kono
parents:
diff changeset
89 FAILED ("NO CHECK DURING DECLARATION " &
kono
parents:
diff changeset
90 "OF OBJECT OF TYPE DREC - " &
kono
parents:
diff changeset
91 TAG);
kono
parents:
diff changeset
92 ELSIF X /= VALUE THEN
kono
parents:
diff changeset
93 FAILED ("INCORRECT VALUE FOR OBJECT OF " &
kono
parents:
diff changeset
94 "TYPE DREC - " & TAG);
kono
parents:
diff changeset
95 END IF;
kono
parents:
diff changeset
96 END;
kono
parents:
diff changeset
97 EXCEPTION
kono
parents:
diff changeset
98 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
99 IF NOT OBJ_XCP THEN
kono
parents:
diff changeset
100 FAILED ("IMPROPER CONSTRAINT CHECKED " &
kono
parents:
diff changeset
101 "DURING DECLARATION OF OBJECT " &
kono
parents:
diff changeset
102 "OF TYPE DREC - " & TAG);
kono
parents:
diff changeset
103 END IF;
kono
parents:
diff changeset
104 END;
kono
parents:
diff changeset
105 EXCEPTION
kono
parents:
diff changeset
106 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
107 FAILED ("CONSTRAINT IMPROPERLY CHECKED " &
kono
parents:
diff changeset
108 "DURING DECLARATION OF DREC - " & TAG);
kono
parents:
diff changeset
109 END;
kono
parents:
diff changeset
110
kono
parents:
diff changeset
111 GENERIC
kono
parents:
diff changeset
112 TYPE CONS IS PRIVATE;
kono
parents:
diff changeset
113 PROCEDURE ACC_CHK (OBJ_XCP : BOOLEAN;
kono
parents:
diff changeset
114 TAG : STRING);
kono
parents:
diff changeset
115
kono
parents:
diff changeset
116 PROCEDURE ACC_CHK (OBJ_XCP : BOOLEAN;
kono
parents:
diff changeset
117 TAG : STRING) IS
kono
parents:
diff changeset
118 BEGIN
kono
parents:
diff changeset
119 DECLARE
kono
parents:
diff changeset
120 TYPE ACC_CONS IS ACCESS CONS;
kono
parents:
diff changeset
121 BEGIN
kono
parents:
diff changeset
122 DECLARE
kono
parents:
diff changeset
123 X : ACC_CONS;
kono
parents:
diff changeset
124
kono
parents:
diff changeset
125 FUNCTION VALUE RETURN CONS IS
kono
parents:
diff changeset
126 BEGIN
kono
parents:
diff changeset
127 IF EQUAL (5, 5) THEN
kono
parents:
diff changeset
128 RETURN X.ALL;
kono
parents:
diff changeset
129 ELSE
kono
parents:
diff changeset
130 RETURN X.ALL;
kono
parents:
diff changeset
131 END IF;
kono
parents:
diff changeset
132 END VALUE;
kono
parents:
diff changeset
133 BEGIN
kono
parents:
diff changeset
134 X := NEW CONS;
kono
parents:
diff changeset
135
kono
parents:
diff changeset
136 IF OBJ_XCP THEN
kono
parents:
diff changeset
137 FAILED ("NO CHECK DURING ALLOCATION " &
kono
parents:
diff changeset
138 "OF OBJECT OF TYPE CONS - " &
kono
parents:
diff changeset
139 TAG);
kono
parents:
diff changeset
140 ELSIF X.ALL /= VALUE THEN
kono
parents:
diff changeset
141 FAILED ("INCORRECT VALUE FOR OBJECT " &
kono
parents:
diff changeset
142 "OF TYPE CONS - " & TAG);
kono
parents:
diff changeset
143 END IF;
kono
parents:
diff changeset
144 EXCEPTION
kono
parents:
diff changeset
145 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
146 IF NOT OBJ_XCP THEN
kono
parents:
diff changeset
147 FAILED ("IMPROPER CONSTRAINT " &
kono
parents:
diff changeset
148 "CHECKED DURING " &
kono
parents:
diff changeset
149 "ALLOCATION OF OBJECT " &
kono
parents:
diff changeset
150 "OF TYPE CONS - " & TAG);
kono
parents:
diff changeset
151 END IF;
kono
parents:
diff changeset
152 END;
kono
parents:
diff changeset
153 EXCEPTION
kono
parents:
diff changeset
154 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
155 FAILED ("CONSTRAINT IMPROPERLY CHECKED " &
kono
parents:
diff changeset
156 "DURING DECLARATION OF X - " & TAG);
kono
parents:
diff changeset
157 END;
kono
parents:
diff changeset
158 EXCEPTION
kono
parents:
diff changeset
159 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
160 FAILED ("CONSTRAINT IMPROPERLY CHECKED " &
kono
parents:
diff changeset
161 "DURING DECLARATION OF ACC_CONS - " & TAG);
kono
parents:
diff changeset
162 END ACC_CHK;
kono
parents:
diff changeset
163 BEGIN
kono
parents:
diff changeset
164 SEQUENCE_NUMBER := 1;
kono
parents:
diff changeset
165 DECLARE
kono
parents:
diff changeset
166 TYPE REC_DEF (D3 : INTEGER := 1) IS
kono
parents:
diff changeset
167 RECORD
kono
parents:
diff changeset
168 C1 : REC (D3, 0);
kono
parents:
diff changeset
169 END RECORD;
kono
parents:
diff changeset
170
kono
parents:
diff changeset
171 PACKAGE PACK1 IS NEW DER_CHK (REC_DEF,
kono
parents:
diff changeset
172 OBJ_XCP => TRUE,
kono
parents:
diff changeset
173 TAG => "PACK1");
kono
parents:
diff changeset
174
kono
parents:
diff changeset
175 PROCEDURE PROC1 IS NEW ACC_CHK (REC_DEF);
kono
parents:
diff changeset
176 BEGIN
kono
parents:
diff changeset
177 PROC1 (OBJ_XCP => TRUE, TAG => "PROC1");
kono
parents:
diff changeset
178 END;
kono
parents:
diff changeset
179
kono
parents:
diff changeset
180 SEQUENCE_NUMBER := 2;
kono
parents:
diff changeset
181 DECLARE
kono
parents:
diff changeset
182 TYPE ARR_DEF (D3 : INTEGER := IDENT_INT(1)) IS
kono
parents:
diff changeset
183 RECORD
kono
parents:
diff changeset
184 C1 : MY_ARR (0..D3);
kono
parents:
diff changeset
185 END RECORD;
kono
parents:
diff changeset
186
kono
parents:
diff changeset
187 PACKAGE PACK2 IS NEW DER_CHK (ARR_DEF,
kono
parents:
diff changeset
188 OBJ_XCP => TRUE,
kono
parents:
diff changeset
189 TAG => "PACK2");
kono
parents:
diff changeset
190
kono
parents:
diff changeset
191 PROCEDURE PROC2 IS NEW ACC_CHK (ARR_DEF);
kono
parents:
diff changeset
192 BEGIN
kono
parents:
diff changeset
193 PROC2 (OBJ_XCP => TRUE, TAG => "PROC2");
kono
parents:
diff changeset
194 END;
kono
parents:
diff changeset
195
kono
parents:
diff changeset
196 SEQUENCE_NUMBER := 3;
kono
parents:
diff changeset
197 DECLARE
kono
parents:
diff changeset
198 TYPE VAR_REC_DEF1 (D3 : INTEGER := 1) IS
kono
parents:
diff changeset
199 RECORD
kono
parents:
diff changeset
200 CASE D3 IS
kono
parents:
diff changeset
201 WHEN -5..10 =>
kono
parents:
diff changeset
202 C1 : REC (D3, IDENT_INT(11));
kono
parents:
diff changeset
203 WHEN OTHERS =>
kono
parents:
diff changeset
204 C2 : INTEGER := IDENT_INT(5);
kono
parents:
diff changeset
205 END CASE;
kono
parents:
diff changeset
206 END RECORD;
kono
parents:
diff changeset
207
kono
parents:
diff changeset
208 PACKAGE PACK3 IS NEW DER_CHK (VAR_REC_DEF1,
kono
parents:
diff changeset
209 OBJ_XCP => TRUE,
kono
parents:
diff changeset
210 TAG => "PACK3");
kono
parents:
diff changeset
211
kono
parents:
diff changeset
212 PROCEDURE PROC3 IS NEW ACC_CHK (VAR_REC_DEF1);
kono
parents:
diff changeset
213 BEGIN
kono
parents:
diff changeset
214 PROC3 (OBJ_XCP => TRUE, TAG => "PROC3");
kono
parents:
diff changeset
215 END;
kono
parents:
diff changeset
216
kono
parents:
diff changeset
217 SEQUENCE_NUMBER := 4;
kono
parents:
diff changeset
218 DECLARE
kono
parents:
diff changeset
219 TYPE VAR_REC_DEF6 (D3 : INTEGER := IDENT_INT(-6)) IS
kono
parents:
diff changeset
220 RECORD
kono
parents:
diff changeset
221 CASE D3 IS
kono
parents:
diff changeset
222 WHEN -5..10 =>
kono
parents:
diff changeset
223 C1 : REC (D3, IDENT_INT(11));
kono
parents:
diff changeset
224 WHEN OTHERS =>
kono
parents:
diff changeset
225 C2 : INTEGER := IDENT_INT(5);
kono
parents:
diff changeset
226 END CASE;
kono
parents:
diff changeset
227 END RECORD;
kono
parents:
diff changeset
228
kono
parents:
diff changeset
229 PACKAGE PACK4 IS NEW DER_CHK (VAR_REC_DEF6,
kono
parents:
diff changeset
230 OBJ_XCP => FALSE,
kono
parents:
diff changeset
231 TAG => "PACK4");
kono
parents:
diff changeset
232
kono
parents:
diff changeset
233 PROCEDURE PROC4 IS NEW ACC_CHK (VAR_REC_DEF6);
kono
parents:
diff changeset
234 BEGIN
kono
parents:
diff changeset
235 PROC4 (OBJ_XCP => FALSE, TAG => "PROC4");
kono
parents:
diff changeset
236 END;
kono
parents:
diff changeset
237
kono
parents:
diff changeset
238 SEQUENCE_NUMBER := 5;
kono
parents:
diff changeset
239 DECLARE
kono
parents:
diff changeset
240 TYPE VAR_REC_DEF11 (D3 : INTEGER := 11) IS
kono
parents:
diff changeset
241 RECORD
kono
parents:
diff changeset
242 CASE D3 IS
kono
parents:
diff changeset
243 WHEN -5..10 =>
kono
parents:
diff changeset
244 C1 : REC (D3, IDENT_INT(11));
kono
parents:
diff changeset
245 WHEN OTHERS =>
kono
parents:
diff changeset
246 C2 : INTEGER := IDENT_INT(5);
kono
parents:
diff changeset
247 END CASE;
kono
parents:
diff changeset
248 END RECORD;
kono
parents:
diff changeset
249
kono
parents:
diff changeset
250 PACKAGE PACK5 IS NEW DER_CHK (VAR_REC_DEF11,
kono
parents:
diff changeset
251 OBJ_XCP => FALSE,
kono
parents:
diff changeset
252 TAG => "PACK5");
kono
parents:
diff changeset
253
kono
parents:
diff changeset
254 PROCEDURE PROC5 IS NEW ACC_CHK (VAR_REC_DEF11);
kono
parents:
diff changeset
255 BEGIN
kono
parents:
diff changeset
256 PROC5 (OBJ_XCP => FALSE, TAG => "PROC5");
kono
parents:
diff changeset
257 END;
kono
parents:
diff changeset
258
kono
parents:
diff changeset
259 SEQUENCE_NUMBER := 6;
kono
parents:
diff changeset
260 DECLARE
kono
parents:
diff changeset
261 TYPE VAR_ARR_DEF1 (D3 : INTEGER := IDENT_INT(1)) IS
kono
parents:
diff changeset
262 RECORD
kono
parents:
diff changeset
263 CASE D3 IS
kono
parents:
diff changeset
264 WHEN -5..10 =>
kono
parents:
diff changeset
265 C1 : MY_ARR(D3..IDENT_INT(11));
kono
parents:
diff changeset
266 WHEN OTHERS =>
kono
parents:
diff changeset
267 C2 : INTEGER := IDENT_INT(5);
kono
parents:
diff changeset
268 END CASE;
kono
parents:
diff changeset
269 END RECORD;
kono
parents:
diff changeset
270
kono
parents:
diff changeset
271 PACKAGE PACK6 IS NEW DER_CHK (VAR_ARR_DEF1,
kono
parents:
diff changeset
272 OBJ_XCP => TRUE,
kono
parents:
diff changeset
273 TAG => "PACK6");
kono
parents:
diff changeset
274
kono
parents:
diff changeset
275 PROCEDURE PROC6 IS NEW ACC_CHK (VAR_ARR_DEF1);
kono
parents:
diff changeset
276 BEGIN
kono
parents:
diff changeset
277 PROC6 (OBJ_XCP => TRUE, TAG => "PROC6");
kono
parents:
diff changeset
278 END;
kono
parents:
diff changeset
279
kono
parents:
diff changeset
280 SEQUENCE_NUMBER := 7;
kono
parents:
diff changeset
281 DECLARE
kono
parents:
diff changeset
282 TYPE VAR_ARR_DEF6 (D3 : INTEGER := -6) IS
kono
parents:
diff changeset
283 RECORD
kono
parents:
diff changeset
284 CASE D3 IS
kono
parents:
diff changeset
285 WHEN -5..10 =>
kono
parents:
diff changeset
286 C1 : MY_ARR(D3..IDENT_INT(11));
kono
parents:
diff changeset
287 WHEN OTHERS =>
kono
parents:
diff changeset
288 C2 : INTEGER := IDENT_INT(5);
kono
parents:
diff changeset
289 END CASE;
kono
parents:
diff changeset
290 END RECORD;
kono
parents:
diff changeset
291
kono
parents:
diff changeset
292 PACKAGE PACK7 IS NEW DER_CHK (VAR_ARR_DEF6,
kono
parents:
diff changeset
293 OBJ_XCP => FALSE,
kono
parents:
diff changeset
294 TAG => "PACK7");
kono
parents:
diff changeset
295
kono
parents:
diff changeset
296 PROCEDURE PROC7 IS NEW ACC_CHK (VAR_ARR_DEF6);
kono
parents:
diff changeset
297 BEGIN
kono
parents:
diff changeset
298 PROC7 (OBJ_XCP => FALSE, TAG => "PROC7");
kono
parents:
diff changeset
299 END;
kono
parents:
diff changeset
300
kono
parents:
diff changeset
301 SEQUENCE_NUMBER := 8;
kono
parents:
diff changeset
302 DECLARE
kono
parents:
diff changeset
303 TYPE VAR_ARR_DEF11 (D3 : INTEGER := IDENT_INT(11)) IS
kono
parents:
diff changeset
304 RECORD
kono
parents:
diff changeset
305 CASE D3 IS
kono
parents:
diff changeset
306 WHEN -5..10 =>
kono
parents:
diff changeset
307 C1 : MY_ARR(D3..IDENT_INT(11));
kono
parents:
diff changeset
308 WHEN OTHERS =>
kono
parents:
diff changeset
309 C2 : INTEGER := IDENT_INT(5);
kono
parents:
diff changeset
310 END CASE;
kono
parents:
diff changeset
311 END RECORD;
kono
parents:
diff changeset
312
kono
parents:
diff changeset
313 PACKAGE PACK8 IS NEW DER_CHK (VAR_ARR_DEF11,
kono
parents:
diff changeset
314 OBJ_XCP => FALSE,
kono
parents:
diff changeset
315 TAG => "PACK8");
kono
parents:
diff changeset
316
kono
parents:
diff changeset
317 PROCEDURE PROC8 IS NEW ACC_CHK (VAR_ARR_DEF11);
kono
parents:
diff changeset
318 BEGIN
kono
parents:
diff changeset
319 PROC8 (OBJ_XCP => FALSE, TAG => "PROC8");
kono
parents:
diff changeset
320 END;
kono
parents:
diff changeset
321 EXCEPTION
kono
parents:
diff changeset
322 WHEN OTHERS =>
kono
parents:
diff changeset
323 FAILED ("UNEXPECTED EXCEPTION RAISED DURING " &
kono
parents:
diff changeset
324 "DECLARATION / INSTANTIATION ELABORATION - " &
kono
parents:
diff changeset
325 INTEGER'IMAGE (SEQUENCE_NUMBER));
kono
parents:
diff changeset
326 END;
kono
parents:
diff changeset
327
kono
parents:
diff changeset
328 RESULT;
kono
parents:
diff changeset
329 END C37213L;