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

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

-- C45431A.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.
--*
-- CHECK THAT FOR FIXED POINT TYPES +A = A AND THAT, FOR MODEL NUMBERS,
-- -(-A) = A.

-- CASE A: BASIC TYPES THAT FIT THE CHARACTERISTICS OF DURATION'BASE.

-- WRG 8/28/86
-- PWN 02/02/95  REMOVED INCONSISTENCIES WITH ADA 9X.

WITH REPORT; USE REPORT;
PROCEDURE C45431A IS

BEGIN

     TEST ("C45431A", "CHECK THAT FOR FIXED POINT TYPES +A = A AND " &
                      "THAT, FOR MODEL NUMBERS, -(-A) = A " &
                      "-- BASIC TYPES");

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

A:   DECLARE
          TYPE LIKE_DURATION IS DELTA 0.020 RANGE -86_400.0 .. 86_400.0;

          NON_MODEL_CONST : CONSTANT      := 2.0 / 3;
          NON_MODEL_VAR   : LIKE_DURATION := 0.0;

          SMALL, MAX, MIN, ZERO : LIKE_DURATION := 0.5;
          X                     : LIKE_DURATION := 0.0;
     BEGIN
          -- INITIALIZE "CONSTANTS":
          IF EQUAL (3, 3) THEN
               NON_MODEL_VAR := NON_MODEL_CONST;
               SMALL         := LIKE_DURATION'SMALL;
               MAX           := LIKE_DURATION'LAST;
               MIN           := LIKE_DURATION'FIRST;
               ZERO          := 0.0;
          END IF;

          -- CHECK + OR - ZERO = ZERO:
          IF "+"(RIGHT => ZERO) /= 0.0 OR
             +LIKE_DURATION'(0.0) /= ZERO THEN
               FAILED ("+0.0 /= 0.0");
          END IF;
          IF "-"(RIGHT => ZERO) /= 0.0 OR
             -LIKE_DURATION'(0.0) /= ZERO THEN
               FAILED ("-0.0 /= 0.0");
          END IF;
          IF -(-ZERO) /= 0.0 THEN
               FAILED ("-(-0.0) /= 0.0");
          END IF;

          -- CHECK + AND - MAX:
          IF EQUAL (3, 3) THEN
               X := MAX;
          END IF;
          IF +X /= MAX OR +LIKE_DURATION'LAST /= MAX THEN
               FAILED ("+LIKE_DURATION'LAST /= LIKE_DURATION'LAST");
          END IF;
          IF -(-X) /= MAX OR -(-LIKE_DURATION'LAST) /= MAX THEN
               FAILED ("-(-LIKE_DURATION'LAST) /= LIKE_DURATION'LAST");
          END IF;

          -- CHECK + AND - MIN:
          IF EQUAL (3, 3) THEN
               X := MIN;
          END IF;
          IF +X /= MIN OR +LIKE_DURATION'FIRST /= MIN THEN
               FAILED ("+LIKE_DURATION'FIRST /= LIKE_DURATION'FIRST");
          END IF;
          IF -(-X) /= MIN OR -(-LIKE_DURATION'FIRST) /= MIN THEN
               FAILED("-(-LIKE_DURATION'FIRST) /= LIKE_DURATION'FIRST");
          END IF;

          -- CHECK + AND - SMALL:
          IF EQUAL (3, 3) THEN
               X := SMALL;
          END IF;
          IF +X /= SMALL OR +LIKE_DURATION'SMALL /= SMALL THEN
               FAILED ("+LIKE_DURATION'SMALL /= LIKE_DURATION'SMALL");
          END IF;
          IF -(-X) /= SMALL OR -(-LIKE_DURATION'SMALL) /= SMALL THEN
               FAILED("-(-LIKE_DURATION'SMALL) /= LIKE_DURATION'SMALL");
          END IF;

          -- CHECK ARBITRARY MID-RANGE NUMBERS:
          IF EQUAL (3, 3) THEN
               X := 1000.984_375;
          END IF;
          IF +X /= 1000.984_375 OR +1000.984_375 /= X THEN
               FAILED ("+1000.984_375 /= 1000.984_375");
          END IF;
          IF -(-X) /= 1000.984_375 OR -(-1000.984_375) /= X THEN
               FAILED ("-(-1000.984_375) /= 1000.984_375");
          END IF;

          -- CHECK "+" AND "-" FOR NON-MODEL NUMBER:
          IF +LIKE_DURATION'(NON_MODEL_CONST) NOT IN 0.656_25 ..
                                                     0.671_875 OR
             +NON_MODEL_VAR NOT IN 0.656_25 .. 0.671_875 THEN
               FAILED ("+LIKE_DURATION'(2.0 / 3) NOT IN 0.656_25 .. " &
                       "0.671_875");
          END IF;
          IF -LIKE_DURATION'(NON_MODEL_CONST) NOT IN -0.671_875 ..
                                                     -0.656_25 OR
             -NON_MODEL_VAR NOT IN -0.671_875 .. -0.656_25 THEN
               FAILED ("-LIKE_DURATION'(2.0 / 3) NOT IN -0.671_875 " &
                       ".. -0.656_25");
          END IF;

     EXCEPTION
          WHEN OTHERS =>
               FAILED ("EXCEPTION RAISED -- A");
     END A;

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

B:   DECLARE
          TYPE DECIMAL_M4 IS DELTA 100.0 RANGE -1000.0 .. 1000.0;

          NON_MODEL_CONST : CONSTANT   := 2.0 / 3;
          NON_MODEL_VAR   : DECIMAL_M4 := 0.0;

          SMALL, MAX, MIN, ZERO : DECIMAL_M4 := -128.0;
          X                     : DECIMAL_M4 :=    0.0;
     BEGIN
          -- INITIALIZE "CONSTANTS":
          IF EQUAL (3, 3) THEN
               NON_MODEL_VAR :=  NON_MODEL_CONST;
               SMALL         :=  DECIMAL_M4'SMALL;
               ZERO          :=  0.0;
          END IF;

          -- CHECK + OR - ZERO = ZERO:
          IF +ZERO /= 0.0 OR +DECIMAL_M4'(0.0) /= ZERO THEN
               FAILED ("+0.0 /= 0.0");
          END IF;
          IF -ZERO /= 0.0 OR -DECIMAL_M4'(0.0) /= ZERO THEN
               FAILED ("-0.0 /= 0.0");
          END IF;
          IF -(-ZERO) /= 0.0 THEN
               FAILED ("-(-0.0) /= 0.0");
          END IF;

          -- CHECK + AND - MAX:
          IF EQUAL (3, 3) THEN
               X := MAX;
          END IF;
          -- CHECK + AND - SMALL:
          IF EQUAL (3, 3) THEN
               X := SMALL;
          END IF;
          IF +X /= SMALL OR +DECIMAL_M4'SMALL /= SMALL THEN
               FAILED ("+DECIMAL_M4'SMALL /= DECIMAL_M4'SMALL");
          END IF;
          IF -(-X) /= SMALL OR -(-DECIMAL_M4'SMALL) /= SMALL THEN
               FAILED ("-(-DECIMAL_M4'SMALL) /= DECIMAL_M4'SMALL");
          END IF;

          -- CHECK ARBITRARY MID-RANGE NUMBERS:
          IF EQUAL (3, 3) THEN
               X := 256.0;
          END IF;
          IF +X /= 256.0 OR +256.0 /= X THEN
               FAILED ("+256.0 /= 256.0");
          END IF;
          IF -(-X) /= 256.0 OR -(-256.0) /= X THEN
               FAILED ("-(-256.0) /= 256.0");
          END IF;

          -- CHECK "+" AND "-" FOR NON-MODEL NUMBER:
          IF +DECIMAL_M4'(NON_MODEL_CONST) NOT IN 0.0 .. 64.0 OR
             +NON_MODEL_VAR NOT IN 0.0 .. 64.0 THEN
               FAILED ("+DECIMAL_M4'(2.0 / 3) NOT IN 0.0 .. 64.0");
          END IF;
          IF -DECIMAL_M4'(NON_MODEL_CONST) NOT IN -64.0 .. 0.0 OR
             -NON_MODEL_VAR NOT IN -64.0 .. 0.0 THEN
               FAILED ("-DECIMAL_M4'(2.0 / 3) NOT IN -64.0 .. 0.0");
          END IF;

     EXCEPTION
          WHEN OTHERS =>
               FAILED ("EXCEPTION RAISED -- B");
     END B;

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

     RESULT;

END C45431A;