-- C85014A.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. --* -- OBJECTIVE: -- CHECK THAT THE NUMBER OF FORMAL PARAMETERS IS USED TO DETERMINE -- WHICH SUBPROGRAM OR ENTRY IS BEING RENAMED. -- HISTORY: -- JET 03/24/88 CREATED ORIGINAL TEST. -- BCB 04/18/90 CORRECTED ERROR MESSAGE FOR ENTRY2. -- RLB 03/19/07 Fixed limited returns to be compatible with Amendment 1. WITH REPORT; USE REPORT; PROCEDURE C85014A IS TASK TYPE T1 IS ENTRY ENTER (I1: IN OUT INTEGER); ENTRY STOP; END T1; TASK TYPE T2 IS ENTRY ENTER (I1, I2: IN OUT INTEGER); ENTRY STOP; END T2; Task1 : aliased T1; Task2 : aliased T2; function F return access T1 is begin return Task1'Access; end F; function F return access T2 is begin return Task2'Access; end F; PROCEDURE PROC (I1: IN OUT INTEGER) IS BEGIN I1 := I1 + 1; END PROC; PROCEDURE PROC (I1, I2: IN OUT INTEGER) IS BEGIN I1 := I1 + 2; I2 := I2 + 2; END PROC; TASK BODY T1 IS ACCEPTING_ENTRIES : BOOLEAN := TRUE; BEGIN WHILE ACCEPTING_ENTRIES LOOP SELECT ACCEPT ENTER (I1 : IN OUT INTEGER) DO I1 := I1 + 1; END ENTER; OR ACCEPT STOP DO ACCEPTING_ENTRIES := FALSE; END STOP; END SELECT; END LOOP; END T1; TASK BODY T2 IS ACCEPTING_ENTRIES : BOOLEAN := TRUE; BEGIN WHILE ACCEPTING_ENTRIES LOOP SELECT ACCEPT ENTER (I1, I2 : IN OUT INTEGER) DO I1 := I1 + 2; I2 := I2 + 2; END ENTER; OR ACCEPT STOP DO ACCEPTING_ENTRIES := FALSE; END STOP; END SELECT; END LOOP; END T2; BEGIN TEST ("C85014A", "CHECK THAT THE NUMBER OF FORMAL PARAMETERS IS " & "USED TO DETERMINE WHICH SUBPROGRAM OR ENTRY " & "IS BEING RENAMED"); DECLARE PROCEDURE PROC1 (J1: IN OUT INTEGER) RENAMES PROC; PROCEDURE PROC2 (J1, J2: IN OUT INTEGER) RENAMES PROC; PROCEDURE ENTRY1 (J1: IN OUT INTEGER) RENAMES F.ENTER; PROCEDURE ENTRY2 (J1, J2: IN OUT INTEGER) RENAMES F.ENTER; K1, K2 : INTEGER := 0; BEGIN PROC1(K1); IF K1 /= IDENT_INT(1) THEN FAILED("INCORRECT RETURN VALUE FROM PROC1"); END IF; ENTRY1(K2); IF K2 /= IDENT_INT(1) THEN FAILED("INCORRECT RETURN VALUE FROM ENTRY1"); END IF; PROC2(K1, K2); IF K1 /= IDENT_INT(3) OR K2 /= IDENT_INT(3) THEN FAILED("INCORRECT RETURN VALUE FROM PROC2"); END IF; ENTRY2(K1, K2); IF K1 /= IDENT_INT(5) OR K2 /= IDENT_INT(5) THEN FAILED("INCORRECT RETURN VALUE FROM ENTRY2"); END IF; END; TASK1.STOP; TASK2.STOP; RESULT; END C85014A;