view gcc/testsuite/ada/acats/tests/c4/c45611c.dep @ 111:04ced10e8804

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

--  C45611C.DEP

--                             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 EXPONENTIATION OF A LONG_INTEGER TO AN INTEGER VALUE
--     IS CORRECTLY EVALUATED.

-- APPLICABILITY CRITERIA:
--     THIS TEST IS APPLICABLE TO THOSE IMPLEMENTATIONS WHICH SUPPORT
--     LONG_INTEGER.

--     IF "LONG_INTEGER" IS NOT SUPPORTED, THEN THE DECLARATION OF
--     "CHECK_LONG" MUST BE REJECTED.

-- HISTORY:
--     HTG 09/23/86 CREATED ORIGINAL TEST.
--     DHH 01/13/88 ADDED APPLICABILITY CRITERIA AND STANDARD HEADER.

WITH REPORT; USE REPORT;

PROCEDURE C45611C IS

    CHECK_LONG : LONG_INTEGER;                      -- N/A => ERROR.

    I1,INT : LONG_INTEGER;

    FUNCTION IDENT (X : LONG_INTEGER) RETURN LONG_INTEGER IS
    BEGIN
         RETURN LONG_INTEGER (IDENT_INT (INTEGER (X)));
    END IDENT;

    BEGIN


         TEST ("C45611C", "CHECK THAT EXPONENTIATION OF A " &
                          "LONG_INTEGER VALUE IS CORRECTLY " &
                          "EVALUATED");

         I1 := IDENT(0) ** IDENT_INT(0);

         IF IDENT(I1) /= IDENT(1) THEN
              FAILED( "INCORRECT RESULT FOR '0**0'" );
         END IF;

         INT := "**" (IDENT(0),IDENT_INT(1));

         IF IDENT(INT) /= IDENT(0) THEN
              FAILED( "INCORRECT RESULT FOR '0**1'" );
         END IF;

         I1 := IDENT(6) ** IDENT_INT(0);

         IF IDENT(I1) /= IDENT(1) THEN
              FAILED( "INCORRECT RESULT FOR '6**0'" );
         END IF;

         INT := IDENT(156) ** IDENT_INT(1);

         IF IDENT(INT) /= IDENT(156) THEN
              FAILED( "INCORRECT RESULT FOR '156**1'" );
         END IF;

         I1 := IDENT(-3) ** IDENT_INT(0);

         IF IDENT(I1) /= IDENT(1) THEN
              FAILED( "INCORRECT RESULT FOR '(-3)**0'" );
         END IF;

         INT := "**" (IDENT(-7),IDENT_INT(1));

         IF IDENT(INT) /= IDENT(-7) THEN
              FAILED( "INCORRECT RESULT FOR '(-7)**1'" );
         END IF;

         I1 := "**" (IDENT(-1),IDENT_INT(2));

         IF IDENT(I1) /= IDENT(1) THEN
              FAILED( "INCORRECT RESULT FOR '(-1)**2'" );
         END IF;


         INT := IDENT(-1) ** IDENT_INT(3);

         IF IDENT(INT) /= IDENT(-1) THEN
              FAILED( "INCORRECT RESULT FOR '(-1)**3'" );
         END IF;

         INT := "**" (IDENT(0),IDENT_INT(2));

         IF IDENT(INT) /= IDENT(0) THEN
              FAILED( "INCORRECT RESULT FOR '0**2'" );
         END IF;

         INT := IDENT(0) ** IDENT_INT(10);

         IF IDENT(INT) /= IDENT(0) THEN
              FAILED( "INCORRECT RESULT FOR '0**10'" );
         END IF;

         INT := "**" (IDENT(6),IDENT_INT(2));

         IF IDENT(INT) /= IDENT(36) THEN
              FAILED( "INCORRECT RESULT FOR '6**2'" );
         END IF;

         INT := "**" (IDENT(2),IDENT_INT(2));

         IF IDENT(INT) /= IDENT(4) THEN
              FAILED( "INCORRECT RESULT FOR '2**2'" );
         END IF;

         I1 := "**" (IDENT(1),IDENT_INT(10));

         IF IDENT(I1) /= IDENT(1) THEN
              FAILED( "INCORRECT RESULT FOR '1**10'" );
         END IF;

         RESULT;

    END C45611C;