c94002a.ada

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

ADA
332
字号
-- C94002A.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 DEPENDENT TASKS CREATED BY (LOCAL)--   ALLOCATORS DOES NOT TERMINATE UNTIL ALL DEPENDENT TASKS ARE--   TERMINATED.-- SUBTESTS ARE:--   (A, B)  A SIMPLE TASK ALLOCATOR, IN A BLOCK.--   (C, D)  A RECORD OF TASK ALLOCATOR, IN A FUNCTION.--   (E, F)  A RECORD OF ARRAY OF TASK ALLOCATOR, IN A TASK BODY.-- THIS TEST CONTAINS SHARED VARIABLES AND RACE CONDITIONS.-- JRK 10/2/81-- SPS 11/2/82-- SPS 11/21/82-- JRK 11/29/82-- TBN  8/25/86     REDUCED DELAYS; ADDED LIMITED PRIVATE TYPES; --                  INCLUDED EXITS BY RAISING AN EXCEPTION.-- PWN 01/31/95     REMOVED PRAGMA PRIORITY FOR ADA 9X.with Impdef;WITH REPORT; USE REPORT;WITH SYSTEM; USE SYSTEM;PROCEDURE C94002A IS     PACKAGE P IS          MY_EXCEPTION : EXCEPTION;          GLOBAL : INTEGER;          TASK TYPE T1 IS               ENTRY E (I : INTEGER);          END T1;          TYPE T2 IS LIMITED PRIVATE;          PROCEDURE CALL_ENTRY (A : T2; B : INTEGER);     PRIVATE          TASK TYPE T2 IS               ENTRY E (I : INTEGER);          END T2;     END P;     PACKAGE BODY P IS          TASK BODY T1 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 T1;          TASK BODY T2 IS               LOCAL : INTEGER;          BEGIN               ACCEPT E (I : INTEGER) DO                    LOCAL := I;               END E;               DELAY 30.0 * Impdef.One_Second;               GLOBAL := LOCAL;          END T2;          PROCEDURE CALL_ENTRY (A : T2; B : INTEGER) IS          BEGIN               A.E (B);          END CALL_ENTRY;     END P;     USE P;BEGIN     TEST ("C94002A", "CHECK THAT A UNIT WITH DEPENDENT TASKS " &                      "CREATED BY (LOCAL) ALLOCATORS DOES NOT " &                      "TERMINATE UNTIL ALL DEPENDENT TASKS " &                      "ARE TERMINATED");     --------------------------------------------------     GLOBAL := IDENT_INT (0);     BEGIN -- (A)          DECLARE               TYPE A_T IS ACCESS T1;               A : A_T;          BEGIN               IF EQUAL (3, 3) THEN                    A := NEW T1;                    A.ALL.E (IDENT_INT(1));                    RAISE MY_EXCEPTION;               END IF;          END;          FAILED ("MY_EXCEPTION WAS NOT RAISED - 1");     EXCEPTION          WHEN MY_EXCEPTION =>               IF GLOBAL /= 1 THEN                    FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &                            "BLOCK EXIT - 1");               END IF;          WHEN OTHERS =>               FAILED ("UNEXPECTED EXCEPTION RAISED - 1");     END; -- (A)     --------------------------------------------------     GLOBAL := IDENT_INT (0);     DECLARE -- (B)          TYPE A_T IS ACCESS T2;          A : A_T;     BEGIN -- (B)          IF EQUAL (3, 3) THEN               A := NEW T2;               CALL_ENTRY (A.ALL, IDENT_INT(2));          END IF;     END; -- (B)     IF GLOBAL /= 2 THEN          FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &                  "BLOCK EXIT - 2");     END IF;     --------------------------------------------------     GLOBAL := IDENT_INT (0);     DECLARE -- (C)          I : INTEGER;          FUNCTION F RETURN INTEGER IS               TYPE RT;               TYPE ART IS ACCESS RT;               TYPE RT IS                    RECORD                         A : ART;                         T : T1;                    END RECORD;               LIST : ART;               TEMP : ART;          BEGIN               FOR I IN 1 .. IDENT_INT (1) LOOP                    TEMP := NEW RT;                    TEMP.A := LIST;                    LIST := TEMP;                    LIST.T.E (IDENT_INT(3));               END LOOP;               RETURN 0;          END F;     BEGIN -- (C)          I := F;          IF GLOBAL /= 3 THEN               FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &                       "FUNCTION EXIT - 3");          END IF;     END; -- (C)     --------------------------------------------------     GLOBAL := IDENT_INT (0);     DECLARE -- (D)          I : INTEGER;          FUNCTION F RETURN INTEGER IS               TYPE RT;               TYPE ART IS ACCESS RT;               TYPE RT IS                    RECORD                         A : ART;                         T : T2;                    END RECORD;               LIST : ART;               TEMP : ART;          BEGIN               FOR I IN 1 .. IDENT_INT (1) LOOP                    TEMP := NEW RT;                    TEMP.A := LIST;                    LIST := TEMP;                    CALL_ENTRY (LIST.T, IDENT_INT(4));                    IF EQUAL (3, 3) THEN                         RAISE MY_EXCEPTION;                    END IF;               END LOOP;               RETURN 0;          END F;     BEGIN -- (D)          I := F;          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 RAISED - 4");     END; -- (D)     --------------------------------------------------     GLOBAL := IDENT_INT (0);     DECLARE -- (E)          LOOP_COUNT : INTEGER := 0;          CUT_OFF : CONSTANT := 5 * 60;     -- FIVE MINUTE DELAY.          TASK TSK IS               ENTRY ENT;          END TSK;          TASK BODY TSK IS               TYPE ARR IS ARRAY (1..1) OF T1;               TYPE RAT;               TYPE ARAT IS ACCESS RAT;               TYPE RAT IS                    RECORD                         A : ARAT;                         T : ARR;                    END RECORD;               LIST : ARAT;               TEMP : ARAT;          BEGIN               FOR I IN 1 .. IDENT_INT (1) LOOP                    TEMP := NEW RAT;                    TEMP.A := LIST;                    LIST := TEMP;                    LIST.T(1).E (IDENT_INT(5));                    IF EQUAL (3, 3) THEN                         RAISE MY_EXCEPTION;                    END IF;               END LOOP;          END TSK;     BEGIN -- (E)          WHILE NOT TSK'TERMINATED AND LOOP_COUNT < CUT_OFF LOOP               DELAY 1.0 * Impdef.One_Second;               LOOP_COUNT := LOOP_COUNT + 1;          END LOOP;          IF LOOP_COUNT >= CUT_OFF THEN               FAILED ("DEPENDENT TASK NOT TERMINATED WITHIN FIVE " &                       "MINUTES - 5");          END IF;          IF GLOBAL /= 5 THEN               FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &                       "TASK EXIT - 5");          END IF;     END; -- (E)     --------------------------------------------------     GLOBAL := IDENT_INT (0);     DECLARE -- (F)          LOOP_COUNT : INTEGER := 0;          CUT_OFF : CONSTANT := 5 * 60;     -- FIVE MINUTE DELAY.          TASK TSK IS               ENTRY ENT;          END TSK;          TASK BODY TSK IS               TYPE ARR IS ARRAY (1..1) OF T2;               TYPE RAT;               TYPE ARAT IS ACCESS RAT;               TYPE RAT IS                    RECORD                         A : ARAT;                         T : ARR;                    END RECORD;               LIST : ARAT;               TEMP : ARAT;          BEGIN               FOR I IN 1 .. IDENT_INT (1) LOOP                    TEMP := NEW RAT;                    TEMP.A := LIST;                    LIST := TEMP;                    CALL_ENTRY (LIST.T(1), IDENT_INT(6));               END LOOP;          END TSK;     BEGIN -- (F)          WHILE NOT TSK'TERMINATED AND LOOP_COUNT < CUT_OFF LOOP               DELAY 1.0 * Impdef.One_Second;               LOOP_COUNT := LOOP_COUNT + 1;          END LOOP;          IF LOOP_COUNT >= CUT_OFF THEN               FAILED ("DEPENDENT TASK NOT TERMINATED WITHIN FIVE " &                       "MINUTES - 6");          END IF;          IF GLOBAL /= 6 THEN               FAILED ("DEPENDENT TASK NOT TERMINATED BEFORE " &                       "TASK EXIT - 6");          END IF;     END; -- (F)     RESULT;END C94002A;

⌨️ 快捷键说明

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