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 + -
显示快捷键?