annotate gcc/testsuite/ada/acats/tests/c9/c95086e.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 -- C95086E.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 -- CHECK THAT CONSTRAINT_ERROR IS NOT RAISED BEFORE OR AFTER THE ENTRY
kono
parents:
diff changeset
26 -- CALL FOR IN OUT ARRAY PARAMETERS, WHERE THE ACTUAL PARAMETER HAS THE
kono
parents:
diff changeset
27 -- FORM OF A TYPE CONVERSION. THE FOLLOWING CASES ARE TESTED:
kono
parents:
diff changeset
28 -- (A) OK CASE.
kono
parents:
diff changeset
29 -- (B) FORMAL CONSTRAINED, BOTH FORMAL AND ACTUAL HAVE SAME NUMBER
kono
parents:
diff changeset
30 -- COMPONENTS PER DIMENSION, BUT ACTUAL INDEX BOUNDS LIE OUTSIDE
kono
parents:
diff changeset
31 -- FORMAL INDEX SUBTYPE.
kono
parents:
diff changeset
32 -- (C) FORMAL CONSTRAINED, FORMAL AND ACTUAL HAVE DIFFERENT NUMBER
kono
parents:
diff changeset
33 -- COMPONENTS PER DIMENSION, BOTH FORMAL AND ACTUAL ARE NULL
kono
parents:
diff changeset
34 -- ARRAYS.
kono
parents:
diff changeset
35 -- (D) FORMAL CONSTRAINED, ACTUAL NULL, WITH INDEX BOUNDS OUTSIDE
kono
parents:
diff changeset
36 -- FORMAL INDEX SUBTYPE.
kono
parents:
diff changeset
37 -- (E) FORMAL UNCONSTRAINED, ACTUAL NULL, WITH INDEX BOUNDS OUTSIDE
kono
parents:
diff changeset
38 -- FORMAL INDEX SUBTYPE FOR NULL DIMENSIONS ONLY.
kono
parents:
diff changeset
39
kono
parents:
diff changeset
40 -- RJW 2/3/86
kono
parents:
diff changeset
41 -- TMB 11/15/95 ELIMINATED INCOMPATIBILITY WITH ADA95
kono
parents:
diff changeset
42 -- TMB 11/19/96 FIXED SLIDING PROBLEM IN SECTION D
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 WITH REPORT; USE REPORT;
kono
parents:
diff changeset
45 PROCEDURE C95086E IS
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 BEGIN
kono
parents:
diff changeset
48 TEST ("C95086E", "CHECK THAT CONSTRAINT_ERROR IS NOT RAISED " &
kono
parents:
diff changeset
49 "BEFORE OR AFTER THE ENTRY CALL FOR IN OUT ARRAY " &
kono
parents:
diff changeset
50 "PARAMETERS, WITH THE ACTUAL HAVING THE FORM OF A TYPE " &
kono
parents:
diff changeset
51 "CONVERSION");
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 ---------------------------------------------
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 DECLARE -- (A)
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 SUBTYPE INDEX IS INTEGER RANGE 1..5;
kono
parents:
diff changeset
58 TYPE ARRAY_TYPE IS ARRAY (INDEX RANGE <>, INDEX RANGE <>)
kono
parents:
diff changeset
59 OF BOOLEAN;
kono
parents:
diff changeset
60 SUBTYPE FORMAL IS ARRAY_TYPE (1..3, 1..3);
kono
parents:
diff changeset
61 SUBTYPE ACTUAL IS ARRAY_TYPE (1..3, 1..3);
kono
parents:
diff changeset
62 AR : ACTUAL := (1..3 => (1..3 => TRUE));
kono
parents:
diff changeset
63 CALLED : BOOLEAN := FALSE;
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 TASK T IS
kono
parents:
diff changeset
66 ENTRY E (X : IN OUT FORMAL);
kono
parents:
diff changeset
67 END T;
kono
parents:
diff changeset
68
kono
parents:
diff changeset
69 TASK BODY T IS
kono
parents:
diff changeset
70 BEGIN
kono
parents:
diff changeset
71 ACCEPT E (X : IN OUT FORMAL) DO
kono
parents:
diff changeset
72 CALLED := TRUE;
kono
parents:
diff changeset
73 END E;
kono
parents:
diff changeset
74 EXCEPTION
kono
parents:
diff changeset
75 WHEN OTHERS =>
kono
parents:
diff changeset
76 FAILED ("EXCEPTION RAISED IN TASK - (A)");
kono
parents:
diff changeset
77 END T;
kono
parents:
diff changeset
78
kono
parents:
diff changeset
79 BEGIN -- (A)
kono
parents:
diff changeset
80
kono
parents:
diff changeset
81 T.E (FORMAL (AR));
kono
parents:
diff changeset
82
kono
parents:
diff changeset
83 EXCEPTION
kono
parents:
diff changeset
84 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
85 IF NOT CALLED THEN
kono
parents:
diff changeset
86 FAILED ("EXCEPTION RAISED BEFORE CALL - (A)");
kono
parents:
diff changeset
87 ELSE
kono
parents:
diff changeset
88 FAILED ("EXCEPTION RAISED ON RETURN - (A)");
kono
parents:
diff changeset
89 END IF;
kono
parents:
diff changeset
90 WHEN OTHERS =>
kono
parents:
diff changeset
91 FAILED ("EXCEPTION RAISED - (A)");
kono
parents:
diff changeset
92 END; -- (A)
kono
parents:
diff changeset
93
kono
parents:
diff changeset
94 ---------------------------------------------
kono
parents:
diff changeset
95
kono
parents:
diff changeset
96 DECLARE -- (B)
kono
parents:
diff changeset
97
kono
parents:
diff changeset
98 SUBTYPE INDEX IS INTEGER RANGE 1..3;
kono
parents:
diff changeset
99 TYPE FORMAL IS ARRAY (INDEX, INDEX) OF BOOLEAN;
kono
parents:
diff changeset
100 TYPE ACTUAL IS ARRAY (3..5, 3..5) OF BOOLEAN;
kono
parents:
diff changeset
101 AR : ACTUAL := (3..5 => (3..5 => FALSE));
kono
parents:
diff changeset
102 CALLED : BOOLEAN := FALSE;
kono
parents:
diff changeset
103
kono
parents:
diff changeset
104 TASK T IS
kono
parents:
diff changeset
105 ENTRY E (X : IN OUT FORMAL);
kono
parents:
diff changeset
106 END T;
kono
parents:
diff changeset
107
kono
parents:
diff changeset
108 TASK BODY T IS
kono
parents:
diff changeset
109 BEGIN
kono
parents:
diff changeset
110 ACCEPT E (X : IN OUT FORMAL) DO
kono
parents:
diff changeset
111 CALLED := TRUE;
kono
parents:
diff changeset
112 X(3, 3) := TRUE;
kono
parents:
diff changeset
113 END E;
kono
parents:
diff changeset
114 EXCEPTION
kono
parents:
diff changeset
115 WHEN OTHERS =>
kono
parents:
diff changeset
116 FAILED ("EXCEPTION RAISED IN TASK - (B)");
kono
parents:
diff changeset
117 END T;
kono
parents:
diff changeset
118
kono
parents:
diff changeset
119 BEGIN -- (B)
kono
parents:
diff changeset
120
kono
parents:
diff changeset
121 T.E (FORMAL (AR));
kono
parents:
diff changeset
122 IF AR(5, 5) /= TRUE THEN
kono
parents:
diff changeset
123 FAILED ("INCORRECT RETURNED VALUE - (B)");
kono
parents:
diff changeset
124 END IF;
kono
parents:
diff changeset
125
kono
parents:
diff changeset
126 EXCEPTION
kono
parents:
diff changeset
127 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
128 IF NOT CALLED THEN
kono
parents:
diff changeset
129 FAILED ("EXCEPTION RAISED BEFORE CALL - (B)");
kono
parents:
diff changeset
130 ELSE
kono
parents:
diff changeset
131 FAILED ("EXCEPTION RAISED ON RETURN - (B)");
kono
parents:
diff changeset
132 END IF;
kono
parents:
diff changeset
133 WHEN OTHERS =>
kono
parents:
diff changeset
134 FAILED ("EXCEPTION RAISED - (B)");
kono
parents:
diff changeset
135 END; -- (B)
kono
parents:
diff changeset
136
kono
parents:
diff changeset
137 ---------------------------------------------
kono
parents:
diff changeset
138
kono
parents:
diff changeset
139 DECLARE -- (C)
kono
parents:
diff changeset
140
kono
parents:
diff changeset
141 SUBTYPE INDEX IS INTEGER RANGE 1..5;
kono
parents:
diff changeset
142 TYPE ARRAY_TYPE IS ARRAY (INDEX RANGE <>, INDEX RANGE <>)
kono
parents:
diff changeset
143 OF CHARACTER;
kono
parents:
diff changeset
144 SUBTYPE FORMAL IS ARRAY_TYPE (2..0, 1..3);
kono
parents:
diff changeset
145 AR : ARRAY_TYPE (2..1, 1..3) := (2..1 => (1..3 => ' '));
kono
parents:
diff changeset
146 CALLED : BOOLEAN := FALSE;
kono
parents:
diff changeset
147
kono
parents:
diff changeset
148 TASK T IS
kono
parents:
diff changeset
149 ENTRY E (X : IN OUT FORMAL);
kono
parents:
diff changeset
150 END T;
kono
parents:
diff changeset
151
kono
parents:
diff changeset
152 TASK BODY T IS
kono
parents:
diff changeset
153 BEGIN
kono
parents:
diff changeset
154 ACCEPT E (X : IN OUT FORMAL) DO
kono
parents:
diff changeset
155 IF X'LAST /= 0 AND X'LAST(2) /= 3 THEN
kono
parents:
diff changeset
156 FAILED ("WRONG BOUNDS PASSED - (C)");
kono
parents:
diff changeset
157 END IF;
kono
parents:
diff changeset
158 CALLED := TRUE;
kono
parents:
diff changeset
159 X := (2..0 => (1..3 => 'A'));
kono
parents:
diff changeset
160 END E;
kono
parents:
diff changeset
161 EXCEPTION
kono
parents:
diff changeset
162 WHEN OTHERS =>
kono
parents:
diff changeset
163 FAILED ("EXCEPTION RAISED IN TASK - (C)");
kono
parents:
diff changeset
164 END T;
kono
parents:
diff changeset
165
kono
parents:
diff changeset
166 BEGIN -- (C)
kono
parents:
diff changeset
167
kono
parents:
diff changeset
168 T.E (FORMAL (AR));
kono
parents:
diff changeset
169 IF AR'LAST /= 1 AND AR'LAST(2) /= 3 THEN
kono
parents:
diff changeset
170 FAILED ("BOUNDS CHANGED - (C)");
kono
parents:
diff changeset
171 END IF;
kono
parents:
diff changeset
172
kono
parents:
diff changeset
173 EXCEPTION
kono
parents:
diff changeset
174 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
175 IF NOT CALLED THEN
kono
parents:
diff changeset
176 FAILED ("EXCEPTION RAISED BEFORE CALL - (C)");
kono
parents:
diff changeset
177 ELSE
kono
parents:
diff changeset
178 FAILED ("EXCEPTION RAISED ON RETURN - (C)");
kono
parents:
diff changeset
179 END IF;
kono
parents:
diff changeset
180 WHEN OTHERS =>
kono
parents:
diff changeset
181 FAILED ("EXCEPTION RAISED - (C)");
kono
parents:
diff changeset
182 END; -- (C)
kono
parents:
diff changeset
183
kono
parents:
diff changeset
184 ---------------------------------------------
kono
parents:
diff changeset
185
kono
parents:
diff changeset
186 DECLARE -- (D)
kono
parents:
diff changeset
187
kono
parents:
diff changeset
188 SUBTYPE INDEX IS INTEGER RANGE 1..3;
kono
parents:
diff changeset
189 TYPE FORMAL IS ARRAY (INDEX RANGE 1..3, INDEX RANGE 3..1)
kono
parents:
diff changeset
190 OF CHARACTER;
kono
parents:
diff changeset
191 TYPE ACTUAL IS ARRAY (3..5, 5..3) OF CHARACTER;
kono
parents:
diff changeset
192 AR : ACTUAL := (3..5 => (5..3 => ' '));
kono
parents:
diff changeset
193 CALLED : BOOLEAN := FALSE;
kono
parents:
diff changeset
194
kono
parents:
diff changeset
195 TASK T IS
kono
parents:
diff changeset
196 ENTRY E (X : IN OUT FORMAL);
kono
parents:
diff changeset
197 END T;
kono
parents:
diff changeset
198
kono
parents:
diff changeset
199 TASK BODY T IS
kono
parents:
diff changeset
200 BEGIN
kono
parents:
diff changeset
201 ACCEPT E (X : IN OUT FORMAL) DO
kono
parents:
diff changeset
202 IF X'LAST /= 3 AND X'LAST(2) /= 1 THEN
kono
parents:
diff changeset
203 FAILED ("WRONG BOUNDS PASSED - (D)");
kono
parents:
diff changeset
204 END IF;
kono
parents:
diff changeset
205 CALLED := TRUE;
kono
parents:
diff changeset
206 X := (1..3 => (3..1 => 'A'));
kono
parents:
diff changeset
207 END E;
kono
parents:
diff changeset
208 EXCEPTION
kono
parents:
diff changeset
209 WHEN OTHERS =>
kono
parents:
diff changeset
210 FAILED ("EXCEPTION RAISED IN TASK - (D)");
kono
parents:
diff changeset
211 END T;
kono
parents:
diff changeset
212
kono
parents:
diff changeset
213 BEGIN -- (D)
kono
parents:
diff changeset
214
kono
parents:
diff changeset
215 T.E (FORMAL (AR));
kono
parents:
diff changeset
216 IF AR'LAST /= 5 AND AR'LAST(2) /= 3 THEN
kono
parents:
diff changeset
217 FAILED ("BOUNDS CHANGED - (D)");
kono
parents:
diff changeset
218 END IF;
kono
parents:
diff changeset
219
kono
parents:
diff changeset
220 EXCEPTION
kono
parents:
diff changeset
221 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
222 IF NOT CALLED THEN
kono
parents:
diff changeset
223 FAILED ("EXCEPTION RAISED BEFORE CALL - (D)");
kono
parents:
diff changeset
224 ELSE
kono
parents:
diff changeset
225 FAILED ("EXCEPTION RAISED ON RETURN - (D)");
kono
parents:
diff changeset
226 END IF;
kono
parents:
diff changeset
227 WHEN OTHERS =>
kono
parents:
diff changeset
228 FAILED ("EXCEPTION RAISED - (D)");
kono
parents:
diff changeset
229 END; -- (D)
kono
parents:
diff changeset
230
kono
parents:
diff changeset
231 ---------------------------------------------
kono
parents:
diff changeset
232
kono
parents:
diff changeset
233 DECLARE -- (E)
kono
parents:
diff changeset
234
kono
parents:
diff changeset
235 SUBTYPE INDEX IS INTEGER RANGE 1..3;
kono
parents:
diff changeset
236 TYPE FORMAL IS ARRAY (INDEX RANGE <>, INDEX RANGE <>)
kono
parents:
diff changeset
237 OF CHARACTER;
kono
parents:
diff changeset
238 TYPE ACTUAL IS ARRAY (POSITIVE RANGE 5..2,
kono
parents:
diff changeset
239 POSITIVE RANGE 1..3) OF CHARACTER;
kono
parents:
diff changeset
240 AR : ACTUAL := (5..2 => (1..3 => ' '));
kono
parents:
diff changeset
241 CALLED : BOOLEAN := FALSE;
kono
parents:
diff changeset
242
kono
parents:
diff changeset
243 TASK T IS
kono
parents:
diff changeset
244 ENTRY E (X : IN OUT FORMAL);
kono
parents:
diff changeset
245 END T;
kono
parents:
diff changeset
246
kono
parents:
diff changeset
247 TASK BODY T IS
kono
parents:
diff changeset
248 BEGIN
kono
parents:
diff changeset
249 ACCEPT E (X : IN OUT FORMAL) DO
kono
parents:
diff changeset
250 IF X'LAST /= 2 AND X'LAST(2) /= 3 THEN
kono
parents:
diff changeset
251 FAILED ("WRONG BOUNDS PASSED - (E)");
kono
parents:
diff changeset
252 END IF;
kono
parents:
diff changeset
253 CALLED := TRUE;
kono
parents:
diff changeset
254 X := (3..1 => (1..3 => ' '));
kono
parents:
diff changeset
255 END E;
kono
parents:
diff changeset
256 EXCEPTION
kono
parents:
diff changeset
257 WHEN OTHERS =>
kono
parents:
diff changeset
258 FAILED ("EXCEPTION RAISED IN TASK - (E)");
kono
parents:
diff changeset
259 END T;
kono
parents:
diff changeset
260
kono
parents:
diff changeset
261 BEGIN -- (E)
kono
parents:
diff changeset
262
kono
parents:
diff changeset
263 T.E (FORMAL (AR));
kono
parents:
diff changeset
264 IF AR'LAST /= 2 AND AR'LAST(2) /= 3 THEN
kono
parents:
diff changeset
265 FAILED ("BOUNDS CHANGED - (E)");
kono
parents:
diff changeset
266 END IF;
kono
parents:
diff changeset
267
kono
parents:
diff changeset
268 EXCEPTION
kono
parents:
diff changeset
269 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
270 IF NOT CALLED THEN
kono
parents:
diff changeset
271 FAILED ("EXCEPTION RAISED BEFORE CALL - (E)");
kono
parents:
diff changeset
272 ELSE
kono
parents:
diff changeset
273 FAILED ("EXCEPTION RAISED ON RETURN - (E)");
kono
parents:
diff changeset
274 END IF;
kono
parents:
diff changeset
275 WHEN OTHERS =>
kono
parents:
diff changeset
276 FAILED ("EXCEPTION RAISED - (E)");
kono
parents:
diff changeset
277 END; -- (E)
kono
parents:
diff changeset
278
kono
parents:
diff changeset
279 ---------------------------------------------
kono
parents:
diff changeset
280
kono
parents:
diff changeset
281 RESULT;
kono
parents:
diff changeset
282 END C95086E;