OpenCores
URL https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk

Subversion Repositories openrisc_2011-10-31

[/] [openrisc/] [tags/] [gnu-src/] [gcc-4.5.1/] [gcc-4.5.1-or32-1.0rc1/] [gcc/] [testsuite/] [ada/] [acats/] [tests/] [c3/] [c35507b.ada] - Diff between revs 294 and 338

Only display areas with differences | Details | Blame | View Log

Rev 294 Rev 338
-- C35507B.ADA
-- C35507B.ADA
 
 
--                             Grant of Unlimited Rights
--                             Grant of Unlimited Rights
--
--
--     Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
--     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 
--     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 in the software and documentation contained herein.
--     Unlimited rights are defined in DFAR 252.227-7013(a)(19).  By making 
--     Unlimited rights are defined in DFAR 252.227-7013(a)(19).  By making 
--     this public release, the Government intends to confer upon all 
--     this public release, the Government intends to confer upon all 
--     recipients unlimited rights  equal to those held by the Government.  
--     recipients unlimited rights  equal to those held by the Government.  
--     These rights include rights to use, duplicate, release or disclose the 
--     These rights include rights to use, duplicate, release or disclose the 
--     released technical data and computer software in whole or in part, in 
--     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 
--     any manner and for any purpose whatsoever, and to have or permit others 
--     to do so.
--     to do so.
--
--
--                                    DISCLAIMER
--                                    DISCLAIMER
--
--
--     ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
--     ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
--     DISCLOSED ARE AS IS.  THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED 
--     DISCLOSED ARE AS IS.  THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED 
--     WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
--     WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
--     SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE 
--     SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE 
--     OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
--     OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
--     PARTICULAR PURPOSE OF SAID MATERIAL.
--     PARTICULAR PURPOSE OF SAID MATERIAL.
--*
--*
-- CHECK THAT THE ATTRIBUTE 'WIDTH' YIELDS THE CORRECT RESULTS 
-- CHECK THAT THE ATTRIBUTE 'WIDTH' YIELDS THE CORRECT RESULTS 
-- WHEN THE PREFIX IS FORMAL DISCRETE TYPE WHOSE ACTUAL PARAMETER IS
-- WHEN THE PREFIX IS FORMAL DISCRETE TYPE WHOSE ACTUAL PARAMETER IS
-- A CHARACTER TYPE.   
-- A CHARACTER TYPE.   
 
 
-- RJW 5/29/86
-- RJW 5/29/86
 
 
WITH REPORT; USE REPORT;
WITH REPORT; USE REPORT;
 
 
PROCEDURE  C35507B  IS
PROCEDURE  C35507B  IS
 
 
     GENERIC
     GENERIC
          TYPE CH IS (<>);
          TYPE CH IS (<>);
     PROCEDURE P ( STR : STRING; W : INTEGER );
     PROCEDURE P ( STR : STRING; W : INTEGER );
 
 
     PROCEDURE P ( STR : STRING; W : INTEGER ) IS
     PROCEDURE P ( STR : STRING; W : INTEGER ) IS
 
 
          SUBTYPE NOCHAR IS CH RANGE CH'VAL (1) .. CH'VAL(0);
          SUBTYPE NOCHAR IS CH RANGE CH'VAL (1) .. CH'VAL(0);
     BEGIN
     BEGIN
          IF CH'WIDTH /= W THEN
          IF CH'WIDTH /= W THEN
               FAILED( "INCORRECT WIDTH FOR " & STR );
               FAILED( "INCORRECT WIDTH FOR " & STR );
          END IF;
          END IF;
 
 
          IF NOCHAR'WIDTH /= 0 THEN
          IF NOCHAR'WIDTH /= 0 THEN
               FAILED( "INCORRECT WIDTH FOR NOCHAR WITH " & STR );
               FAILED( "INCORRECT WIDTH FOR NOCHAR WITH " & STR );
          END IF;
          END IF;
     END P;
     END P;
 
 
 
 
BEGIN
BEGIN
 
 
     TEST( "C35507B" , "CHECK THAT THE ATTRIBUTE 'WIDTH' YIELDS " &
     TEST( "C35507B" , "CHECK THAT THE ATTRIBUTE 'WIDTH' YIELDS " &
                       "THE CORRECT RESULTS WHEN THE PREFIX " &
                       "THE CORRECT RESULTS WHEN THE PREFIX " &
                       "IS A FORMAL DISCRETE TYPE WHOSE ACTUAL " &
                       "IS A FORMAL DISCRETE TYPE WHOSE ACTUAL " &
                       "PARAMETER IS A CHARACTER TYPE" );
                       "PARAMETER IS A CHARACTER TYPE" );
 
 
     DECLARE
     DECLARE
          TYPE CHAR1 IS (A, 'A');
          TYPE CHAR1 IS (A, 'A');
 
 
          SUBTYPE CHAR2 IS CHARACTER RANGE 'A' .. 'Z';
          SUBTYPE CHAR2 IS CHARACTER RANGE 'A' .. 'Z';
 
 
          TYPE NEWCHAR IS NEW CHARACTER
          TYPE NEWCHAR IS NEW CHARACTER
                    RANGE 'A' .. 'Z';
                    RANGE 'A' .. 'Z';
 
 
          PROCEDURE P1 IS NEW P (CHAR1);
          PROCEDURE P1 IS NEW P (CHAR1);
          PROCEDURE P2 IS NEW P (CHAR2);
          PROCEDURE P2 IS NEW P (CHAR2);
          PROCEDURE P3 IS NEW P (NEWCHAR);
          PROCEDURE P3 IS NEW P (NEWCHAR);
     BEGIN
     BEGIN
          P1 ("CHAR1", 3);
          P1 ("CHAR1", 3);
          P2 ("CHAR2", 3);
          P2 ("CHAR2", 3);
          P3 ("NEWCHAR", 3);
          P3 ("NEWCHAR", 3);
     END;
     END;
 
 
     DECLARE
     DECLARE
          SUBTYPE NONGRAPH IS CHARACTER
          SUBTYPE NONGRAPH IS CHARACTER
                    RANGE CHARACTER'VAL (0) .. CHARACTER'VAL (31);
                    RANGE CHARACTER'VAL (0) .. CHARACTER'VAL (31);
 
 
          MAX : INTEGER := 0;
          MAX : INTEGER := 0;
 
 
          PROCEDURE PN IS NEW P (NONGRAPH);
          PROCEDURE PN IS NEW P (NONGRAPH);
     BEGIN
     BEGIN
          FOR CH IN NONGRAPH
          FOR CH IN NONGRAPH
               LOOP
               LOOP
                    IF CHARACTER'IMAGE (CH)'LENGTH > MAX THEN
                    IF CHARACTER'IMAGE (CH)'LENGTH > MAX THEN
                         MAX := CHARACTER'IMAGE (CH)'LENGTH;
                         MAX := CHARACTER'IMAGE (CH)'LENGTH;
                    END IF;
                    END IF;
          END LOOP;
          END LOOP;
 
 
          PN ("NONGRAPH", MAX);
          PN ("NONGRAPH", MAX);
     END;
     END;
 
 
     RESULT;
     RESULT;
END C35507B;
END C35507B;
 
 

powered by: WebSVN 2.1.0

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