blob: 70c23ad949accde513635dd4c3fe551c5770b522 [file] [log] [blame]
-- C4A012B.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 CONSTRAINT_ERROR IS RAISED FOR
-- A UNIVERSAL_REAL EXPRESSION IF DIVISION BY ZERO IS ATTEMPTED.
-- CHECK THAT CONSTRAINT_ERROR IS RAISED FOR
-- 0.0 ** (-1) (OR ANY OTHER NEGATIVE EXPONENT VALUE).
-- HISTORY:
-- RJW 09/04/86 CREATED ORIGINAL TEST.
-- CJJ 09/04/87 ADDED PASS MESSAGE FOR RAISING NUMERIC_ERROR;
-- MODIFIED CODE TO PREVENT COMPILER OPTIMIZING
-- OUT THE TEST.
-- JET 12/31/87 ADDED MORE CODE TO PREVENT OPTIMIZATION.
-- MRM 03/30/93 REMOVED NUMERIC_ERROR FOR 9X COMPATIBILITY
-- JRL 02/29/96 Added code to check for value of Machine_Overflows; if
-- False, test is inapplicable.
WITH REPORT; USE REPORT;
PROCEDURE C4A012B IS
F : FLOAT;
I3 : INTEGER := -3;
SUBTYPE SINT IS INTEGER RANGE -10 .. 10;
SI5 : CONSTANT SINT := -5;
FUNCTION IDENT (X:FLOAT) RETURN FLOAT IS
BEGIN
IF EQUAL (3,3) THEN
RETURN X;
ELSE
RETURN 1.0;
END IF;
END IDENT;
BEGIN
TEST ( "C4A012B", "CHECK THAT CONSTRAINT_ERROR " &
"IS RAISED FOR " &
"0.0 ** (-1) (OR ANY OTHER NEGATIVE EXPONENT " &
"VALUE)" );
IF FLOAT'MACHINE_OVERFLOWS = FALSE THEN
REPORT.NOT_APPLICABLE ("Float'Machine_Overflows = False");
ELSE
BEGIN
F := IDENT (0.0) ** (-1);
FAILED ( "THE EXPRESSION '0.0 ** (-1)' DID NOT RAISE " &
"AN EXCEPTION" );
IF EQUAL ( INTEGER(F), INTEGER(F) ) THEN
COMMENT ("SHOULDN'T BE HERE!");
END IF;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
COMMENT ("CONSTRAINT_ERROR RAISED - 1");
WHEN OTHERS =>
FAILED ( "THE EXPRESSION '0.0 ** (-1)' RAISED THE " &
"WRONG EXCEPTION" );
END;
BEGIN
F := 0.0 ** (IDENT_INT (-1));
FAILED ( "THE EXPRESSION '0.0 ** (IDENT_INT (-1))' DID " &
"NOT RAISE AN EXCEPTION" );
IF EQUAL ( INTEGER(F), INTEGER(F) ) THEN
COMMENT ("SHOULDN'T BE HERE!");
END IF;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
COMMENT ("CONSTRAINT_ERROR RAISED - 2");
WHEN OTHERS =>
FAILED ( "THE EXPRESSION '0.0 ** (IDENT_INT (-1))' " &
"RAISED THE WRONG EXCEPTION" );
END;
BEGIN
F := 0.0 ** (INTEGER'POS (IDENT_INT (-1)));
FAILED ( "THE EXPRESSION '0.0 ** " &
"(INTEGER'POS (IDENT_INT (-1)))' DID " &
"NOT RAISE AN EXCEPTION" );
IF EQUAL ( INTEGER(F), INTEGER(F) ) THEN
COMMENT ("SHOULDN'T BE HERE!");
END IF;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
COMMENT ("CONSTRAINT_ERROR RAISED - 3");
WHEN OTHERS =>
FAILED ( "THE EXPRESSION '0.0 ** " &
"(INTEGER'POS (IDENT_INT (-1)))' RAISED " &
"THE WRONG EXCEPTION" );
END;
BEGIN
F := IDENT(0.0) ** I3;
FAILED ( "THE EXPRESSION '0.0 ** I3' DID NOT RAISE " &
"AN EXCEPTION" );
IF EQUAL ( INTEGER(F), INTEGER(F) ) THEN
COMMENT ("SHOULDN'T BE HERE!");
END IF;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
COMMENT ("CONSTRAINT_ERROR RAISED - 4");
WHEN OTHERS =>
FAILED ( "THE EXPRESSION '0.0 ** I3' RAISED THE " &
"WRONG EXCEPTION" );
END;
BEGIN
F := 0.0 ** (IDENT_INT (I3));
FAILED ( "THE EXPRESSION '0.0 ** (IDENT_INT (I3))' DID " &
"NOT RAISE AN EXCEPTION" );
IF EQUAL ( INTEGER(F), INTEGER(F) ) THEN
COMMENT ("SHOULDN'T BE HERE!");
END IF;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
COMMENT ("CONSTRAINT_ERROR RAISED - 5");
WHEN OTHERS =>
FAILED ( "THE EXPRESSION '0.0 ** (IDENT_INT (I3))' " &
"RAISED THE WRONG EXCEPTION" );
END;
BEGIN
F := IDENT (0.0) ** SI5;
FAILED ( "THE EXPRESSION '0.0 ** SI5' DID NOT RAISE " &
"AN EXCEPTION" );
IF EQUAL ( INTEGER(F), INTEGER(F) ) THEN
COMMENT ("SHOULDN'T BE HERE!");
END IF;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
COMMENT ("CONSTRAINT_ERROR RAISED - 6");
WHEN OTHERS =>
FAILED ( "THE EXPRESSION '0.0 ** SI5' RAISED THE " &
"WRONG EXCEPTION" );
END;
BEGIN
F := 0.0 ** (IDENT_INT (SI5));
FAILED ( "THE EXPRESSION '0.0 ** (IDENT_INT (SI5))' DID " &
"NOT RAISE AN EXCEPTION" );
IF EQUAL ( INTEGER(F), INTEGER(F) ) THEN
COMMENT ("SHOULDN'T BE HERE!");
END IF;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
COMMENT ("CONSTRAINT_ERROR RAISED - 7");
WHEN OTHERS =>
FAILED ( "THE EXPRESSION '0.0 ** (IDENT_INT (SI5))' " &
"RAISED THE WRONG EXCEPTION" );
END;
END IF;
RESULT;
END C4A012B;