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 -- CHECK THAT CONSTRAINT_ERROR IS RAISED IF THE VALUE OF A
27 -- DISCRIMINANT OF A CONSTRAINED COMPONENT OF AN AGGREGATE DOES
28 -- NOT EQUAL THE CORRESPONDING DISCRIMINANT VALUE FOR THE
29 -- COMPONENT'S SUBTYPE.
32 -- BCB 07/19/88 CREATED ORIGINAL TEST.
34 WITH REPORT
; USE REPORT
;
40 TYPE REC
(D
: INTEGER := 0) IS RECORD
44 TYPE DREC
(DD
: INTEGER := ZERO
) IS RECORD
56 TYPE REC3
(D3
: INTEGER := 0) IS RECORD
65 TYPE PRIV1
(D
: INTEGER := 0) IS PRIVATE;
66 TYPE PRIV2
(DD
: INTEGER := ZERO
) IS PRIVATE;
67 FUNCTION INIT
(I
: INTEGER) RETURN PRIV1
;
69 TYPE PRIV1
(D
: INTEGER := 0) IS RECORD
73 TYPE PRIV2
(DD
: INTEGER := ZERO
) IS RECORD
86 FUNCTION GEN_EQUAL
(X
, Y
: GP
) RETURN BOOLEAN;
88 FUNCTION GEN_EQUAL
(X
, Y
: GP
) RETURN BOOLEAN IS
102 TYPE REC6
(D6
: INTEGER := 0) IS RECORD
110 FUNCTION REC4_EQUAL
IS NEW GEN_EQUAL
(REC4
);
111 FUNCTION REC5_EQUAL
IS NEW GEN_EQUAL
(REC5
);
112 FUNCTION REC6_EQUAL
IS NEW GEN_EQUAL
(REC6
);
114 FUNCTION INIT
(I
: INTEGER) RETURN PRIV1
IS
121 TEST
("C43004C", "CHECK THAT CONSTRAINT_ERROR IS RAISED " &
122 "IF THE VALUE OF A DISCRIMINANT OF A " &
123 "CONSTRAINED COMPONENT OF AN AGGREGATE " &
124 "DOES NOT EQUAL THE CORRESPONDING " &
125 "DISCRIMINANT VALUE FOR THECOMPONENT'S " &
129 VV
:= (E
=> (D
=> 1));
130 FAILED
("CONSTRAINT_ERROR NOT RAISED - 1");
131 IF REC4_EQUAL
(VV
,VV
) THEN
132 COMMENT
("DON'T OPTIMIZE VV");
135 WHEN CONSTRAINT_ERROR
=>
138 FAILED
("OTHER EXCEPTION RAISED - 1");
142 WW
:= (F
=> (DD
=> 1));
143 FAILED
("CONSTRAINT_ERROR NOT RAISED - 2");
144 IF REC5_EQUAL
(WW
,WW
) THEN
145 COMMENT
("DON'T OPTIMIZE WW");
148 WHEN CONSTRAINT_ERROR
=>
151 FAILED
("OTHER EXCEPTION RAISED - 2");
155 XX
:= (D6
=> 1, G
=> (D
=> 5));
156 FAILED
("CONSTRAINT_ERROR NOT RAISED - 3");
157 IF REC6_EQUAL
(XX
,XX
) THEN
158 COMMENT
("DON'T OPTIMIZE XX");
161 WHEN CONSTRAINT_ERROR
=>
164 FAILED
("OTHER EXCEPTION RAISED - 3");
170 FUNCTION REC1_EQUAL
IS NEW GEN_EQUAL
(REC1
);
171 FUNCTION REC2_EQUAL
IS NEW GEN_EQUAL
(REC2
);
172 FUNCTION REC3_EQUAL
IS NEW GEN_EQUAL
(REC3
);
173 FUNCTION REC7_EQUAL
IS NEW GEN_EQUAL
(REC7
);
178 V
:= (A
=> (D
=> 1, COMP1
=> 2));
179 FAILED
("CONSTRAINT_ERROR NOT RAISED - 4");
180 IF REC1_EQUAL
(V
,V
) THEN
181 COMMENT
("DON'T OPTIMIZE V");
184 WHEN CONSTRAINT_ERROR
=>
187 FAILED
("OTHER EXCEPTION RAISED - 4");
191 W
:= (B
=> (DD
=> 1, DCOMP1
=> 2));
192 FAILED
("CONSTRAINT_ERROR NOT RAISED - 5");
193 IF REC2_EQUAL
(W
,W
) THEN
194 COMMENT
("DON'T OPTIMIZE W");
197 WHEN CONSTRAINT_ERROR
=>
200 FAILED
("OTHER EXCEPTION RAISED - 5");
204 X
:= (D3
=> 1, C
=> (D
=> 5, COMP1
=> 2));
205 FAILED
("CONSTRAINT_ERROR NOT RAISED - 6");
206 IF REC3_EQUAL
(X
,X
) THEN
207 COMMENT
("DON'T OPTIMIZE X");
210 WHEN CONSTRAINT_ERROR
=>
213 FAILED
("OTHER EXCEPTION RAISED - 6");
217 Y
:= (H
=> INIT
(1));
218 FAILED
("CONSTRAINT_ERROR NOT RAISED - 7");
219 IF REC7_EQUAL
(Y
,Y
) THEN
220 COMMENT
("DON'T OPTIMIZE Y");
223 WHEN CONSTRAINT_ERROR
=>
226 FAILED
("OTHER EXCEPTION RAISED - 7");