view gcc/testsuite/ada/acats/tests/c3/c35503e.ada @ 158:494b0b89df80 default tip

...
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Mon, 25 May 2020 18:13:55 +0900
parents 04ced10e8804
children
line wrap: on
line source

-- C35503E.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 'IMAGE' AND 'VALUE' YIELD THE CORRECT RESULTS WHEN
--     THE PREFIX IS A GENERIC FORMAL DISCRETE TYPE WHOSE ACTUAL
--     PARAMETER IS AN INTEGER TYPE.
--     SUBTESTS ARE :
--         PART (A). TESTS FOR 'IMAGE'.
--         PART (B). TESTS FOR 'VALUE'.

-- HISTORY:
--     RJW 03/17/86 CREATED ORIGINAL TEST.
--     DHH 10/19/87 SHORTENED LINES CONTAINING MORE THAN 72 CHARACTERS.

WITH REPORT; USE REPORT;

PROCEDURE C35503E IS

BEGIN
     TEST ("C35503E", "CHECK THAT 'IMAGE' AND 'VALUE' YIELD THE " &
                      "CORRECT RESULTS  WHEN THE PREFIX IS A " &
                      "GENERIC FORMAL DISCRETE TYPE WHOSE ACTUAL " &
                      "PARAMETER IS AN INTEGER TYPE" );
-- PART (A).

     DECLARE
          TYPE NEWINT IS NEW INTEGER RANGE -2000 .. 2000;

          GENERIC
               TYPE INT IS (<>);
          PROCEDURE P (I1 : INT; STR : STRING );

          PROCEDURE P (I1 : INT; STR : STRING) IS
               SUBTYPE SUBINT IS INT
               RANGE INT'VAL (IDENT_INT(-1000)) ..
                                              INT'VAL (IDENT_INT(1000));
          BEGIN

               IF INT'IMAGE (I1) /= STR THEN
                    FAILED ( "INCORRECT INT'IMAGE OF " & STR );
               END IF;
               IF INT'IMAGE (I1)'FIRST /= 1 THEN
                    FAILED ( "INCORRECT LOWER BOUND FOR INT'IMAGE OF " &
                             STR );
               END IF;

               IF SUBINT'IMAGE (I1) /= STR THEN
                    FAILED ( "INCORRECT SUBINT'IMAGE OF " & STR );
               END IF;
               IF SUBINT'IMAGE (I1)'FIRST /= 1 THEN
                    FAILED ( "INCORRECT LOWER BOUND FOR SUBINT'IMAGE " &
                             "OF " & STR );
               END IF;

          END P;

          PROCEDURE PROC1 IS NEW P (INTEGER);
          PROCEDURE PROC2 IS NEW P (NEWINT);

     BEGIN
          PROC1 (-500, "-500");
          PROC2 (0, " 0");
          PROC2 (99," 99");
     END;

-----------------------------------------------------------------------

-- PART (B).

     DECLARE
          TYPE NEWINT IS NEW INTEGER;

          GENERIC
               TYPE INT IS (<>);
          PROCEDURE P (STR : STRING; I1 : INT );

          PROCEDURE P (STR : STRING; I1 : INT) IS
               SUBTYPE SUBINT IS INT
                    RANGE INT'VAL (IDENT_INT(0)) ..
                                                INT'VAL (IDENT_INT(10));

          BEGIN
               BEGIN
                    IF INT'VALUE (STR) /= I1 THEN
                         FAILED ( "INCORRECT INT'VALUE OF """ &
                                  STR & """");
                    END IF;
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ( "EXCEPTION RAISED INT'VALUE OF """ &
                                  STR & """");
               END;
               BEGIN
                    IF SUBINT'VALUE (STR) /= I1 THEN
                         FAILED ( "INCORRECT SUBINT'VALUE OF """ &
                                  STR & """");
                    END IF;
               EXCEPTION
                    WHEN OTHERS =>
                         FAILED ( "EXCEPTION RAISED SUBINT'VALUE " &
                                  "OF """ & STR & """");
               END;
          END P;

          PROCEDURE PROC1 IS NEW P (INTEGER);
          PROCEDURE PROC2 IS NEW P (NEWINT);

     BEGIN
               PROC1 ("-500" , -500);
               PROC2 (" -001E2 " , -100);
               PROC1 ("3_45" , 345);
               PROC2 ("-2#1111_1111#" , -255);
               PROC1 ("16#FF#" , 255);
               PROC2 ("-016#0FF#" , -255);
               PROC1 ("2#1110_0000#     " , 224);
               PROC2 ("-16#E#E1" , -224);

     END;

     DECLARE
          TYPE NEWINT IS NEW INTEGER;

          GENERIC
               TYPE INT IS (<>);
          PROCEDURE P (STR1 : STRING; I1 : INT; STR2 : STRING);

          PROCEDURE P (STR1 : STRING; I1 : INT; STR2 : STRING) IS
               SUBTYPE SUBINT IS INT
                    RANGE INT'VAL (IDENT_INT(0)) ..
                                                INT'VAL (IDENT_INT(10));

          BEGIN
               BEGIN
                    IF INT'VALUE (STR1) = I1 THEN
                         FAILED ( "NO EXCEPTION RAISED - INT'VALUE " &
                                  "WITH " & STR2 & " - EQUAL");
                    ELSE
                         FAILED ( "NO EXCEPTION RAISED " &
                                  "- INT'VALUE WITH " &
                                  STR2 & " - NOT EQUAL" );
                    END IF;
               EXCEPTION
                    WHEN CONSTRAINT_ERROR =>
                         NULL;
                    WHEN OTHERS =>
                         FAILED ( "WRONG EXCEPTION RAISED - " &
                                  "INT'VALUE WITH " & STR2 );
               END;
               BEGIN
                    IF SUBINT'VALUE (STR1) = I1 THEN
                         FAILED ( "NO EXCEPTION RAISED - " &
                                  "SUBINT'VALUE WITH " & STR2
                                   & " - EQUAL" );
                    ELSE
                         FAILED ( "NO EXCEPTION RAISED - " &
                                  "SUBINT'VALUE WITH " &
                                   STR2 & " - NOT EQUAL" );
                    END IF;
               EXCEPTION
                    WHEN CONSTRAINT_ERROR =>
                         NULL;
                    WHEN OTHERS =>
                         FAILED ( "WRONG EXCEPTION RAISED  - " &
                                  "SUBINT'VALUE WITH " & STR2 );
               END;
          END P;

          PROCEDURE PROC1 IS NEW P (INTEGER);
          PROCEDURE PROC2 IS NEW P (NEWINT);

     BEGIN
          PROC1 ("1.0"           , 1,      "DECIMAL POINT");
          PROC1 (ASCII.HT & "244", 244,    "LEADING 'HT'" );
          PROC2 ("244" & ASCII.HT, 244,    "TRAILING 'HT'" );
          PROC1 ("2__44"         , 244,    "CONSECUTIVE '_'" );
          PROC2 ("_244"          , 244,    "LEADING '_'" );
          PROC1 ("244_"          , 244,    "TRAILING '_'" );
          PROC2 ("244_E1"        , 2440,   "'_' BEFORE 'E'" );
          PROC1 ("244E_1"        , 2440,   "'_' FOLLOWING 'E'" );
          PROC2 ("244_e1"        , 2440,   "'_' BEFORE 'e'" );
          PROC1 ("16#_FF#"       , 255,    "'_' IN BASED LITERAL" );
          PROC2 ("1E-0"          ,   0,    "NEGATIVE EXPONENT" );
          PROC1 ("244."          , 244,    "TRAILING '.'" );
          PROC2 ("8#811#"        , 0,      "DIGITS OUTSIDE OF RANGE" );
          PROC1 ("1#000#"        , 0,      "BASE LESS THAN 2" );
          PROC2 ("17#0#"         , 0,      "BASE GREATER THAN 16" );
     END;

     RESULT;
END C35503E;