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 IF PARAMETERS OF DEFAULT AND FORMAL SUBPROGRAMS HAVE
27 -- THE SAME TYPE BUT NOT THE SAME SUBTYPE, THE PARAMETER SUBTYPES OF
28 -- THE SUBPROGRAM DENOTED BY THE DEFAULT ARE USED INSTEAD OF
29 -- SUBTYPES SPECIFIED IN THE FORMAL SUBPROGRAM DECLARATION.
32 -- RJW 06/11/86 CREATED ORIGINAL TEST.
33 -- DHH 10/20/86 CORRECTED RANGE ERRORS.
34 -- PWN 01/31/95 REMOVED INCONSISTENCIES WITH ADA 9X.
35 -- PWN 10/27/95 REMOVED CHECKS AGAINST ARRAY SLIDING RULES THAT
37 -- PWN 10/25/96 RESTORED CHECKS WITH NEW ADA 95 EXPECTED RESULTS.
39 WITH REPORT
; USE REPORT
;
44 TEST
("CC1311B", "CHECK THAT IF PARAMETERS OF DEFAULT AND " &
45 "FORMAL SUBPROGRAMS HAVE THE SAME TYPE BUT " &
46 "NOT THE SAME SUBTYPE, THE PARAMETER SUBTYPES " &
47 "OF THE SUBPROGRAM DENOTED BY THE DEFAULT ARE " &
48 "USED INSTEAD OF SUBTYPES SPECIFIED IN THE " &
49 "FORMAL SUBPROGRAM DECLARATION" );
52 TYPE NUMBERS
IS (ZERO
, ONE
,TWO
);
53 SUBTYPE ZERO_TWO
IS NUMBERS
;
54 SUBTYPE ZERO_ONE
IS NUMBERS
RANGE ZERO
.. ONE
;
56 FUNCTION FSUB
(X
: ZERO_ONE
) RETURN ZERO_ONE
IS
58 RETURN NUMBERS
'VAL (IDENT_INT
(NUMBERS
'POS (ONE
)));
62 WITH FUNCTION F
(X
: ZERO_TWO
:= TWO
) RETURN ZERO_TWO
64 FUNCTION FUNC
RETURN ZERO_TWO
;
66 FUNCTION FUNC
RETURN ZERO_TWO
IS
70 WHEN CONSTRAINT_ERROR
=>
73 FAILED
( "WRONG EXCEPTION RAISED WITH " &
78 FUNCTION NFUNC1
IS NEW FUNC
;
82 FAILED
( "NO EXCEPTION RAISED WITH NFUNC1" );
87 TYPE GENDER
IS (MALE
, FEMALE
);
89 TYPE PERSON
(SEX
: GENDER
) IS
99 SUBTYPE MAN
IS PERSON
(SEX
=> MALE
);
100 SUBTYPE TESTWRITER
IS PERSON
(FEMALE
);
102 ROSA
: TESTWRITER
:= (FEMALE
, 4);
104 FUNCTION F
(X
: MAN
) RETURN PERSON
IS
105 TOM
: PERSON
(MALE
) := (MALE
, FALSE);
117 WITH FUNCTION F
(X
: T
) RETURN T
IS <> ;
118 PACKAGE PKG
IS END PKG
;
123 FAILED
( "NO EXCEPTION RAISED WITH " &
124 "FUNCTION 'F' AND PACKAGE " &
127 FAILED
( "NO EXCEPTION RAISED WITH " &
128 "FUNCTION 'F' AND PACKAGE " &
132 WHEN CONSTRAINT_ERROR
=>
135 FAILED
( "WRONG EXCEPTION RAISED WITH " &
136 "FUNCTION 'F' AND PACKAGE 'PKG'" );
139 PACKAGE NPKG
IS NEW PKG
(TESTWRITER
, ROSA
);
142 COMMENT
( "PACKAGE BODY ELABORATED - 1" );
146 TYPE VECTOR
IS ARRAY (POSITIVE RANGE <>) OF INTEGER;
147 SUBTYPE SUBV1
IS VECTOR
(1 .. 5);
148 SUBTYPE SUBV2
IS VECTOR
(2 .. 6);
150 V1
: SUBV1
:= (1, 2, 3, 4, 5);
152 FUNCTION FSUB
(Y
: SUBV2
) RETURN VECTOR
IS
155 FOR I
IN Y
'RANGE LOOP
156 Z
(I
) := IDENT_INT
(Y
(I
));
162 WITH FUNCTION F
(X
: SUBV1
:= V1
) RETURN SUBV1
IS FSUB
;
168 COMMENT
( "NO EXCEPTION RAISED WITH " &
169 "FUNCTION 'F' AND PROCEDURE " &
172 COMMENT
( "NO EXCEPTION RAISED WITH " &
173 "FUNCTION 'F' AND PROCEDURE " &
177 WHEN CONSTRAINT_ERROR
=>
178 FAILED
( "CONSTRAINT_ERROR RAISED WITH " &
179 "FUNCTION 'F' AND PROCEDURE " &
182 FAILED
( "WRONG EXCEPTION RAISED WITH " &
183 "FUNCTION 'F' AND PROCEDURE " &
187 PROCEDURE NPROC
IS NEW PROC
;
194 TYPE ACC
IS ACCESS STRING;
196 SUBTYPE INDEX1
IS INTEGER RANGE 1 .. 5;
197 SUBTYPE INDEX2
IS INTEGER RANGE 2 .. 6;
199 SUBTYPE ACC1
IS ACC
(INDEX1
);
200 SUBTYPE ACC2
IS ACC
(INDEX2
);
202 AC2
: ACC2
:= NEW STRING'(2 .. 6 => 'A
');
205 PROCEDURE P (RESULTS : OUT ACC1; X : ACC1) IS
211 WITH PROCEDURE P1 (RESULTS : OUT ACC2; X : ACC2 := AC2)
213 FUNCTION FUNC RETURN ACC;
215 FUNCTION FUNC RETURN ACC IS
221 WHEN CONSTRAINT_ERROR =>
222 RETURN NEW STRING'("ABCDE");
224 FAILED
( "WRONG EXCEPTION RAISED WITH " &
229 FUNCTION NFUNC2
IS NEW FUNC
;
233 IF AC
= NULL OR ELSE AC
.ALL /= "ABCDE" THEN
234 FAILED
( "NO OR WRONG EXCEPTION RAISED WITH NFUNC2" );
239 SUBTYPE FLOAT1
IS FLOAT RANGE -1.0 .. 0.0;
240 SUBTYPE FLOAT2
IS FLOAT RANGE 0.0 .. 1.0;
242 PROCEDURE PSUB
(RESULTS
: OUT FLOAT2
; X
: FLOAT2
) IS
252 WITH PROCEDURE P
(RESULTS
: OUT FLOAT1
;
253 X
: FLOAT1
:= -0.0625) IS PSUB
;
254 PACKAGE PKG
IS END PKG
;
260 IF RESULTS
= 1.0 THEN
261 FAILED
( "NO EXCEPTION RAISED WITH " &
262 "PROCEDURE 'P' AND PACKAGE " &
265 FAILED
( "NO EXCEPTION RAISED WITH " &
266 "PROCEDURE 'P' AND PACKAGE " &
270 WHEN CONSTRAINT_ERROR
=>
273 FAILED
( "WRONG EXCEPTION RAISED WITH " &
274 "PROCEDURE 'P' AND PACKAGE 'PKG'" );
277 PACKAGE NPKG
IS NEW PKG
;
279 COMMENT
( "PACKAGE BODY ELABORATED - 2" );
283 TYPE FIXED
IS DELTA 0.125 RANGE -1.0 .. 1.0;
284 SUBTYPE FIXED1
IS FIXED
RANGE -0.5 .. 0.0;
285 SUBTYPE FIXED2
IS FIXED
RANGE 0.0 .. 0.5;
287 PROCEDURE P
(RESULTS
: OUT FIXED1
; X
: FIXED1
) IS
299 WITH PROCEDURE P
(RESULTS
: OUT F
; X
: F
) IS <> ;
306 IF RESULTS
= 0.0 THEN
307 FAILED
( "NO EXCEPTION RAISED WITH " &
308 "PROCEDURE 'P' AND PROCEDURE " &
311 FAILED
( "NO EXCEPTION RAISED WITH " &
312 "PROCEDURE 'P' AND PROCEDURE " &
316 WHEN CONSTRAINT_ERROR
=>
319 FAILED
( "WRONG EXCEPTION RAISED WITH " &
320 "PROCEDURE 'P' AND PROCEDURE " &
324 PROCEDURE NPROC
IS NEW PROC
(FIXED2
, 0.125);