view gcc/testsuite/ada/acats/tests/c8/c85005g.ada @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
line wrap: on
line source

-- C85005G.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 ANY SUBTYPE CONSTRAINT IMPOSED BY THE TYPE MARK USED
--     IN THE RENAMING DECLARATION IS IGNORED, AND THE SUBTYPE
--     CONSTRAINT ASSOCIATED WITH THE RENAMED VARIABLE IS USED INSTEAD.

-- *** NOTE: This test has been modified since ACVC version 1.11 to    -- 9X
-- ***       remove incompatibilities associated with the transition   -- 9X
-- ***       to Ada 9X.                                                -- 9X
-- ***                                                                 -- 9X

-- HISTORY:
--     JET 07/26/88  CREATED ORIGINAL TEST.
--     MRM 03/30/93  REMOVED NUMERIC_ERROR FOR 9X COMPATIBILITY

WITH REPORT; USE REPORT;
PROCEDURE C85005G IS

     SUBTYPE INT IS INTEGER RANGE -100 .. 100;

     I : INTEGER := IDENT_INT(INTEGER'LAST);
     J : INT := IDENT_INT(INT'LAST);

     DG1 : INTEGER := IDENT_INT(INTEGER'LAST);
     DG2 : INT := IDENT_INT(INT'LAST);

     XI : INT RENAMES I;
     XJ : INTEGER RENAMES J;

     GENERIC
          G1 : IN OUT INT;
          G2 : IN OUT INTEGER;
     PROCEDURE GEN;

     PROCEDURE GEN IS
          XG1 : INT RENAMES G1;
          XG2 : INTEGER RENAMES G2;
     BEGIN
          IF XG1 /= INTEGER'LAST THEN
               FAILED("INCORRECT VALUE OF RENAMING VARIABLE - G1");
          END IF;

          XG1 := IDENT_INT(INTEGER'FIRST);

          IF XG1 /= INTEGER'FIRST THEN
               FAILED("INCORRECT VALUE OF RENAMING VARIABLE - G2");
          END IF;

          IF XG2 /= INT'LAST THEN
               FAILED("INCORRECT VALUE OF RENAMING VARIABLE - G3");
          END IF;

          XG2 := IDENT_INT(INT'FIRST);

          IF XG2 /= INT'FIRST THEN
               FAILED("INCORRECT VALUE OF RENAMING VARIABLE - G4");
          END IF;

          BEGIN
               XG2 := IDENT_INT(INTEGER'LAST);
               FAILED ("NO EXCEPTION RAISED BY XG2 := INTEGER'LAST");
               IF NOT EQUAL(XG2,XG2) THEN
                    COMMENT ("DON'T OPTIMIZE XG2");
               END IF;
          EXCEPTION
               WHEN CONSTRAINT_ERROR =>
                    NULL;
               WHEN OTHERS =>
                    FAILED ("UNEXPECTED EXCEPTION (G)");
          END;
     END GEN;

     PROCEDURE PROC IS NEW GEN(DG1, DG2);

BEGIN
     TEST ("C85005G", "CHECK THAT ANY SUBTYPE CONSTRAINT IMPOSED BY " &
                      "THE TYPE MARK USED IN THE RENAMING " &
                      "DECLARATION IS IGNORED, AND THE SUBTYPE " &
                      "CONSTRAINT ASSOCIATED WITH THE RENAMED " &
                      "VARIABLE IS USED INSTEAD");

     IF XI /= INTEGER'LAST THEN
          FAILED("INCORRECT VALUE OF RENAMING VARIABLE - 1");
     END IF;

     XI := IDENT_INT(INTEGER'FIRST);

     IF XI /= INTEGER'FIRST THEN
          FAILED("INCORRECT VALUE OF RENAMING VARIABLE - 2");
     END IF;

     IF XJ /= INT'LAST THEN
          FAILED("INCORRECT VALUE OF RENAMING VARIABLE - 3");
     END IF;

     XJ := IDENT_INT(INT'FIRST);

     IF XJ /= INT'FIRST THEN
          FAILED("INCORRECT VALUE OF RENAMING VARIABLE - 4");
     END IF;

     BEGIN
          XJ := IDENT_INT(INTEGER'LAST);
          FAILED ("NO EXCEPTION RAISED BY XJ := INTEGER'LAST");
          IF NOT EQUAL(XJ,XJ) THEN
               COMMENT ("DON'T OPTIMIZE XJ");
          END IF;
     EXCEPTION
          WHEN CONSTRAINT_ERROR =>
                NULL;
          WHEN OTHERS =>
                FAILED ("UNEXPECTED EXCEPTION - 1");
     END;

     PROC;

     RESULT;
EXCEPTION
     WHEN OTHERS =>
          FAILED("UNEXPECTED EXCEPTION - 2");
          RESULT;
END C85005G;