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 WHEN A SIZE SPECIFICATION OF THE SMALLEST APPROPRIATE
27 -- UNSIGNED SIZE IS GIVEN FOR AN INTEGER TYPE, THE TYPE CAN BE
28 -- PASSED AS AN ACTUAL PARAMETER TO GENERIC PROCEDURES.
31 -- JET 08/12/87 CREATED ORIGINAL TEST.
32 -- DHH 04/11/89 CHANGED EXTENSION FROM '.DEP' TO '.ADA', CHANGED
33 -- SIZE CLAUSE VALUE TO 7, AND CHANGED OPERATOR ON
35 -- JRL 03/27/92 ELIMINATED REDUNDANT TESTING.
37 WITH REPORT
; USE REPORT
;
41 TYPE BASIC_INT
IS RANGE 0 .. 126;
42 BASIC_SIZE
: CONSTANT := 7;
44 FOR BASIC_INT
'SIZE USE BASIC_SIZE
;
48 TEST
("CD2A32J", "CHECK THAT WHEN A SIZE SPECIFICATION " &
49 "OF THE SMALLEST APPROPRIATE UNSIGNED SIZE " &
50 "IS GIVEN FOR AN INTEGER TYPE, THE TYPE " &
51 "CAN BE PASSED AS AN ACTUAL PARAMETER TO " &
52 "GENERIC PROCEDURES");
54 DECLARE -- TYPE DECLARATION WITHIN GENERIC PROCEDURE.
57 TYPE GPARM
IS RANGE <>;
68 FUNCTION IDENT
(I
: INT
) RETURN INT
IS
79 IF INT
'SIZE /= IDENT_INT
(BASIC_SIZE
) THEN
80 FAILED
("INCORRECT VALUE FOR INT'SIZE");
83 IF I0
'SIZE < IDENT_INT
(BASIC_SIZE
) THEN
84 FAILED
("INCORRECT VALUE FOR I0'SIZE");
87 IF NOT ((I0
< IDENT
(1)) AND
88 (IDENT
(I2
) > IDENT
(I1
)) AND
89 (I1
<= IDENT
(63)) AND
90 (IDENT
(126) = I2
)) THEN
91 FAILED
("INCORRECT RESULTS FOR RELATIONAL " &
95 IF NOT (((I0
+ I2
) = I2
) AND
97 ((I1
* IDENT
(2)) = I2
) AND
98 ((I2
/ I1
) = IDENT
(2)) AND
99 ((I1
** 1) = IDENT
(63)) AND
100 ((I2
REM 10) = IDENT
(6)) AND
101 ((I1
MOD 10) = IDENT
(3))) THEN
102 FAILED
("INCORRECT RESULTS FOR BINARY ARITHMETIC " &
106 IF INT
'POS (I0
) /= IDENT_INT
(0) OR
107 INT
'POS (I1
) /= IDENT_INT
(63) OR
108 INT
'POS (I2
) /= IDENT_INT
(126) THEN
109 FAILED
("INCORRECT VALUE FOR INT'POS");
112 IF INT
'SUCC (I0
) /= IDENT
(1) OR
113 INT
'SUCC (I1
) /= IDENT
(64) THEN
114 FAILED
("INCORRECT VALUE FOR INT'SUCC");
117 IF INT
'IMAGE (I0
) /= IDENT_STR
(" 0") OR
118 INT
'IMAGE (I1
) /= IDENT_STR
(" 63") OR
119 INT
'IMAGE (I2
) /= IDENT_STR
(" 126") THEN
120 FAILED
("INCORRECT VALUE FOR INT'IMAGE");
125 PROCEDURE NEWPROC
IS NEW GENPROC
(BASIC_INT
);