| -- C85013A.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: |
| |
| -- A) A SUBPROGRAM OR ENTRY CAN BE RENAMED WITH: |
| -- A1) DIFFERENT PARAMETER NAMES; |
| -- A2) DIFFERENT DEFAULT VALUES; |
| -- A3) DIFFERENT PARAMETERS HAVING DEFAULT VALUES; |
| -- AND THAT THE NEW NAMES/DEFAULTS ARE USED WHEN THE NEW NAME |
| -- IS USED IN A CALL. |
| |
| -- B) FORMAL PARAMETER CONSTRAINTS FOR THE NEW NAME ARE IGNORED IN |
| -- FAVOR OF THE CONSTRAINTS ASSOCIATED WITH THE RENAMED ENTITY. |
| |
| -- EG 02/22/84 |
| |
| WITH REPORT; |
| |
| PROCEDURE C85013A IS |
| |
| USE REPORT; |
| |
| BEGIN |
| |
| TEST("C85013A","CHECK THAT A SUBPROGRAM CAN BE RENAMED AND " & |
| "THAT THE NEW NAMES/DEFAULTS ARE USED WITH " & |
| "THE CONSTRAINTS ASSOCIATED WITH THE RENAMED" & |
| " ENTITY"); |
| |
| DECLARE |
| |
| TYPE TA IS ARRAY(1 .. 5) OF INTEGER; |
| |
| FUNCTION PROC1 (A : INTEGER := 1; |
| B : TA := (1 .. 5 => 1)) RETURN INTEGER; |
| FUNCTION PROCA (C : INTEGER := 1; |
| D : TA := (1 .. 5 => 1)) RETURN INTEGER |
| RENAMES PROC1; |
| FUNCTION PROCB (B : INTEGER := 1; |
| A : TA := (1 .. 5 => 1)) RETURN INTEGER |
| RENAMES PROC1; |
| FUNCTION PROCC (A : INTEGER := 2; |
| B : TA := (1, 2, 3, 4, 5)) RETURN INTEGER |
| RENAMES PROC1; |
| FUNCTION PROCD (C : INTEGER := 2; |
| D : TA := (1, 2, 3, 4, 5))RETURN INTEGER |
| RENAMES PROC1; |
| |
| FUNCTION PROC1 (A : INTEGER := 1; |
| B : TA := (1 .. 5 => 1)) RETURN INTEGER IS |
| BEGIN |
| FOR I IN 1 .. 5 LOOP |
| IF A = B(I) THEN |
| RETURN I; |
| END IF; |
| END LOOP; |
| RETURN 0; |
| END PROC1; |
| |
| BEGIN |
| |
| IF PROC1 /= 1 THEN |
| FAILED ("CASE A : PARAMETERS NOT PROPERLY INITIALIZED"); |
| END IF; |
| IF PROC1(A => 2) /= 0 THEN |
| FAILED ("CASE A : INCORRECT RESULT"); |
| END IF; |
| IF PROCA /= 1 THEN |
| FAILED ("CASE A1 : INCORRECT RESULT (DEFAULT)"); |
| END IF; |
| IF PROCA(D => (5, 4, 3, 2, 1)) /= 5 THEN |
| FAILED ("CASE A1 : INCORRECT RESULT"); |
| END IF; |
| IF PROCB /= 1 THEN |
| FAILED ("CASE A1 : INCORRECT RESULT (DEFAULT)"); |
| END IF; |
| IF PROCB(A => (5, 4, 3, 2, 1), B => 2) /= 4 THEN |
| FAILED ("CASE A1 : INCORRECT RESULT "); |
| END IF; |
| IF PROCC /= 2 THEN |
| FAILED ("CASE A2 : INCORRECT RESULT (DEFAULT)"); |
| END IF; |
| IF PROCC(3) /= 3 THEN |
| FAILED ("CASE A2 : INCORRECT RESULT "); |
| END IF; |
| IF PROCD /= 2 THEN |
| FAILED ("CASE A2 : INCORRECT RESULT (DEFAULT)"); |
| END IF; |
| IF PROCD(4) /= 4 THEN |
| FAILED ("CASE A2 : INCORRECT RESULT "); |
| END IF; |
| |
| END; |
| |
| DECLARE |
| |
| TYPE TA IS ARRAY (INTEGER RANGE <>) OF INTEGER; |
| SUBTYPE STA1 IS TA(1 .. 5); |
| SUBTYPE STA2 IS TA(11 .. 15); |
| |
| PROCEDURE PROC1 (A : STA1; |
| ID : STRING); |
| PROCEDURE PROC2 (A : STA2; |
| ID : STRING) RENAMES PROC1; |
| |
| PROCEDURE PROC1 (A : STA1; |
| ID : STRING) IS |
| BEGIN |
| IF A'FIRST /= IDENT_INT(1) THEN |
| FAILED ("CASE B : INCORRECT LOWER BOUND " & |
| "GENERATED BY " & ID); |
| END IF; |
| IF A'LAST /= IDENT_INT(5) THEN |
| FAILED ("CASE B : INCORRECT UPPER BOUND " & |
| "GENERATED BY " & ID); |
| END IF; |
| END PROC1; |
| |
| BEGIN |
| |
| PROC1 ((1, 2, 3, 4, 5),"PROC1"); |
| PROC2 ((6, 7, 8, 9, 10),"PROC2"); |
| |
| END; |
| |
| RESULT; |
| |
| END C85013A; |