blob: 92c94d03391311531ea993d0301074903e84ce4f [file] [log] [blame]
-- CC1301A.ADA
-- Grant of Unlimited Rights
--
-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
-- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
-- unlimited rights in the software and documentation contained herein.
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
-- this public release, the Government intends to confer upon all
-- recipients unlimited rights equal to those held by the Government.
-- These rights include rights to use, duplicate, release or disclose the
-- released technical data and computer software in whole or in part, in
-- any manner and for any purpose whatsoever, and to have or permit others
-- to do so.
--
-- DISCLAIMER
--
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
-- PARTICULAR PURPOSE OF SAID MATERIAL.
--*
-- CHECK THAT DEFAULT GENERIC SUBPROGRAM PARAMETERS WORK CORRECTLY,
-- INCLUDING OVERLOADED AND PREDEFINED OPERATOR_SYMBOLS,
-- AND SUBPROGRAMS HIDDEN AT THE INSTANTIATION.
-- BOTH KINDS OF DEFAULTS ARE TESTED, FOR BOTH PROCEDURES
-- AND FUNCTIONS.
-- DAT 8/14/81
-- JBG 5/5/83
-- JBG 8/3/83
WITH REPORT; USE REPORT;
PROCEDURE CC1301A IS
FUNCTION "-" (R, S : INTEGER) RETURN INTEGER;
FUNCTION NEXT (X : INTEGER) RETURN INTEGER;
PROCEDURE BUMP (X : IN OUT INTEGER);
GENERIC
WITH FUNCTION "*" (A, B : INTEGER) RETURN INTEGER IS "-";
WITH FUNCTION "+" (R, S: INTEGER) RETURN INTEGER IS
STANDARD."+";
WITH FUNCTION "-" (A, B : INTEGER) RETURN INTEGER IS <> ;
WITH FUNCTION NEXTO (Q : INTEGER) RETURN INTEGER IS NEXT ;
WITH PROCEDURE BUMPO (A : IN OUT INTEGER) IS BUMP;
WITH FUNCTION NEXT (Q : INTEGER) RETURN INTEGER IS <> ;
WITH PROCEDURE BUMP (Q : IN OUT INTEGER) IS <> ;
TYPE INTEGER IS RANGE <> ;
WITH FUNCTION "*" (A , B : INTEGER) RETURN INTEGER IS <> ;
WITH FUNCTION "-" (A, B : INTEGER) RETURN INTEGER IS <> ;
WITH FUNCTION NEXT (Q : INTEGER) RETURN INTEGER IS <> ;
WITH PROCEDURE BUMP (Z : IN OUT INTEGER) IS <> ;
PACKAGE PKG IS
SUBTYPE INT IS STANDARD.INTEGER;
DIFF : INT := -999;
END PKG;
TYPE NEWINT IS NEW INTEGER RANGE -1000 .. 1000;
FUNCTION PLUS (Q1, Q2 : INTEGER) RETURN INTEGER RENAMES "+";
FUNCTION "+" (X, Y : INTEGER) RETURN INTEGER IS
BEGIN
RETURN PLUS (X, PLUS (Y, -10));
-- (X + Y - 10)
END "+";
FUNCTION "-" (R, S : INTEGER) RETURN INTEGER IS
BEGIN
RETURN - R + S;
-- (-R + S - 10)
END "-";
FUNCTION NEXT (X : INTEGER) RETURN INTEGER IS
BEGIN
RETURN X + 1;
-- (X + 1 - 10)
-- (X - 9)
END NEXT;
PROCEDURE BUMP (X : IN OUT INTEGER) IS
BEGIN
X := NEXT (X);
-- (X := X - 9)
END BUMP;
PACKAGE BODY PKG IS
W : INTEGER;
WI : INT;
BEGIN
W := NEXT (INTEGER'(3) * 4 - 2);
-- (W := (4 ** 3 - 2) - 1)
-- (W := 61)
BUMP (W);
-- (W := 61 + 7)
-- (W := 68)
WI := NEXT (INT'(3) * 4 - 2 + NEXTO (0));
-- (3 * 4) => (3 - 4) => (-3 + 4 - 10) = -9
-- ((-9) - 2) => (2 + 2 - (-9) - 20) = -7
-- (-7 + (-9)) => -16
-- (WI := 7 - (-16)) => (WI := 23)
BUMPO (WI);
-- (WI := 23 - 9) (= 14)
BUMP (WI);
-- (WI := 14 - 9) (= 5)
DIFF := STANDARD."-" (INT(W), WI);
-- (DIFF := 68 - 5) (= 63)
END PKG;
FUNCTION "*" (Y, X : NEWINT) RETURN NEWINT IS
BEGIN
RETURN X ** INTEGER(Y);
-- (X,Y) (Y ** X)
END "*";
FUNCTION NEXT (Z : NEWINT) RETURN NEWINT IS
BEGIN
RETURN Z - 1;
-- (Z - 1)
END NEXT;
PROCEDURE BUMP (ZZ : IN OUT NEWINT) IS
BEGIN
FAILED ("WRONG PROCEDURE CALLED");
END BUMP;
BEGIN
TEST ("CC1301A", "DEFAULT GENERIC SUBPROGRAM PARAMETERS");
DECLARE
PROCEDURE BUMP (QQQ : IN OUT NEWINT) IS
BEGIN
QQQ := QQQ + 7;
-- (QQQ + 7)
END BUMP;
FUNCTION NEXT (Q7 : INTEGER) RETURN INTEGER IS
BEGIN
RETURN Q7 - 17;
-- (-Q7 + 17 - 10)
-- (7 - Q7)
END NEXT;
FUNCTION "-" (Q3, Q4 : INTEGER) RETURN INTEGER IS
BEGIN
RETURN -Q3 + Q4 + Q4;
-- (-Q3 + Q4 - 10 + Q4 - 10) = (Q4 + Q4 - Q3 - 20)
END "-";
PACKAGE P1 IS NEW PKG (INTEGER => NEWINT);
BEGIN
IF P1.DIFF /= 63 THEN
FAILED ("WRONG DEFAULT SUBPROGRAM PARAMETERS");
END IF;
END;
RESULT;
END CC1301A;