OpenCores
URL https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk

Subversion Repositories openrisc_me

[/] [openrisc/] [trunk/] [gnu-src/] [gcc-4.5.1/] [gcc/] [testsuite/] [ada/] [acats/] [tests/] [c4/] [c43204g.ada] - Rev 294

Compare with Previous | Blame | View Log

-- 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;
 

Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.