c41307d.ada
来自「用于进行gcc测试」· ADA 代码 · 共 256 行
ADA
256 行
-- 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/86WITH REPORT; USE REPORT;PROCEDURE C41307D ISBEGIN 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;
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?