3 -- Grant of Unlimited Rights
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
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.
26 -- A DISCRIMINANT CONSTRAINT
27 -- DEPENDS ON A DISCRIMINANT, THE NON-DISCRIMINANT EXPRESSIONS IN THE
28 -- CONSTRAINT ARE EVALUATED WHEN THE COMPONENT SUBTYPE DEFINITION IS
29 -- ELABORATED, BUT THE VALUES ARE CHECKED WHEN THE RECORD TYPE IS:
31 -- CASE D: USED WITHOUT A CONSTRAINT ONLY IN AN ALLOCATOR OR OBJECT
32 -- DECLARATION AND THE COMPONENT IS PRESENT IN THE DEFAULT SUBTYPE.
36 WITH REPORT
; USE REPORT
;
39 SUBTYPE SM
IS INTEGER RANGE 1..10;
41 TYPE REC
(D1
, D2
: SM
) IS
42 RECORD NULL; END RECORD;
44 F1_CONS
: INTEGER := 2;
49 MESSAGE
: STRING) RETURN BOOLEAN IS
52 FAILED
(MESSAGE
& ": CONS IS " &
58 FUNCTION F1
RETURN INTEGER IS
60 F1_CONS
:= F1_CONS
- IDENT_INT
(1);
65 TEST
("C37213F", "CHECK EVALUATION OF DISCRIMINANT EXPRESSIONS " &
66 "WHEN CONSTRAINT DEPENDS ON DISCRIMINANT, " &
67 "DISCRIMINANTS HAVE DEFAULTS, AND COMPONENT" &
68 "SUBTYPE DETERMINES WHETHER CONSTRAINT SHOULD " &
71 -- CASE D1: COMPONENT IS PRESENT
74 TYPE CONS
(D3
: INTEGER := IDENT_INT
(1)) IS
78 C1
: REC
(D3
, F1
); -- F1 EVALUATED
80 C2
: INTEGER := IDENT_INT
(0);
83 CHK1
: BOOLEAN := CHK
(F1_CONS
, 1, "F1 NOT EVALUATED");
84 X
: CONS
; -- F1 NOT EVALUATED AGAIN
85 Y
: CONS
; -- F1 NOT EVALUATED AGAIN
86 CHK2
: BOOLEAN := CHK
(F1_CONS
, 1, "F1 EVALUATED");
88 IF X
/= (1, (1, 1)) OR Y
/= (1, (1, 1)) THEN
89 FAILED
("DISCRIMINANT VALUES NOT CORRECT");
96 TYPE CONS
(D3
: INTEGER := IDENT_INT
(1)) IS
102 C2
: INTEGER := IDENT_INT
(0);
110 FAILED
("DISCRIMINANT CHECK NOT PERFORMED - 1");
111 IF X
/= (1, (1, 1)) THEN
112 COMMENT
("SHOULDN'T GET HERE");
116 WHEN CONSTRAINT_ERROR
=>
119 FAILED
("UNEXPECTED EXCEPTION - 1");
124 TYPE ACC_CONS
IS ACCESS CONS
;
128 FAILED
("DISCRIMINANT CHECK NOT PERFORMED - 2");
129 IF X
.ALL /= (1, (1, 1)) THEN
130 COMMENT
("IRRELEVANT");
133 WHEN CONSTRAINT_ERROR
=>
136 FAILED
("UNEXPECTED EXCEPTION RAISED - 2A");
140 FAILED
("UNEXPECTED EXCEPTION RAISED - 2B");
145 SUBTYPE SCONS
IS CONS
;
150 FAILED
("DISCRIMINANT CHECK NOT " &
152 IF X
/= (1, (1, 1)) THEN
153 COMMENT
("IRRELEVANT");
157 WHEN CONSTRAINT_ERROR
=>
160 FAILED
("UNEXPECTED EXCEPTION RAISED - 3");
164 FAILED
("CONSTRAINT CHECKED TOO SOON - 3");
169 TYPE ARR
IS ARRAY (1..5) OF CONS
;
174 FAILED
("DISCRIMINANT CHECK NOT " &
176 IF X
/= (1..5 => (1, (1, 1))) THEN
177 COMMENT
("IRRELEVANT");
181 WHEN CONSTRAINT_ERROR
=>
184 FAILED
("UNEXPECTED EXCEPTION RAISED - 4");
188 FAILED
("CONSTRAINT CHECKED TOO SOON - 4");
201 FAILED
("DISCRIMINANT CHECK NOT " &
203 IF X
/= (C1
=> (1, (1, 1))) THEN
204 COMMENT
("IRRELEVANT");
208 WHEN CONSTRAINT_ERROR
=>
211 FAILED
("UNEXPECTED EXCEPTION RAISED - 5");
215 FAILED
("CONSTRAINT CHECKED TOO SOON - 5");
220 TYPE DREC
IS NEW CONS
;
225 FAILED
("DISCRIMINANT CHECK NOT " &
227 IF X
/= (1, (1, 1)) THEN
228 COMMENT
("IRRELEVANT");
232 WHEN CONSTRAINT_ERROR
=>
235 FAILED
("UNEXPECTED EXCEPTION RAISED - 6");
239 FAILED
("CONSTRAINT CHECKED TOO SOON - 6");
244 -- CASE C2 : COMPONENT IS ABSENT
249 TYPE CONS
(D3
: INTEGER := IDENT_INT
(-6)) IS
253 C1
: REC
(D3
, F1
); -- F1 EVALUATED
255 C2
: INTEGER := IDENT_INT
(0);
258 CHK1
: BOOLEAN := CHK
(F1_CONS
, 1, "F1 NOT EVALUATED - 2");
259 X
: CONS
; -- F1 NOT EVALUATED AGAIN
260 Y
: CONS
; -- F1 NOT EVALUATED AGAIN
261 CHK2
: BOOLEAN := CHK
(F1_CONS
, 1, "F1 EVALUATED - 2");
263 IF X
/= (-6, 0) OR Y
/= (-6, 0) THEN
264 FAILED
("DISCRIMINANT VALUES NOT CORRECT");
271 TYPE CONS
(D3
: INTEGER := IDENT_INT
(11)) IS
277 C2
: INTEGER := IDENT_INT
(0);
286 FAILED
("WRONG VALUE FOR X - 11");
291 FAILED
("NONEXISTENT CONSTRAINT CHECKED - 11");
296 SUBTYPE SCONS
IS CONS
;
302 FAILED
("X VALUE WRONG - 12");
308 FAILED
("NONEXISTENT CONSTRAINT CHECKED - 12");
313 TYPE ARR
IS ARRAY (1..5) OF CONS
;
316 IF X
/= (1..5 => (11, 0)) THEN
317 FAILED
("X VALUE INCORRECT - 13");
322 FAILED
("NONEXISTENT CONSTRAINT CHECKED - 13");
333 IF X
/= (C1
=> (11, 0)) THEN
334 FAILED
("X VALUE IS INCORRECT - 14");
339 FAILED
("NONEXISTENT CONSTRAINT CHECKED - 14");
344 TYPE NREC
IS NEW CONS
;
348 FAILED
("X VALUE INCORRECT - 15");
353 FAILED
("NONEXISTENT CONSTRAINT CHECKED - 15");
358 TYPE ACC_CONS
IS ACCESS CONS
;
359 X
: ACC_CONS
:= NEW CONS
;
361 IF X
.ALL /= (11, 0) THEN
362 FAILED
("X VALUE INCORRECT - 17");
367 FAILED
("NONEXISTENT CONSTRAINT CHECKED - 17");
376 FAILED
("CONSTRAINT CHECK DONE TOO EARLY");