annotate gcc/testsuite/ada/acats/tests/c9/c95086c.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 -- C95086C.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 FOR ACCESS PARAMETERS
kono
parents:
diff changeset
26 -- AFTER THE ENTRY CALL, WHEN AN IN OUT OR OUT FORMAL
kono
parents:
diff changeset
27 -- ACCESS VALUE IS NULL, AND THE ACTUAL PARAMETER HAS
kono
parents:
diff changeset
28 -- DIFFERENT CONSTRAINTS.
kono
parents:
diff changeset
29 --
kono
parents:
diff changeset
30 -- SUBTESTS ARE:
kono
parents:
diff changeset
31 -- (A) IN OUT MODE, STATIC PRIVATE DISCRIMINANT.
kono
parents:
diff changeset
32 -- (B) OUT MODE, DYNAMIC TWO DIMENSIONAL BOUNDS.
kono
parents:
diff changeset
33 -- (C) SAME AS (A), WITH TYPE CONVERSION.
kono
parents:
diff changeset
34 -- (D) SAME AS (B), WITH TYPE CONVERSION.
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 -- RJW 1/29/86
kono
parents:
diff changeset
37
kono
parents:
diff changeset
38 WITH REPORT; USE REPORT;
kono
parents:
diff changeset
39 PROCEDURE C95086C IS
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 BEGIN
kono
parents:
diff changeset
42 TEST ("C95086C", "CHECK THAT CONSTRAINT_ERROR IS NOT RAISED " &
kono
parents:
diff changeset
43 "AFTER THE ENTRY CALL, WHEN AN IN OUT OR OUT FORMAL " &
kono
parents:
diff changeset
44 "ACCESS VALUE IS NULL, AND THE ACTUAL PARAMETER HAS " &
kono
parents:
diff changeset
45 "DIFFERENT CONSTRAINTS" );
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 --------------------------------------------------
kono
parents:
diff changeset
48
kono
parents:
diff changeset
49 DECLARE -- (A)
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 PACKAGE PKG IS
kono
parents:
diff changeset
52 TYPE E IS (E1, E2);
kono
parents:
diff changeset
53 TYPE T (D : E := E1) IS PRIVATE;
kono
parents:
diff changeset
54 PRIVATE
kono
parents:
diff changeset
55 TYPE T (D : E := E1) IS
kono
parents:
diff changeset
56 RECORD
kono
parents:
diff changeset
57 I : INTEGER;
kono
parents:
diff changeset
58 CASE D IS
kono
parents:
diff changeset
59 WHEN E1 =>
kono
parents:
diff changeset
60 B : BOOLEAN;
kono
parents:
diff changeset
61 WHEN E2 =>
kono
parents:
diff changeset
62 C : CHARACTER;
kono
parents:
diff changeset
63 END CASE;
kono
parents:
diff changeset
64 END RECORD;
kono
parents:
diff changeset
65 END PKG;
kono
parents:
diff changeset
66
kono
parents:
diff changeset
67 USE PKG;
kono
parents:
diff changeset
68
kono
parents:
diff changeset
69 TYPE A IS ACCESS T;
kono
parents:
diff changeset
70 SUBTYPE SA IS A (E2);
kono
parents:
diff changeset
71 V : A (E1) := NULL;
kono
parents:
diff changeset
72 ENTERED : BOOLEAN := FALSE;
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 TASK T1 IS
kono
parents:
diff changeset
75 ENTRY P (X : IN OUT SA);
kono
parents:
diff changeset
76 END T1;
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78 TASK BODY T1 IS
kono
parents:
diff changeset
79 BEGIN
kono
parents:
diff changeset
80 ACCEPT P (X : IN OUT SA) DO
kono
parents:
diff changeset
81 ENTERED := TRUE;
kono
parents:
diff changeset
82 X := NULL;
kono
parents:
diff changeset
83 END P;
kono
parents:
diff changeset
84 EXCEPTION
kono
parents:
diff changeset
85 WHEN OTHERS =>
kono
parents:
diff changeset
86 FAILED ("EXCEPTION RAISED IN TASK - (A)");
kono
parents:
diff changeset
87 END T1;
kono
parents:
diff changeset
88
kono
parents:
diff changeset
89 BEGIN -- (A)
kono
parents:
diff changeset
90
kono
parents:
diff changeset
91 T1.P (V);
kono
parents:
diff changeset
92
kono
parents:
diff changeset
93 EXCEPTION
kono
parents:
diff changeset
94 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
95 IF NOT ENTERED THEN
kono
parents:
diff changeset
96 FAILED ("EXCEPTION RAISED BEFORE CALL - (A)");
kono
parents:
diff changeset
97 ELSE
kono
parents:
diff changeset
98 FAILED ("EXCEPTION RAISED ON RETURN - (A)");
kono
parents:
diff changeset
99 END IF;
kono
parents:
diff changeset
100 WHEN OTHERS =>
kono
parents:
diff changeset
101 FAILED ("EXCEPTION RAISED - (A)");
kono
parents:
diff changeset
102 END; -- (A)
kono
parents:
diff changeset
103
kono
parents:
diff changeset
104 --------------------------------------------------
kono
parents:
diff changeset
105
kono
parents:
diff changeset
106 DECLARE -- (B)
kono
parents:
diff changeset
107
kono
parents:
diff changeset
108 TYPE T IS ARRAY (CHARACTER RANGE <>, BOOLEAN RANGE <>) OF
kono
parents:
diff changeset
109 INTEGER;
kono
parents:
diff changeset
110
kono
parents:
diff changeset
111 TYPE A IS ACCESS T;
kono
parents:
diff changeset
112 SUBTYPE SA IS A ('D'..'F', FALSE..FALSE);
kono
parents:
diff changeset
113 V : A (IDENT_CHAR('A') .. IDENT_CHAR('B'),
kono
parents:
diff changeset
114 IDENT_BOOL(TRUE) .. IDENT_BOOL(TRUE)) := NULL;
kono
parents:
diff changeset
115 ENTERED : BOOLEAN := FALSE;
kono
parents:
diff changeset
116
kono
parents:
diff changeset
117 TASK T1 IS
kono
parents:
diff changeset
118 ENTRY P (X : OUT SA);
kono
parents:
diff changeset
119 END T1;
kono
parents:
diff changeset
120
kono
parents:
diff changeset
121 TASK BODY T1 IS
kono
parents:
diff changeset
122 BEGIN
kono
parents:
diff changeset
123 ACCEPT P (X : OUT SA) DO
kono
parents:
diff changeset
124 ENTERED := TRUE;
kono
parents:
diff changeset
125 X := NULL;
kono
parents:
diff changeset
126 END P;
kono
parents:
diff changeset
127 EXCEPTION
kono
parents:
diff changeset
128 WHEN OTHERS =>
kono
parents:
diff changeset
129 FAILED ("EXCEPTION RAISED IN TASK - (B)");
kono
parents:
diff changeset
130 END T1;
kono
parents:
diff changeset
131
kono
parents:
diff changeset
132 BEGIN -- (B)
kono
parents:
diff changeset
133
kono
parents:
diff changeset
134 T1.P (V);
kono
parents:
diff changeset
135
kono
parents:
diff changeset
136 EXCEPTION
kono
parents:
diff changeset
137 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
138 IF NOT ENTERED THEN
kono
parents:
diff changeset
139 FAILED ("EXCEPTION RAISED BEFORE CALL - (B)");
kono
parents:
diff changeset
140 ELSE
kono
parents:
diff changeset
141 FAILED ("EXCEPTION RAISED ON RETURN - (B)");
kono
parents:
diff changeset
142 END IF;
kono
parents:
diff changeset
143 WHEN OTHERS =>
kono
parents:
diff changeset
144 FAILED ("EXCEPTION RAISED - (B)");
kono
parents:
diff changeset
145 END; -- (B)
kono
parents:
diff changeset
146
kono
parents:
diff changeset
147 --------------------------------------------------
kono
parents:
diff changeset
148
kono
parents:
diff changeset
149 DECLARE -- (C)
kono
parents:
diff changeset
150
kono
parents:
diff changeset
151 PACKAGE PKG IS
kono
parents:
diff changeset
152 TYPE E IS (E1, E2);
kono
parents:
diff changeset
153 TYPE T (D : E := E1) IS PRIVATE;
kono
parents:
diff changeset
154 PRIVATE
kono
parents:
diff changeset
155 TYPE T (D : E := E1) IS
kono
parents:
diff changeset
156 RECORD
kono
parents:
diff changeset
157 I : INTEGER;
kono
parents:
diff changeset
158 CASE D IS
kono
parents:
diff changeset
159 WHEN E1 =>
kono
parents:
diff changeset
160 B : BOOLEAN;
kono
parents:
diff changeset
161 WHEN E2 =>
kono
parents:
diff changeset
162 C : CHARACTER;
kono
parents:
diff changeset
163 END CASE;
kono
parents:
diff changeset
164 END RECORD;
kono
parents:
diff changeset
165 END PKG;
kono
parents:
diff changeset
166
kono
parents:
diff changeset
167 USE PKG;
kono
parents:
diff changeset
168
kono
parents:
diff changeset
169 TYPE A IS ACCESS T;
kono
parents:
diff changeset
170 SUBTYPE SA IS A (E2);
kono
parents:
diff changeset
171 V : A (E1) := NULL;
kono
parents:
diff changeset
172 ENTERED : BOOLEAN := FALSE;
kono
parents:
diff changeset
173
kono
parents:
diff changeset
174 TASK T1 IS
kono
parents:
diff changeset
175 ENTRY P (X : IN OUT SA);
kono
parents:
diff changeset
176 END T1;
kono
parents:
diff changeset
177
kono
parents:
diff changeset
178 TASK BODY T1 IS
kono
parents:
diff changeset
179 BEGIN
kono
parents:
diff changeset
180 ACCEPT P (X : IN OUT SA) DO
kono
parents:
diff changeset
181 ENTERED := TRUE;
kono
parents:
diff changeset
182 X := NULL;
kono
parents:
diff changeset
183 END P;
kono
parents:
diff changeset
184 EXCEPTION
kono
parents:
diff changeset
185 WHEN OTHERS =>
kono
parents:
diff changeset
186 FAILED ("EXCEPTION RAISED IN TASK - (C)");
kono
parents:
diff changeset
187 END T1;
kono
parents:
diff changeset
188
kono
parents:
diff changeset
189 BEGIN -- (C)
kono
parents:
diff changeset
190
kono
parents:
diff changeset
191 T1.P (SA(V));
kono
parents:
diff changeset
192
kono
parents:
diff changeset
193 EXCEPTION
kono
parents:
diff changeset
194 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
195 IF NOT ENTERED THEN
kono
parents:
diff changeset
196 FAILED ("EXCEPTION RAISED BEFORE CALL - (C)");
kono
parents:
diff changeset
197 ELSE
kono
parents:
diff changeset
198 FAILED ("EXCEPTION RAISED ON RETURN - (C)");
kono
parents:
diff changeset
199 END IF;
kono
parents:
diff changeset
200 WHEN OTHERS =>
kono
parents:
diff changeset
201 FAILED ("EXCEPTION RAISED - (C)");
kono
parents:
diff changeset
202 END; -- (C)
kono
parents:
diff changeset
203
kono
parents:
diff changeset
204 --------------------------------------------------
kono
parents:
diff changeset
205
kono
parents:
diff changeset
206 DECLARE -- (D)
kono
parents:
diff changeset
207
kono
parents:
diff changeset
208 TYPE T IS ARRAY (CHARACTER RANGE <>, BOOLEAN RANGE <>) OF
kono
parents:
diff changeset
209 INTEGER;
kono
parents:
diff changeset
210
kono
parents:
diff changeset
211 TYPE A IS ACCESS T;
kono
parents:
diff changeset
212 SUBTYPE SA IS A ('D'..'F', FALSE..FALSE);
kono
parents:
diff changeset
213 V : A (IDENT_CHAR('A') .. IDENT_CHAR('B'),
kono
parents:
diff changeset
214 IDENT_BOOL(TRUE) .. IDENT_BOOL(TRUE)) := NULL;
kono
parents:
diff changeset
215 ENTERED : BOOLEAN := FALSE;
kono
parents:
diff changeset
216
kono
parents:
diff changeset
217 TASK T1 IS
kono
parents:
diff changeset
218 ENTRY P (X : OUT SA);
kono
parents:
diff changeset
219 END T1;
kono
parents:
diff changeset
220
kono
parents:
diff changeset
221 TASK BODY T1 IS
kono
parents:
diff changeset
222 BEGIN
kono
parents:
diff changeset
223 ACCEPT P (X : OUT SA) DO
kono
parents:
diff changeset
224 ENTERED := TRUE;
kono
parents:
diff changeset
225 X := NULL;
kono
parents:
diff changeset
226 END P;
kono
parents:
diff changeset
227 EXCEPTION
kono
parents:
diff changeset
228 WHEN OTHERS =>
kono
parents:
diff changeset
229 FAILED ("EXCEPTION RAISED IN TASK - (D)");
kono
parents:
diff changeset
230 END T1;
kono
parents:
diff changeset
231
kono
parents:
diff changeset
232 BEGIN -- (D)
kono
parents:
diff changeset
233
kono
parents:
diff changeset
234 T1.P (SA(V));
kono
parents:
diff changeset
235
kono
parents:
diff changeset
236 EXCEPTION
kono
parents:
diff changeset
237 WHEN CONSTRAINT_ERROR =>
kono
parents:
diff changeset
238 IF NOT ENTERED THEN
kono
parents:
diff changeset
239 FAILED ("EXCEPTION RAISED BEFORE CALL - (D)");
kono
parents:
diff changeset
240 ELSE
kono
parents:
diff changeset
241 FAILED ("EXCEPTION RAISED ON RETURN - (D)");
kono
parents:
diff changeset
242 END IF;
kono
parents:
diff changeset
243 WHEN OTHERS =>
kono
parents:
diff changeset
244 FAILED ("EXCEPTION RAISED - (D)");
kono
parents:
diff changeset
245 END; -- (D)
kono
parents:
diff changeset
246
kono
parents:
diff changeset
247 --------------------------------------------------
kono
parents:
diff changeset
248
kono
parents:
diff changeset
249 RESULT;
kono
parents:
diff changeset
250 END C95086C;