annotate gcc/testsuite/ada/acats/tests/c4/c432003.a @ 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 -- C432003.A
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 --
kono
parents:
diff changeset
26 -- OBJECTIVE:
kono
parents:
diff changeset
27 -- Check that if the type of the ancestor part of an extension aggregate
kono
parents:
diff changeset
28 -- has discriminants that are not inherited by the type of the aggregate,
kono
parents:
diff changeset
29 -- and the ancestor part is a subtype mark that denotes a constrained
kono
parents:
diff changeset
30 -- subtype, Constraint_Error is raised if: 1) any discriminant of the
kono
parents:
diff changeset
31 -- ancestor has a different value than that specified for a corresponding
kono
parents:
diff changeset
32 -- discriminant in the derived type definition for some ancestor of the
kono
parents:
diff changeset
33 -- type of the aggregate, or 2) the value for the discriminant in the
kono
parents:
diff changeset
34 -- record association list is not the value of the corresponding
kono
parents:
diff changeset
35 -- discriminant. Check that the components of the value of the
kono
parents:
diff changeset
36 -- aggregate not given by the record component association list are
kono
parents:
diff changeset
37 -- initialized by default as for an object of the ancestor type.
kono
parents:
diff changeset
38 --
kono
parents:
diff changeset
39 -- TEST DESCRIPTION:
kono
parents:
diff changeset
40 -- Consider:
kono
parents:
diff changeset
41 --
kono
parents:
diff changeset
42 -- type T (D1: ...) is tagged ...
kono
parents:
diff changeset
43 --
kono
parents:
diff changeset
44 -- type DT is new T with ...
kono
parents:
diff changeset
45 -- subtype ST is DT (D1 => 3); -- Constrained subtype.
kono
parents:
diff changeset
46 --
kono
parents:
diff changeset
47 -- type NT1 (D2: ...) is new DT (D1 => D2) with null record;
kono
parents:
diff changeset
48 -- type NT2 (D2: ...) is new DT (D1 => 6) with null record;
kono
parents:
diff changeset
49 -- type NT3 is new DT (D1 => 6) with null record;
kono
parents:
diff changeset
50 --
kono
parents:
diff changeset
51 -- A: NT1 := (T with D2 => 6); -- OK: T is unconstrained.
kono
parents:
diff changeset
52 -- B: NT1 := (DT with D2 => 6); -- OK: DT is unconstrained.
kono
parents:
diff changeset
53 -- C: NT1 := (ST with D2 => 6); -- NO: ST.D1 /= D2.
kono
parents:
diff changeset
54 --
kono
parents:
diff changeset
55 -- D: NT2 := (T with D2 => 4); -- OK: T is unconstrained.
kono
parents:
diff changeset
56 -- E: NT2 := (DT with D2 => 4); -- OK: DT is unconstrained.
kono
parents:
diff changeset
57 -- F: NT2 := (ST with . . . ); -- NO: ST.D1 /= DT.D1 as specified in NT2.
kono
parents:
diff changeset
58 --
kono
parents:
diff changeset
59 -- G: NT3 := (T with D1 => 6); -- OK: T is unconstrained.
kono
parents:
diff changeset
60 -- H: NT3 := (DT with D1 => 6); -- OK: DT is unconstrained.
kono
parents:
diff changeset
61 -- I: NT3 := (ST with D1 => 6); -- NO: ST.D1 /= DT.D1 as specified in NT3.
kono
parents:
diff changeset
62 --
kono
parents:
diff changeset
63 -- In A, B, D, E, G, and H the ancestor part is the name of an
kono
parents:
diff changeset
64 -- unconstrained subtype, so this rule does not apply. In C, F, and I
kono
parents:
diff changeset
65 -- the ancestor part (ST) is the name of a constrained subtype of DT,
kono
parents:
diff changeset
66 -- which is itself a derived type of a discriminated tagged type T. ST
kono
parents:
diff changeset
67 -- constrains the discriminant of DT (D1) to the value 3; thus, the
kono
parents:
diff changeset
68 -- type of any extension aggregate for which ST is the ancestor part
kono
parents:
diff changeset
69 -- must have an ancestor which also constrained D1 to 3. F and I raise
kono
parents:
diff changeset
70 -- Constraint_Error because NT2 and NT3, respectively, constrain D1 to
kono
parents:
diff changeset
71 -- 6. C raises Constraint_Error because NT1 constrains D1 to the value
kono
parents:
diff changeset
72 -- of D2, which is set to 6 in the record component association list of
kono
parents:
diff changeset
73 -- the aggregate.
kono
parents:
diff changeset
74 --
kono
parents:
diff changeset
75 -- This test verifies each of the three scenarios above:
kono
parents:
diff changeset
76 --
kono
parents:
diff changeset
77 -- (1) Ancestor of type of aggregate constrains discriminant with
kono
parents:
diff changeset
78 -- new discriminant.
kono
parents:
diff changeset
79 -- (2) Ancestor of type of aggregate constrains discriminant with
kono
parents:
diff changeset
80 -- value, and has a new discriminant part.
kono
parents:
diff changeset
81 -- (3) Ancestor of type of aggregate constrains discriminant with
kono
parents:
diff changeset
82 -- value, and has no discriminant part.
kono
parents:
diff changeset
83 --
kono
parents:
diff changeset
84 -- Verification is made for cases where the type of the aggregate is
kono
parents:
diff changeset
85 -- once- and twice-removed from the type of the ancestor part.
kono
parents:
diff changeset
86 --
kono
parents:
diff changeset
87 -- Additionally, a case is included where a new discriminant corresponds
kono
parents:
diff changeset
88 -- to multiple discriminants of the type of the ancestor part.
kono
parents:
diff changeset
89 --
kono
parents:
diff changeset
90 -- To test the portion of the objective concerning "initialization by
kono
parents:
diff changeset
91 -- default," the test verifies that, after a successful aggregate
kono
parents:
diff changeset
92 -- assignment, components not assigned an explicit value by the aggregate
kono
parents:
diff changeset
93 -- contain the default values for the corresponding components of the
kono
parents:
diff changeset
94 -- ancestor type.
kono
parents:
diff changeset
95 --
kono
parents:
diff changeset
96 --
kono
parents:
diff changeset
97 -- CHANGE HISTORY:
kono
parents:
diff changeset
98 -- 06 Dec 94 SAIC ACVC 2.0
kono
parents:
diff changeset
99 -- 15 Dec 94 SAIC Removed discriminant defaults from tagged types.
kono
parents:
diff changeset
100 -- 17 Nov 95 SAIC ACVC 2.0.1 fixes: Corrected subtype constraint
kono
parents:
diff changeset
101 -- for component NT_C3.Str2. Added missing component
kono
parents:
diff changeset
102 -- checks. Removed record component update from
kono
parents:
diff changeset
103 -- Avoid_Optimization. Fixed incorrect component
kono
parents:
diff changeset
104 -- checks.
kono
parents:
diff changeset
105 -- 02 Dec 95 SAIC ACVC 2.0.1 fixes: Corrected Failed comment for
kono
parents:
diff changeset
106 -- Q case.
kono
parents:
diff changeset
107 --
kono
parents:
diff changeset
108 --!
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 package C432003_0 is
kono
parents:
diff changeset
111
kono
parents:
diff changeset
112 Default_String : constant String := "This is a default string"; -- len = 24
kono
parents:
diff changeset
113 Another_String : constant String := "Another default string"; -- len = 22
kono
parents:
diff changeset
114
kono
parents:
diff changeset
115 subtype Length is Natural range 0..255;
kono
parents:
diff changeset
116
kono
parents:
diff changeset
117 type ROOT (D1 : Length) is tagged
kono
parents:
diff changeset
118 record
kono
parents:
diff changeset
119 S1 : String (1..D1) := Default_String(1..D1);
kono
parents:
diff changeset
120 Acc : Natural := 356;
kono
parents:
diff changeset
121 end record;
kono
parents:
diff changeset
122
kono
parents:
diff changeset
123 procedure Avoid_Optimization (Rec : in out ROOT); -- Inherited by all type
kono
parents:
diff changeset
124 -- extensions.
kono
parents:
diff changeset
125
kono
parents:
diff changeset
126 type Unconstrained_Der is new ROOT with
kono
parents:
diff changeset
127 record
kono
parents:
diff changeset
128 Str1 : String(1..5) := "abcde";
kono
parents:
diff changeset
129 end record;
kono
parents:
diff changeset
130
kono
parents:
diff changeset
131 subtype Constrained_Subtype is Unconstrained_Der (D1 => 10);
kono
parents:
diff changeset
132
kono
parents:
diff changeset
133 type NT_A1 (D2 : Length) is new Unconstrained_Der (D1 => D2) with
kono
parents:
diff changeset
134 record
kono
parents:
diff changeset
135 S2 : String(1..D2); -- Inherited discrim. constrained by
kono
parents:
diff changeset
136 end record; -- new discriminant.
kono
parents:
diff changeset
137
kono
parents:
diff changeset
138 type NT_A2 (D3 : Length) is new NT_A1 (D2 => D3) with
kono
parents:
diff changeset
139 record
kono
parents:
diff changeset
140 S3 : String(1..D3); -- Inherited discrim. constrained by
kono
parents:
diff changeset
141 end record; -- new discriminant.
kono
parents:
diff changeset
142
kono
parents:
diff changeset
143
kono
parents:
diff changeset
144 type NT_B1 (D2 : Length) is new Unconstrained_Der (D1 => 5) with
kono
parents:
diff changeset
145 record
kono
parents:
diff changeset
146 S2 : String(1..D2); -- Inherited discrim. constrained by
kono
parents:
diff changeset
147 end record; -- explicit value.
kono
parents:
diff changeset
148
kono
parents:
diff changeset
149 type NT_B2 (D3 : Length) is new NT_B1 (D2 => 10) with
kono
parents:
diff changeset
150 record
kono
parents:
diff changeset
151 S3 : String(1..D3); -- Inherited discrim. constrained by
kono
parents:
diff changeset
152 end record; -- explicit value.
kono
parents:
diff changeset
153
kono
parents:
diff changeset
154 type NT_B3 (D2 : Length) is new Unconstrained_Der (D1 => 10) with
kono
parents:
diff changeset
155 record
kono
parents:
diff changeset
156 S2 : String(1..D2);
kono
parents:
diff changeset
157 end record;
kono
parents:
diff changeset
158
kono
parents:
diff changeset
159
kono
parents:
diff changeset
160 type NT_C1 is new Unconstrained_Der (D1 => 5) with
kono
parents:
diff changeset
161 record
kono
parents:
diff changeset
162 Str2 : String(1..5); -- Inherited discrim. constrained
kono
parents:
diff changeset
163 end record; -- No new value.
kono
parents:
diff changeset
164
kono
parents:
diff changeset
165 type NT_C2 (D2 : Length) is new NT_C1 with
kono
parents:
diff changeset
166 record
kono
parents:
diff changeset
167 S2 : String(1..D2); -- Inherited discrim. not further
kono
parents:
diff changeset
168 end record; -- constrained, new discriminant.
kono
parents:
diff changeset
169
kono
parents:
diff changeset
170 type NT_C3 is new Unconstrained_Der(D1 => 10) with
kono
parents:
diff changeset
171 record
kono
parents:
diff changeset
172 Str2 : String(1..5);
kono
parents:
diff changeset
173 end record;
kono
parents:
diff changeset
174
kono
parents:
diff changeset
175
kono
parents:
diff changeset
176 type MULTI_ROOT (D1 : Length; D2 : Length) is tagged
kono
parents:
diff changeset
177 record
kono
parents:
diff changeset
178 S1 : String (1..D1) := Default_String(1..D1);
kono
parents:
diff changeset
179 S2 : String (1..D2) := Another_String(1..D2);
kono
parents:
diff changeset
180 end record;
kono
parents:
diff changeset
181
kono
parents:
diff changeset
182 procedure Avoid_Optimization (Rec : in out MULTI_ROOT); -- Inherited by all
kono
parents:
diff changeset
183 -- type extensions.
kono
parents:
diff changeset
184
kono
parents:
diff changeset
185 type Mult_Unconstr_Der is new MULTI_ROOT with
kono
parents:
diff changeset
186 record
kono
parents:
diff changeset
187 Str1 : String(1..8) := "AbCdEfGh"; -- Derived, no constraints.
kono
parents:
diff changeset
188 end record;
kono
parents:
diff changeset
189
kono
parents:
diff changeset
190 -- Subtypes with constrained discriminants.
kono
parents:
diff changeset
191 subtype Mult_Constr_Sub1 is Mult_Unconstr_Der(D1 => 15, -- Disc. have
kono
parents:
diff changeset
192 D2 => 20); -- diff values
kono
parents:
diff changeset
193
kono
parents:
diff changeset
194 subtype Mult_Constr_Sub2 is Mult_Unconstr_Der(D1 => 15, -- Disc. have
kono
parents:
diff changeset
195 D2 => 15); -- same value
kono
parents:
diff changeset
196
kono
parents:
diff changeset
197 type Mult_NT_A1 (D3 : Length) is
kono
parents:
diff changeset
198 new Mult_Unconstr_Der (D1 => D3, D2 => D3) with
kono
parents:
diff changeset
199 record
kono
parents:
diff changeset
200 S3 : String(1..D3); -- Both inherited discriminants constrained
kono
parents:
diff changeset
201 end record; -- by new discriminant.
kono
parents:
diff changeset
202
kono
parents:
diff changeset
203 end C432003_0;
kono
parents:
diff changeset
204
kono
parents:
diff changeset
205
kono
parents:
diff changeset
206 --=====================================================================--
kono
parents:
diff changeset
207
kono
parents:
diff changeset
208
kono
parents:
diff changeset
209 with Report;
kono
parents:
diff changeset
210 package body C432003_0 is
kono
parents:
diff changeset
211
kono
parents:
diff changeset
212 procedure Avoid_Optimization (Rec : in out ROOT) is
kono
parents:
diff changeset
213 begin
kono
parents:
diff changeset
214 Rec.S1 := Report.Ident_Str(Rec.S1);
kono
parents:
diff changeset
215 end Avoid_Optimization;
kono
parents:
diff changeset
216
kono
parents:
diff changeset
217 procedure Avoid_Optimization (Rec : in out MULTI_ROOT) is
kono
parents:
diff changeset
218 begin
kono
parents:
diff changeset
219 Rec.S1 := Report.Ident_Str(Rec.S1);
kono
parents:
diff changeset
220 end Avoid_Optimization;
kono
parents:
diff changeset
221
kono
parents:
diff changeset
222 end C432003_0;
kono
parents:
diff changeset
223
kono
parents:
diff changeset
224
kono
parents:
diff changeset
225 --=====================================================================--
kono
parents:
diff changeset
226
kono
parents:
diff changeset
227
kono
parents:
diff changeset
228 with C432003_0;
kono
parents:
diff changeset
229 with Report;
kono
parents:
diff changeset
230 procedure C432003 is
kono
parents:
diff changeset
231 begin
kono
parents:
diff changeset
232
kono
parents:
diff changeset
233 Report.Test("C432003", "Extension aggregates where ancestor part " &
kono
parents:
diff changeset
234 "is a subtype mark that denotes a constrained " &
kono
parents:
diff changeset
235 "subtype causing Constraint_Error if any " &
kono
parents:
diff changeset
236 "discriminant of the ancestor has a different " &
kono
parents:
diff changeset
237 "value than that specified for a corresponding " &
kono
parents:
diff changeset
238 "discriminant in the derived type definition " &
kono
parents:
diff changeset
239 "for some ancestor of the type of the aggregate");
kono
parents:
diff changeset
240
kono
parents:
diff changeset
241 Test_Block:
kono
parents:
diff changeset
242 declare
kono
parents:
diff changeset
243
kono
parents:
diff changeset
244 -- Variety of string object declarations.
kono
parents:
diff changeset
245 String2 : String(1..2) := Report.Ident_Str("12");
kono
parents:
diff changeset
246 String5 : String(1..5) := Report.Ident_Str("12345");
kono
parents:
diff changeset
247 String8 : String(1..8) := Report.Ident_Str("AbCdEfGh");
kono
parents:
diff changeset
248 String10 : String(1..10) := Report.Ident_Str("1234567890");
kono
parents:
diff changeset
249 String15 : String(1..15) := Report.Ident_Str("123456789012345");
kono
parents:
diff changeset
250 String20 : String(1..20) := Report.Ident_Str("12345678901234567890");
kono
parents:
diff changeset
251
kono
parents:
diff changeset
252 begin
kono
parents:
diff changeset
253
kono
parents:
diff changeset
254
kono
parents:
diff changeset
255 begin
kono
parents:
diff changeset
256 declare
kono
parents:
diff changeset
257 A : C432003_0.NT_A1 := -- OK
kono
parents:
diff changeset
258 (C432003_0.ROOT with D2 => 5,
kono
parents:
diff changeset
259 Str1 => "cdefg",
kono
parents:
diff changeset
260 S2 => String5);
kono
parents:
diff changeset
261 begin
kono
parents:
diff changeset
262 C432003_0.Avoid_Optimization(A);
kono
parents:
diff changeset
263 if A.Acc /= 356 or
kono
parents:
diff changeset
264 A.Str1 /= "cdefg" or
kono
parents:
diff changeset
265 A.S2 /= String5 or
kono
parents:
diff changeset
266 A.D2 /= 5 or
kono
parents:
diff changeset
267 A.S1 /= C432003_0.Default_String(1..5)
kono
parents:
diff changeset
268 then
kono
parents:
diff changeset
269 Report.Failed("Incorrect object values for Object A");
kono
parents:
diff changeset
270 end if;
kono
parents:
diff changeset
271 end;
kono
parents:
diff changeset
272 exception
kono
parents:
diff changeset
273 when Constraint_Error =>
kono
parents:
diff changeset
274 Report.Failed("Constraint_Error raised for Object A");
kono
parents:
diff changeset
275 end;
kono
parents:
diff changeset
276
kono
parents:
diff changeset
277
kono
parents:
diff changeset
278 begin
kono
parents:
diff changeset
279 declare
kono
parents:
diff changeset
280 C: C432003_0.NT_A1 := -- OK
kono
parents:
diff changeset
281 (C432003_0.Constrained_Subtype with D2 => 10,
kono
parents:
diff changeset
282 S2 => String10);
kono
parents:
diff changeset
283 begin
kono
parents:
diff changeset
284 C432003_0.Avoid_Optimization(C);
kono
parents:
diff changeset
285 if C.D2 /= 10 or C.Acc /= 356 or
kono
parents:
diff changeset
286 C.Str1 /= "abcde" or C.S2 /= String10 or
kono
parents:
diff changeset
287 C.S1 /= C432003_0.Default_String(1..10)
kono
parents:
diff changeset
288 then
kono
parents:
diff changeset
289 Report.Failed("Incorrect object values for Object C");
kono
parents:
diff changeset
290 end if;
kono
parents:
diff changeset
291 end;
kono
parents:
diff changeset
292 exception
kono
parents:
diff changeset
293 when Constraint_Error =>
kono
parents:
diff changeset
294 Report.Failed("Constraint_Error raised for Object C");
kono
parents:
diff changeset
295 end;
kono
parents:
diff changeset
296
kono
parents:
diff changeset
297
kono
parents:
diff changeset
298 begin
kono
parents:
diff changeset
299 declare
kono
parents:
diff changeset
300 D: C432003_0.NT_A1 := -- C_E
kono
parents:
diff changeset
301 (C432003_0.Constrained_Subtype with
kono
parents:
diff changeset
302 D2 => Report.Ident_Int(5),
kono
parents:
diff changeset
303 S2 => String5);
kono
parents:
diff changeset
304 begin
kono
parents:
diff changeset
305 C432003_0.Avoid_Optimization(D);
kono
parents:
diff changeset
306 Report.Failed("Constraint_Error not raised for Object D");
kono
parents:
diff changeset
307 end;
kono
parents:
diff changeset
308 exception
kono
parents:
diff changeset
309 when Constraint_Error =>
kono
parents:
diff changeset
310 null; -- Raise of Constraint_Error is expected.
kono
parents:
diff changeset
311 end;
kono
parents:
diff changeset
312
kono
parents:
diff changeset
313
kono
parents:
diff changeset
314 begin
kono
parents:
diff changeset
315 declare
kono
parents:
diff changeset
316 E: C432003_0.NT_A2 := -- OK
kono
parents:
diff changeset
317 (C432003_0.Constrained_Subtype with D3 => 10,
kono
parents:
diff changeset
318 S2 => String10,
kono
parents:
diff changeset
319 S3 => String10);
kono
parents:
diff changeset
320 begin
kono
parents:
diff changeset
321 C432003_0.Avoid_Optimization(E);
kono
parents:
diff changeset
322 if E.D3 /= 10 or E.Acc /= 356 or
kono
parents:
diff changeset
323 E.Str1 /= "abcde" or E.S2 /= String10 or
kono
parents:
diff changeset
324 E.S3 /= String10 or
kono
parents:
diff changeset
325 E.S1 /= C432003_0.Default_String(1..10)
kono
parents:
diff changeset
326 then
kono
parents:
diff changeset
327 Report.Failed("Incorrect object values for Object E");
kono
parents:
diff changeset
328 end if;
kono
parents:
diff changeset
329 end;
kono
parents:
diff changeset
330 exception
kono
parents:
diff changeset
331 when Constraint_Error =>
kono
parents:
diff changeset
332 Report.Failed("Constraint_Error raised for Object E");
kono
parents:
diff changeset
333 end;
kono
parents:
diff changeset
334
kono
parents:
diff changeset
335
kono
parents:
diff changeset
336 begin
kono
parents:
diff changeset
337 declare
kono
parents:
diff changeset
338 F: C432003_0.NT_A2 := -- C_E
kono
parents:
diff changeset
339 (C432003_0.Constrained_Subtype with
kono
parents:
diff changeset
340 D3 => Report.Ident_Int(5),
kono
parents:
diff changeset
341 S2 => String5,
kono
parents:
diff changeset
342 S3 => String5);
kono
parents:
diff changeset
343 begin
kono
parents:
diff changeset
344 C432003_0.Avoid_Optimization(F);
kono
parents:
diff changeset
345 Report.Failed("Constraint_Error not raised for Object F");
kono
parents:
diff changeset
346 end;
kono
parents:
diff changeset
347 exception
kono
parents:
diff changeset
348 when Constraint_Error =>
kono
parents:
diff changeset
349 null; -- Raise of Constraint_Error is expected.
kono
parents:
diff changeset
350 end;
kono
parents:
diff changeset
351
kono
parents:
diff changeset
352
kono
parents:
diff changeset
353 begin
kono
parents:
diff changeset
354 declare
kono
parents:
diff changeset
355 G: C432003_0.NT_B2 := -- OK
kono
parents:
diff changeset
356 (C432003_0.ROOT with D3 => 5,
kono
parents:
diff changeset
357 Str1 => "cdefg",
kono
parents:
diff changeset
358 S2 => String10,
kono
parents:
diff changeset
359 S3 => String5);
kono
parents:
diff changeset
360 begin
kono
parents:
diff changeset
361 C432003_0.Avoid_Optimization(G);
kono
parents:
diff changeset
362 if G.D3 /= 5 or G.Acc /= 356 or
kono
parents:
diff changeset
363 G.Str1 /= "cdefg" or G.S2 /= String10 or
kono
parents:
diff changeset
364 G.S3 /= String5 or
kono
parents:
diff changeset
365 G.S1 /= C432003_0.Default_String(1..5)
kono
parents:
diff changeset
366 then
kono
parents:
diff changeset
367 Report.Failed("Incorrect object values for Object G");
kono
parents:
diff changeset
368 end if;
kono
parents:
diff changeset
369 end;
kono
parents:
diff changeset
370 exception
kono
parents:
diff changeset
371 when Constraint_Error =>
kono
parents:
diff changeset
372 Report.Failed("Constraint_Error raised for Object G");
kono
parents:
diff changeset
373 end;
kono
parents:
diff changeset
374
kono
parents:
diff changeset
375
kono
parents:
diff changeset
376 begin
kono
parents:
diff changeset
377 declare
kono
parents:
diff changeset
378 H: C432003_0.NT_B3 := -- OK
kono
parents:
diff changeset
379 (C432003_0.Unconstrained_Der with D2 => 5,
kono
parents:
diff changeset
380 S2 => String5);
kono
parents:
diff changeset
381 begin
kono
parents:
diff changeset
382 C432003_0.Avoid_Optimization(H);
kono
parents:
diff changeset
383 if H.D2 /= 5 or H.Acc /= 356 or
kono
parents:
diff changeset
384 H.Str1 /= "abcde" or H.S2 /= String5 or
kono
parents:
diff changeset
385 H.S1 /= C432003_0.Default_String(1..10)
kono
parents:
diff changeset
386 then
kono
parents:
diff changeset
387 Report.Failed("Incorrect object values for Object H");
kono
parents:
diff changeset
388 end if;
kono
parents:
diff changeset
389 end;
kono
parents:
diff changeset
390 exception
kono
parents:
diff changeset
391 when Constraint_Error =>
kono
parents:
diff changeset
392 Report.Failed("Constraint_Error raised for Object H");
kono
parents:
diff changeset
393 end;
kono
parents:
diff changeset
394
kono
parents:
diff changeset
395
kono
parents:
diff changeset
396 begin
kono
parents:
diff changeset
397 declare
kono
parents:
diff changeset
398 I: C432003_0.NT_B1 := -- C_E
kono
parents:
diff changeset
399 (C432003_0.Constrained_Subtype with
kono
parents:
diff changeset
400 D2 => Report.Ident_Int(10),
kono
parents:
diff changeset
401 S2 => String10);
kono
parents:
diff changeset
402 begin
kono
parents:
diff changeset
403 C432003_0.Avoid_Optimization(I);
kono
parents:
diff changeset
404 Report.Failed("Constraint_Error not raised for Object I");
kono
parents:
diff changeset
405 end;
kono
parents:
diff changeset
406 exception
kono
parents:
diff changeset
407 when Constraint_Error =>
kono
parents:
diff changeset
408 null; -- Raise of Constraint_Error is expected.
kono
parents:
diff changeset
409 end;
kono
parents:
diff changeset
410
kono
parents:
diff changeset
411
kono
parents:
diff changeset
412 begin
kono
parents:
diff changeset
413 declare
kono
parents:
diff changeset
414 J: C432003_0.NT_B2 := -- C_E
kono
parents:
diff changeset
415 (C432003_0.Constrained_Subtype with
kono
parents:
diff changeset
416 D3 => Report.Ident_Int(10),
kono
parents:
diff changeset
417 S2 => String10,
kono
parents:
diff changeset
418 S3 => String10);
kono
parents:
diff changeset
419 begin
kono
parents:
diff changeset
420 C432003_0.Avoid_Optimization(J);
kono
parents:
diff changeset
421 Report.Failed("Constraint_Error not raised by Object J");
kono
parents:
diff changeset
422 end;
kono
parents:
diff changeset
423 exception
kono
parents:
diff changeset
424 when Constraint_Error =>
kono
parents:
diff changeset
425 null; -- Raise of Constraint_Error is expected.
kono
parents:
diff changeset
426 end;
kono
parents:
diff changeset
427
kono
parents:
diff changeset
428
kono
parents:
diff changeset
429 begin
kono
parents:
diff changeset
430 declare
kono
parents:
diff changeset
431 K: C432003_0.NT_B3 := -- OK
kono
parents:
diff changeset
432 (C432003_0.Constrained_Subtype with D2 => 5,
kono
parents:
diff changeset
433 S2 => String5);
kono
parents:
diff changeset
434 begin
kono
parents:
diff changeset
435 C432003_0.Avoid_Optimization(K);
kono
parents:
diff changeset
436 if K.D2 /= 5 or K.Acc /= 356 or
kono
parents:
diff changeset
437 K.Str1 /= "abcde" or K.S2 /= String5 or
kono
parents:
diff changeset
438 K.S1 /= C432003_0.Default_String(1..10)
kono
parents:
diff changeset
439 then
kono
parents:
diff changeset
440 Report.Failed("Incorrect object values for Object K");
kono
parents:
diff changeset
441 end if;
kono
parents:
diff changeset
442 end;
kono
parents:
diff changeset
443 exception
kono
parents:
diff changeset
444 when Constraint_Error =>
kono
parents:
diff changeset
445 Report.Failed("Constraint_Error raised for Object K");
kono
parents:
diff changeset
446 end;
kono
parents:
diff changeset
447
kono
parents:
diff changeset
448
kono
parents:
diff changeset
449 begin
kono
parents:
diff changeset
450 declare
kono
parents:
diff changeset
451 M: C432003_0.NT_C2 := -- OK
kono
parents:
diff changeset
452 (C432003_0.ROOT with D2 => 10,
kono
parents:
diff changeset
453 Str1 => "cdefg",
kono
parents:
diff changeset
454 Str2 => String5,
kono
parents:
diff changeset
455 S2 => String10);
kono
parents:
diff changeset
456 begin
kono
parents:
diff changeset
457 C432003_0.Avoid_Optimization(M);
kono
parents:
diff changeset
458 if M.D2 /= 10 or M.Acc /= 356 or
kono
parents:
diff changeset
459 M.Str1 /= "cdefg" or M.S2 /= String10 or
kono
parents:
diff changeset
460 M.Str2 /= String5 or
kono
parents:
diff changeset
461 M.S1 /= C432003_0.Default_String(1..5)
kono
parents:
diff changeset
462 then
kono
parents:
diff changeset
463 Report.Failed("Incorrect object values for Object M");
kono
parents:
diff changeset
464 end if;
kono
parents:
diff changeset
465 end;
kono
parents:
diff changeset
466 exception
kono
parents:
diff changeset
467 when Constraint_Error =>
kono
parents:
diff changeset
468 Report.Failed("Constraint_Error raised for Object M");
kono
parents:
diff changeset
469 end;
kono
parents:
diff changeset
470
kono
parents:
diff changeset
471
kono
parents:
diff changeset
472 begin
kono
parents:
diff changeset
473 declare
kono
parents:
diff changeset
474 O: C432003_0.NT_C1 := -- C_E
kono
parents:
diff changeset
475 (C432003_0.Constrained_Subtype with
kono
parents:
diff changeset
476 Str2 => Report.Ident_Str(String5));
kono
parents:
diff changeset
477 begin
kono
parents:
diff changeset
478 C432003_0.Avoid_Optimization(O);
kono
parents:
diff changeset
479 Report.Failed("Constraint_Error not raised for Object O");
kono
parents:
diff changeset
480 end;
kono
parents:
diff changeset
481 exception
kono
parents:
diff changeset
482 when Constraint_Error =>
kono
parents:
diff changeset
483 null; -- Raise of Constraint_Error is expected.
kono
parents:
diff changeset
484 end;
kono
parents:
diff changeset
485
kono
parents:
diff changeset
486
kono
parents:
diff changeset
487 begin
kono
parents:
diff changeset
488 declare
kono
parents:
diff changeset
489 P: C432003_0.NT_C2 := -- C_E
kono
parents:
diff changeset
490 (C432003_0.Constrained_Subtype with
kono
parents:
diff changeset
491 D2 => Report.Ident_Int(10),
kono
parents:
diff changeset
492 Str2 => String5,
kono
parents:
diff changeset
493 S2 => String10);
kono
parents:
diff changeset
494 begin
kono
parents:
diff changeset
495 C432003_0.Avoid_Optimization(P);
kono
parents:
diff changeset
496 Report.Failed("Constraint_Error not raised by Object P");
kono
parents:
diff changeset
497 end;
kono
parents:
diff changeset
498 exception
kono
parents:
diff changeset
499 when Constraint_Error =>
kono
parents:
diff changeset
500 null; -- Raise of Constraint_Error is expected.
kono
parents:
diff changeset
501 end;
kono
parents:
diff changeset
502
kono
parents:
diff changeset
503
kono
parents:
diff changeset
504 begin
kono
parents:
diff changeset
505 declare
kono
parents:
diff changeset
506 Q: C432003_0.NT_C3 :=
kono
parents:
diff changeset
507 (C432003_0.Constrained_Subtype with Str2 => String5); -- OK
kono
parents:
diff changeset
508 begin
kono
parents:
diff changeset
509 C432003_0.Avoid_Optimization(Q);
kono
parents:
diff changeset
510 if Q.Str2 /= String5 or
kono
parents:
diff changeset
511 Q.Acc /= 356 or
kono
parents:
diff changeset
512 Q.Str1 /= "abcde" or
kono
parents:
diff changeset
513 Q.D1 /= 10 or
kono
parents:
diff changeset
514 Q.S1 /= C432003_0.Default_String(1..10)
kono
parents:
diff changeset
515 then
kono
parents:
diff changeset
516 Report.Failed("Incorrect object values for Object Q");
kono
parents:
diff changeset
517 end if;
kono
parents:
diff changeset
518 end;
kono
parents:
diff changeset
519 exception
kono
parents:
diff changeset
520 when Constraint_Error =>
kono
parents:
diff changeset
521 Report.Failed("Constraint_Error raised for Object Q");
kono
parents:
diff changeset
522 end;
kono
parents:
diff changeset
523
kono
parents:
diff changeset
524
kono
parents:
diff changeset
525 -- The following cases test where a new discriminant corresponds
kono
parents:
diff changeset
526 -- to multiple discriminants of the type of the ancestor part.
kono
parents:
diff changeset
527
kono
parents:
diff changeset
528 begin
kono
parents:
diff changeset
529 declare
kono
parents:
diff changeset
530 S: C432003_0.Mult_NT_A1 := -- OK
kono
parents:
diff changeset
531 (C432003_0.Mult_Unconstr_Der with D3 => 15,
kono
parents:
diff changeset
532 S3 => String15);
kono
parents:
diff changeset
533 begin
kono
parents:
diff changeset
534 C432003_0.Avoid_Optimization(S);
kono
parents:
diff changeset
535 if S.S1 /= C432003_0.Default_String(1..15) or
kono
parents:
diff changeset
536 S.Str1 /= String8 or
kono
parents:
diff changeset
537 S.S2 /= C432003_0.Another_String(1..15) or
kono
parents:
diff changeset
538 S.S3 /= String15 or
kono
parents:
diff changeset
539 S.D3 /= 15
kono
parents:
diff changeset
540 then
kono
parents:
diff changeset
541 Report.Failed("Incorrect object values for Object S");
kono
parents:
diff changeset
542 end if;
kono
parents:
diff changeset
543 end;
kono
parents:
diff changeset
544 exception
kono
parents:
diff changeset
545 when Constraint_Error =>
kono
parents:
diff changeset
546 Report.Failed("Constraint_Error raised for Object S");
kono
parents:
diff changeset
547 end;
kono
parents:
diff changeset
548
kono
parents:
diff changeset
549
kono
parents:
diff changeset
550 begin
kono
parents:
diff changeset
551 declare
kono
parents:
diff changeset
552 U: C432003_0.Mult_NT_A1 := -- C_E
kono
parents:
diff changeset
553 (C432003_0.Mult_Constr_Sub1 with
kono
parents:
diff changeset
554 D3 => Report.Ident_Int(15),
kono
parents:
diff changeset
555 S3 => String15);
kono
parents:
diff changeset
556 begin
kono
parents:
diff changeset
557 C432003_0.Avoid_Optimization(U);
kono
parents:
diff changeset
558 Report.Failed("Constraint_Error not raised for Object U");
kono
parents:
diff changeset
559 end;
kono
parents:
diff changeset
560 exception
kono
parents:
diff changeset
561 when Constraint_Error =>
kono
parents:
diff changeset
562 null; -- Raise of Constraint_Error is expected.
kono
parents:
diff changeset
563 end;
kono
parents:
diff changeset
564
kono
parents:
diff changeset
565
kono
parents:
diff changeset
566 begin
kono
parents:
diff changeset
567 declare
kono
parents:
diff changeset
568 V: C432003_0.Mult_NT_A1 := -- OK
kono
parents:
diff changeset
569 (C432003_0.Mult_Constr_Sub2 with D3 => 15,
kono
parents:
diff changeset
570 S3 => String15);
kono
parents:
diff changeset
571 begin
kono
parents:
diff changeset
572 C432003_0.Avoid_Optimization(V);
kono
parents:
diff changeset
573 if V.D3 /= 15 or
kono
parents:
diff changeset
574 V.Str1 /= String8 or
kono
parents:
diff changeset
575 V.S3 /= String15 or
kono
parents:
diff changeset
576 V.S1 /= C432003_0.Default_String(1..15) or
kono
parents:
diff changeset
577 V.S2 /= C432003_0.Another_String(1..15)
kono
parents:
diff changeset
578 then
kono
parents:
diff changeset
579 Report.Failed("Incorrect object values for Object V");
kono
parents:
diff changeset
580 end if;
kono
parents:
diff changeset
581 end;
kono
parents:
diff changeset
582 exception
kono
parents:
diff changeset
583 when Constraint_Error =>
kono
parents:
diff changeset
584 Report.Failed("Constraint_Error raised for Object V");
kono
parents:
diff changeset
585 end;
kono
parents:
diff changeset
586
kono
parents:
diff changeset
587
kono
parents:
diff changeset
588 exception
kono
parents:
diff changeset
589 when others => Report.Failed("Exception raised in Test_Block");
kono
parents:
diff changeset
590 end Test_Block;
kono
parents:
diff changeset
591
kono
parents:
diff changeset
592 Report.Result;
kono
parents:
diff changeset
593
kono
parents:
diff changeset
594 end C432003;