c94001c.ada

来自「linux下编程用 编译软件」· ADA 代码 · 共 268 行

ADA
268
字号
-- C94001C.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 UNIT WITH INDIRECT DEPENDENT TASKS CREATED BY OBJECT-- DECLARATIONS IS NOT TERMINATED UNTIL ALL INDIRECT DEPENDENT TASKS-- BECOME TERMINATED.-- SUBTESTS ARE:--   (A, B)  A BLOCK CONTAINING A SIMPLE TASK OBJECT, IN A BLOCK.--   (C, D)  A FUNCTION CONTAINING AN ARRAY OF TASK OBJECT, IN A--           FUNCTION.--   (E, F)  A TASK CONTAINING AN ARRAY OF RECORD OF TASK OBJECT,--           IN A TASK BODY.--   CASES (B, D, F) EXIT BY RAISING AN EXCEPTION.-- THIS TEST CONTAINS SHARED VARIABLES AND RACE CONDITIONS.-- TBN  8/25/86-- PWN 01/31/95  REMOVED PRAGMA PRIORITY FOR ADA 9X.with Impdef;WITH REPORT; USE REPORT;WITH SYSTEM; USE SYSTEM;PROCEDURE C94001C IS     MY_EXCEPTION : EXCEPTION;     GLOBAL : INTEGER;     TASK TYPE TT IS          ENTRY E (I : INTEGER);     END TT;     TASK BODY TT IS          LOCAL : INTEGER;     BEGIN          ACCEPT E (I : INTEGER) DO               LOCAL := I;          END E;          DELAY 30.0 * Impdef.One_Second;    -- SINCE THE PARENT UNIT HAS HIGHER PRIORITY                         -- AT THIS POINT, IT WILL RECEIVE CONTROL AND                         -- TERMINATE IF THE ERROR IS PRESENT.          GLOBAL := LOCAL;     END TT;BEGIN     TEST ("C94001C", "CHECK THAT A UNIT WITH INDIRECT DEPENDENT " &                      "TASKS CREATED BY OBJECT DECLARATIONS IS NOT " &                      "TERMINATED UNTIL ALL INDIRECT DEPENDENT TASKS " &                      "BECOME TERMINATED");     --------------------------------------------------     GLOBAL := IDENT_INT (0);     BEGIN -- (A)          DECLARE               T : TT;          BEGIN               T.E (IDENT_INT(1));          END;     END; -- (A)     IF GLOBAL /= 1 THEN          FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &                  "BLOCK EXIT - 1");     END IF;     --------------------------------------------------     BEGIN -- (B)          GLOBAL := IDENT_INT (0);          BEGIN               DECLARE                    T : TT;               BEGIN                    T.E (IDENT_INT(2));                    RAISE MY_EXCEPTION;               END;          END;          FAILED ("MY_EXCEPTION WAS NOT RAISED - 2");     EXCEPTION          WHEN MY_EXCEPTION =>               IF GLOBAL /= 2 THEN                    FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &                            "BLOCK EXIT - 2");               END IF;          WHEN OTHERS =>               FAILED ("UNEXPECTED EXCEPTION - 2");     END; -- (B)     --------------------------------------------------     GLOBAL := IDENT_INT (0);     DECLARE -- (C)          OBJ_INT : INTEGER;          FUNCTION F1 RETURN INTEGER IS               I : INTEGER;               FUNCTION F2 RETURN INTEGER IS                    A : ARRAY (1..1) OF TT;               BEGIN                    A(1).E (IDENT_INT(3));                    RETURN 0;               END F2;          BEGIN               I := F2;               RETURN (0);          END F1;     BEGIN -- (C)          OBJ_INT := F1;          IF GLOBAL /= 3 THEN               FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &                       "FUNCTION EXIT - 3");          END IF;     END; -- (C)     --------------------------------------------------     DECLARE -- (D)          OBJ_INT : INTEGER;          FUNCTION F1 RETURN INTEGER IS               I : INTEGER;               FUNCTION F2 RETURN INTEGER IS                    A : ARRAY (1..1) OF TT;               BEGIN                    A(1).E (IDENT_INT(4));                    IF EQUAL (3, 3) THEN                         RAISE MY_EXCEPTION;                    END IF;                    RETURN 0;               END F2;          BEGIN               I := F2;               RETURN (0);          END F1;     BEGIN -- (D)          GLOBAL := IDENT_INT (0);          OBJ_INT := F1;          FAILED ("MY_EXCEPTION WAS NOT RAISED - 4");     EXCEPTION          WHEN MY_EXCEPTION =>               IF GLOBAL /= 4 THEN                    FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &                            "FUNCTION EXIT - 4");               END IF;          WHEN OTHERS =>               FAILED ("UNEXPECTED EXCEPTION - 4");     END; -- (D)     --------------------------------------------------     GLOBAL := IDENT_INT (0);     DECLARE -- (E)          DELAY_COUNT : INTEGER := 0;          TASK OUT_TSK;          TASK BODY OUT_TSK IS               TASK TSK IS                    ENTRY ENT;               END TSK;               TASK BODY TSK IS                    TYPE RT IS                         RECORD                              T : TT;                         END RECORD;                    AR : ARRAY (1..1) OF RT;               BEGIN                    AR(1).T.E (IDENT_INT(5));               END TSK;          BEGIN               NULL;          END OUT_TSK;     BEGIN -- (E)          WHILE NOT(OUT_TSK'TERMINATED) AND DELAY_COUNT < 60 LOOP               DELAY 1.0 * Impdef.One_Second;               DELAY_COUNT := DELAY_COUNT + 1;          END LOOP;          IF DELAY_COUNT = 60 THEN               FAILED ("OUT_TSK HAS NOT TERMINATED - 5");          ELSIF GLOBAL /= 5 THEN               FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &                       "BLOCK EXIT - 5");          END IF;     END; -- (E)     --------------------------------------------------     GLOBAL := IDENT_INT (0);     DECLARE          DELAY_COUNT : INTEGER := 0;          TASK OUT_TSK;               TASK BODY OUT_TSK IS               TASK TSK IS                    ENTRY ENT;               END TSK;               TASK BODY TSK IS                    TYPE RT IS                         RECORD                              T : TT;                         END RECORD;                    AR : ARRAY (1..1) OF RT;               BEGIN                    AR(1).T.E (IDENT_INT(6));                    RAISE MY_EXCEPTION;               END TSK;          BEGIN               RAISE MY_EXCEPTION;          END OUT_TSK;     BEGIN          WHILE NOT(OUT_TSK'TERMINATED) AND DELAY_COUNT < 60 LOOP               DELAY 1.0 * Impdef.One_Second;               DELAY_COUNT := DELAY_COUNT + 1;          END LOOP;          IF DELAY_COUNT = 60 THEN               FAILED ("OUT_TSK HAS NOT TERMINATED - 6");          ELSIF GLOBAL /= 6 THEN               FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &                       "BLOCK EXIT - 6");          END IF;     END;     RESULT;END C94001C;

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?