| -- C41307D.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 L.R IS ALLOWED INSIDE A PACKAGE, GENERIC PACKAGE, |
| -- SUBPROGRAM, GENERIC SUBPROGRAM, TASK, BLOCK, LOOP, OR AN ACCEPT |
| -- STATEMENT NAMED L, IF R IS DECLARED INSIDE THE UNIT. |
| |
| -- TBN 12/15/86 |
| |
| WITH REPORT; USE REPORT; |
| PROCEDURE C41307D IS |
| |
| BEGIN |
| TEST ("C41307D", "CHECK THAT L.R IS ALLOWED INSIDE A PACKAGE, " & |
| "GENERIC PACKAGE, SUBPROGRAM, GENERIC " & |
| "SUBPROGRAM, TASK, BLOCK, LOOP, OR AN ACCEPT " & |
| "STATEMENT NAMED L, IF R IS DECLARED INSIDE " & |
| "THE UNIT"); |
| DECLARE |
| PACKAGE L IS |
| R : INTEGER := 5; |
| A : INTEGER := L.R; |
| END L; |
| |
| PACKAGE BODY L IS |
| B : INTEGER := L.R + 1; |
| BEGIN |
| IF IDENT_INT(A) /= 5 OR IDENT_INT(B) /= 6 THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED NAME - 1"); |
| END IF; |
| END L; |
| |
| GENERIC |
| S : INTEGER; |
| PACKAGE M IS |
| X : INTEGER := M.S; |
| END M; |
| |
| PACKAGE BODY M IS |
| Y : INTEGER := M.S + 1; |
| BEGIN |
| IF IDENT_INT(X) /= 2 OR |
| IDENT_INT(Y) /= 3 OR |
| IDENT_INT(M.X) /= 2 THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED NAME - 2"); |
| END IF; |
| END M; |
| |
| PACKAGE Q IS NEW M(2); |
| BEGIN |
| IF IDENT_INT(Q.X) /= 2 THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED NAME - 3"); |
| END IF; |
| END; |
| ------------------------------------------------------------------- |
| |
| DECLARE |
| CH : CHARACTER := '6'; |
| |
| PROCEDURE L (R : IN OUT CHARACTER) IS |
| A : CHARACTER := L.R; |
| BEGIN |
| IF IDENT_CHAR(L.A) /= '6' THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED NAME - 4"); |
| END IF; |
| L.R := IDENT_CHAR('7'); |
| END L; |
| |
| GENERIC |
| S : CHARACTER; |
| PROCEDURE M; |
| |
| PROCEDURE M IS |
| T : CHARACTER := M.S; |
| BEGIN |
| IF IDENT_CHAR(T) /= '3' OR IDENT_CHAR(M.S) /= '3' THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED NAME - 5"); |
| END IF; |
| END M; |
| |
| PROCEDURE P1 IS NEW M('3'); |
| |
| BEGIN |
| L (CH); |
| IF CH /= IDENT_CHAR('7') THEN |
| FAILED ("INCORRECT RESULTS RETURNED FROM PROCEDURE - 6"); |
| END IF; |
| P1; |
| END; |
| ------------------------------------------------------------------- |
| |
| DECLARE |
| INT : INTEGER := 3; |
| |
| FUNCTION L (R : INTEGER) RETURN INTEGER IS |
| A : INTEGER := L.R; |
| BEGIN |
| IF IDENT_INT(L.A) /= IDENT_INT(3) THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED NAME - 7"); |
| END IF; |
| RETURN IDENT_INT(4); |
| END L; |
| |
| GENERIC |
| S : INTEGER; |
| FUNCTION M RETURN INTEGER; |
| |
| FUNCTION M RETURN INTEGER IS |
| T : INTEGER := M.S; |
| BEGIN |
| IF IDENT_INT(M.T) /= 4 OR M.S /= IDENT_INT(4) THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED NAME - 8"); |
| END IF; |
| RETURN IDENT_INT(1); |
| END M; |
| |
| FUNCTION F1 IS NEW M(4); |
| |
| BEGIN |
| IF L(INT) /= 4 OR F1 /= 1 THEN |
| FAILED ("INCORRECT RESULTS RETURNED FROM FUNCTION - 9"); |
| END IF; |
| END; |
| ------------------------------------------------------------------- |
| |
| DECLARE |
| TASK L IS |
| ENTRY E (A : INTEGER); |
| END L; |
| |
| TASK TYPE M IS |
| ENTRY E1 (A : INTEGER); |
| END M; |
| |
| T1 : M; |
| |
| TASK BODY L IS |
| X : INTEGER := IDENT_INT(1); |
| R : INTEGER RENAMES X; |
| Y : INTEGER := L.R; |
| BEGIN |
| X := X + L.R; |
| IF X /= IDENT_INT(2) OR Y /= IDENT_INT(1) THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED NAME - " & |
| "10"); |
| END IF; |
| END L; |
| |
| TASK BODY M IS |
| X : INTEGER := IDENT_INT(2); |
| R : INTEGER RENAMES X; |
| Y : INTEGER := M.R; |
| BEGIN |
| ACCEPT E1 (A : INTEGER) DO |
| X := X + M.R; |
| IF X /= IDENT_INT(4) OR Y /= IDENT_INT(2) THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED " & |
| "NAME - 11"); |
| END IF; |
| IF E1.A /= IDENT_INT(3) THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED " & |
| "NAME - 12"); |
| END IF; |
| END E1; |
| END M; |
| BEGIN |
| T1.E1 (3); |
| END; |
| ------------------------------------------------------------------- |
| |
| DECLARE |
| TASK T IS |
| ENTRY G (1..2) (A : INTEGER); |
| END T; |
| |
| TASK BODY T IS |
| BEGIN |
| ACCEPT G (1) (A : INTEGER) DO |
| IF G.A /= IDENT_INT(2) THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED " & |
| "NAME - 13"); |
| END IF; |
| BLK: |
| DECLARE |
| B : INTEGER := 7; |
| BEGIN |
| IF T.BLK.B /= IDENT_INT(7) THEN |
| FAILED ("INCORRECT RESULTS FROM " & |
| "EXPANDED NAME - 14"); |
| END IF; |
| END BLK; |
| END G; |
| ACCEPT G (2) (A : INTEGER) DO |
| IF G.A /= IDENT_INT(1) THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED " & |
| "NAME - 15"); |
| END IF; |
| END G; |
| END T; |
| BEGIN |
| T.G (1) (2); |
| T.G (2) (1); |
| END; |
| ------------------------------------------------------------------- |
| |
| SWAP: |
| DECLARE |
| VAR : CHARACTER := '*'; |
| RENAME_VAR : CHARACTER RENAMES VAR; |
| NEW_VAR : CHARACTER; |
| BEGIN |
| IF EQUAL (3, 3) THEN |
| NEW_VAR := SWAP.RENAME_VAR; |
| END IF; |
| IF NEW_VAR /= IDENT_CHAR('*') THEN |
| FAILED ("INCORRECT RESULTS FROM EXPANDED NAME - " & |
| "16"); |
| END IF; |
| LP: FOR I IN 1..2 LOOP |
| IF SWAP.LP.I = IDENT_INT(2) OR |
| LP.I = IDENT_INT(1) THEN |
| GOTO SWAP.LAB1; |
| END IF; |
| NEW_VAR := IDENT_CHAR('+'); |
| <<LAB1>> |
| NEW_VAR := IDENT_CHAR('-'); |
| END LOOP LP; |
| IF NEW_VAR /= IDENT_CHAR('-') THEN |
| FAILED ("INCORRECT RESULTS FROM FOR LOOP - 17"); |
| END IF; |
| END SWAP; |
| |
| RESULT; |
| END C41307D; |