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.
25 -- CHECK THAT AN UNCONSTRAINED FORMAL GENERIC PARAMETER OF MODE "IN"
26 -- HAVING AN ARRAY TYPE OR A TYPE WITH DISCRIMINANTS HAS THE CONSTRAINTS
27 -- OF THE ACTUAL PARAMETER.
31 WITH REPORT
; USE REPORT
;
34 SUBTYPE INT
IS INTEGER RANGE 1 .. 10;
36 TYPE ARRAY1
IS ARRAY (INT
RANGE <>) OF INTEGER;
38 TYPE REC1
(D
: INT
) IS
43 TYPE REC2
(D
: INT
:= 2) IS
45 A
: ARRAY1
(D
.. IDENT_INT
(4));
50 TYPE ARRAY2
IS ARRAY (INT
RANGE <>) OF REC2
;
53 TEST
("CC3121A", "CHECK THAT AN UNCONSTRAINED FORMAL GENERIC " &
54 "PARAMETER OF MODE 'IN' HAVING AN ARRAY TYPE " &
55 "OR A TYPE WITH DISCRIMINANTS HAS THE " &
56 "CONSTRAINTS OF THE ACTUAL PARAMETER");
59 OBJ_ARA1
: ARRAY1
(IDENT_INT
(2) .. 5);
67 IF VAR
'FIRST /= IDENT_INT
(2) THEN
68 FAILED
("INCORRECT RESULTS FOR VAR'FIRST");
70 IF VAR
'LAST /= IDENT_INT
(5) THEN
71 FAILED
("INCORRECT RESULTS FOR VAR'LAST");
75 PROCEDURE PROC1
IS NEW PROC
(OBJ_ARA1
);
80 -------------------------------------------------------------------
86 FUNCTION FUNC
RETURN INTEGER;
88 FUNCTION FUNC
RETURN INTEGER IS
90 IF VAR
.D
/= IDENT_INT
(2) THEN
91 FAILED
("INCORRECT RESULTS FROM VAR.D");
93 IF VAR
.A
'FIRST /= IDENT_INT
(2) THEN
94 FAILED
("INCORRECT RESULTS FROM VAR.A'FIRST");
96 IF VAR
.A
'LAST /= IDENT_INT
(4) THEN
97 FAILED
("INCORRECT RESULTS FROM VAR.A'LAST");
99 IF VAR
.B
.D
/= IDENT_INT
(2) THEN
100 FAILED
("INCORRECT RESULTS FROM VAR.B.D");
105 FUNCTION FUNC1
IS NEW FUNC
(OBJ_REC2
);
108 IF FUNC1
/= IDENT_INT
(1) THEN
109 FAILED
("INCORRECT RESULTS FROM FUNC1 CALL");
113 -------------------------------------------------------------------
115 OBJ_ARA2
: ARRAY2
(IDENT_INT
(6) .. 8);
123 IF VAR
'FIRST /= IDENT_INT
(6) THEN
124 FAILED
("INCORRECT RESULTS FOR VAR'FIRST");
126 IF VAR
'LAST /= IDENT_INT
(8) THEN
127 FAILED
("INCORRECT RESULTS FOR VAR'LAST");
129 IF VAR
(6).D
/= IDENT_INT
(2) THEN
130 FAILED
("INCORRECT RESULTS FROM VAR(6).D");
132 IF VAR
(6).A
'FIRST /= IDENT_INT
(2) THEN
133 FAILED
("INCORRECT RESULTS FROM VAR(6).A'FIRST");
135 IF VAR
(6).A
'LAST /= IDENT_INT
(4) THEN
136 FAILED
("INCORRECT RESULTS FROM VAR(6).A'LAST");
138 IF VAR
(6).B
.D
/= IDENT_INT
(2) THEN
139 FAILED
("INCORRECT RESULTS FROM VAR(6).B.D");
143 PROCEDURE PROC2
IS NEW PROC
(OBJ_ARA2
);
148 -------------------------------------------------------------------
155 PAC_VAR
: INTEGER := 1;
160 IF VAR
.D
/= IDENT_INT
(3) THEN
161 FAILED
("INCORRECT RESULTS FROM VAR.D");
163 IF VAR
.A
'FIRST /= IDENT_INT
(3) THEN
164 FAILED
("INCORRECT RESULTS FROM VAR.A'FIRST");
166 IF VAR
.A
'LAST /= IDENT_INT
(4) THEN
167 FAILED
("INCORRECT RESULTS FROM VAR.A'LAST");
169 IF VAR
.B
.D
/= IDENT_INT
(3) THEN
170 FAILED
("INCORRECT RESULTS FROM VAR.B.D");
174 PACKAGE PAC1
IS NEW PAC
(OBJ_REC3
);
180 -------------------------------------------------------------------