c43204g.ada

来自「用于进行gcc测试」· ADA 代码 · 共 126 行

ADA
126
字号
-- C43204G.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.--*-- OBJECTIVE:--     CHECK THAT AN AGGREGATE WITH AN OTHERS CLAUSE CAN APPEAR AS A--     CONSTRAINED FORMAL PARAMETER OF AN ENTRY, AND THAT THE BOUNDS--     OF THE AGGREGATE ARE DETERMINED CORRECTLY.-- HISTORY:--     JET 08/15/88  CREATED ORIGINAL TEST.WITH REPORT; USE REPORT;PROCEDURE C43204G IS     TYPE ARR11 IS ARRAY (INTEGER RANGE -3 .. 3) OF INTEGER;     TYPE ARR12 IS ARRAY (IDENT_INT(-3) .. IDENT_INT(3)) OF INTEGER;     TYPE ARR13 IS ARRAY (IDENT_INT(1) .. IDENT_INT(-1)) OF INTEGER;     TYPE ARR21 IS ARRAY (INTEGER RANGE -1 .. 1,                          INTEGER RANGE -1 .. 1) OF INTEGER;     TYPE ARR22 IS ARRAY (IDENT_INT(-1) .. IDENT_INT(1),                          IDENT_INT(-1) .. IDENT_INT(1)) OF INTEGER;     TYPE ARR23 IS ARRAY (INTEGER RANGE -1 .. 1,                          IDENT_INT(-1) .. IDENT_INT(1)) OF INTEGER;     TYPE ARR24 IS ARRAY (IDENT_INT(1) .. IDENT_INT(-1),                          IDENT_INT(-1) .. IDENT_INT(1)) OF INTEGER;     TASK T IS          ENTRY E (EA11 : ARR11 := (1,1,1,1, OTHERS => IDENT_INT(2));                   EA12 : ARR12 := (OTHERS => IDENT_INT(2));                   EA13 : ARR13 := (OTHERS => IDENT_INT(2));                   EA21 : ARR21 := ((1,1,1), (1,1,1), (1,1,1),                                    OTHERS => (-1..1 => IDENT_INT(2)));                   EA22 : ARR22 := ((OTHERS => IDENT_INT(2)), (1,1,1),                                    (1,1,1));                   EA23 : ARR23 := (-1..0 => (OTHERS => 1),                                    1 => (OTHERS => IDENT_INT(2)));                   EA24: ARR24 := (OTHERS => (OTHERS => IDENT_INT(2))));     END T;     TASK BODY T IS     BEGIN          ACCEPT E (EA11 : ARR11 := (1,1,1,1, OTHERS => IDENT_INT(2));                    EA12 : ARR12 := (OTHERS => IDENT_INT(2));                    EA13 : ARR13 := (OTHERS => IDENT_INT(2));                    EA21 : ARR21 := ((1,1,1), (1,1,1), (1,1,1),                                     OTHERS => (-1..1 => IDENT_INT(2)));                    EA22 : ARR22 := ((OTHERS => IDENT_INT(2)), (1,1,1),                                     (1,1,1));                    EA23 : ARR23 := (-1..0 => (OTHERS => 1),                                     1 => (OTHERS => IDENT_INT(2)));                    EA24 : ARR24 := (OTHERS => (OTHERS =>                                    IDENT_INT(2))))          DO               IF EA11 /= (1, 1, 1, 1, 2, 2, 2) THEN                    FAILED("INCORRECT VALUE OF EA11");               END IF;               IF EA12 /= (2, 2, 2, 2, 2, 2, 2) THEN                    FAILED("INCORRECT VALUE OF EA12");               END IF;               IF EA13'LENGTH /= 0 THEN                    FAILED("INCORRECT VALUE OF EA13");               END IF;               IF EA21 /= ((1,1,1), (1,1,1), (1,1,1)) THEN                    FAILED("INCORRECT VALUE OF EA21");               END IF;               IF EA22 /= ((2,2,2), (1,1,1), (1,1,1)) THEN                    FAILED("INCORRECT VALUE OF EA22");               END IF;               IF EA23 /= ((1,1,1), (1,1,1), (2,2,2)) THEN                    FAILED("INCORRECT VALUE OF EA23");               END IF;               IF EA24'LENGTH /= 0 OR EA24'LENGTH(2) /= 3 THEN                    FAILED("INCORRECT VALUE OF EA24");               END IF;          END E;     END T;BEGIN     TEST ("C43204G", "CHECK THAT AN AGGREGATE WITH AN OTHERS CLAUSE " &                      "CAN APPEAR AS A CONSTRAINED FORMAL PARAMETER " &                      "OF AN ENTRY, AND THAT THE BOUNDS OF THE " &                      "AGGREGATE ARE DETERMINED CORRECTLY");     T.E;     RESULT;EXCEPTION     WHEN OTHERS =>          FAILED ("UNEXPECTED CONSTRAINT_ERROR OR OTHER EXCEPTION " &                  "RAISED");          IF T'CALLABLE THEN               T.E;          END IF;          RESULT;END C43204G;

⌨️ 快捷键说明

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