-- C45411A.ADA
|
-- C45411A.ADA
|
|
|
-- Grant of Unlimited Rights
|
-- Grant of Unlimited Rights
|
--
|
--
|
-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
|
-- 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
|
-- 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 in the software and documentation contained herein.
|
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
|
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
|
-- this public release, the Government intends to confer upon all
|
-- this public release, the Government intends to confer upon all
|
-- recipients unlimited rights equal to those held by the Government.
|
-- recipients unlimited rights equal to those held by the Government.
|
-- These rights include rights to use, duplicate, release or disclose the
|
-- These rights include rights to use, duplicate, release or disclose the
|
-- released technical data and computer software in whole or in part, in
|
-- 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
|
-- any manner and for any purpose whatsoever, and to have or permit others
|
-- to do so.
|
-- to do so.
|
--
|
--
|
-- DISCLAIMER
|
-- DISCLAIMER
|
--
|
--
|
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
|
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
|
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
|
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
|
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
|
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
|
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
|
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
|
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
|
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
|
-- PARTICULAR PURPOSE OF SAID MATERIAL.
|
-- PARTICULAR PURPOSE OF SAID MATERIAL.
|
--*
|
--*
|
-- OBJECTIVE:
|
-- OBJECTIVE:
|
-- CHECK THAT UNARY "+" AND "-" YIELD CORRECT RESULTS FOR
|
-- CHECK THAT UNARY "+" AND "-" YIELD CORRECT RESULTS FOR
|
-- PREDEFINED INTEGER OPERANDS.
|
-- PREDEFINED INTEGER OPERANDS.
|
|
|
-- HISTORY:
|
-- HISTORY:
|
-- JET 01/25/88 CREATED ORIGINAL TEST.
|
-- JET 01/25/88 CREATED ORIGINAL TEST.
|
-- PWN 10/27/95 REMOVED OUT OF RANGE STATIC VALUE CHECKS.
|
-- PWN 10/27/95 REMOVED OUT OF RANGE STATIC VALUE CHECKS.
|
|
|
WITH REPORT; USE REPORT;
|
WITH REPORT; USE REPORT;
|
|
|
PROCEDURE C45411A IS
|
PROCEDURE C45411A IS
|
|
|
TYPE DT IS NEW INTEGER RANGE -3..3;
|
TYPE DT IS NEW INTEGER RANGE -3..3;
|
I1 : INTEGER := 1;
|
I1 : INTEGER := 1;
|
D1 : DT := 1;
|
D1 : DT := 1;
|
|
|
BEGIN
|
BEGIN
|
TEST ("C45411A", "CHECK THAT UNARY ""+"" AND ""-"" YIELD " &
|
TEST ("C45411A", "CHECK THAT UNARY ""+"" AND ""-"" YIELD " &
|
"CORRECT RESULTS FOR PREDEFINED INTEGER " &
|
"CORRECT RESULTS FOR PREDEFINED INTEGER " &
|
"OPERANDS");
|
"OPERANDS");
|
|
|
FOR I IN (1-2)..INTEGER(1) LOOP
|
FOR I IN (1-2)..INTEGER(1) LOOP
|
IF "-"(RIGHT => I1) /= IDENT_INT(I) THEN
|
IF "-"(RIGHT => I1) /= IDENT_INT(I) THEN
|
FAILED ("INCORRECT RESULT FOR ""-"" -" &
|
FAILED ("INCORRECT RESULT FOR ""-"" -" &
|
INTEGER'IMAGE(I+2));
|
INTEGER'IMAGE(I+2));
|
END IF;
|
END IF;
|
|
|
IF +I1 /= IDENT_INT(I1) THEN
|
IF +I1 /= IDENT_INT(I1) THEN
|
FAILED ("INCORRECT RESULT FOR ""+"" -" &
|
FAILED ("INCORRECT RESULT FOR ""+"" -" &
|
INTEGER'IMAGE(I+2));
|
INTEGER'IMAGE(I+2));
|
END IF;
|
END IF;
|
I1 := I1 - 1;
|
I1 := I1 - 1;
|
END LOOP;
|
END LOOP;
|
|
|
FOR I IN (1-2)..INTEGER(1) LOOP
|
FOR I IN (1-2)..INTEGER(1) LOOP
|
IF -I /= IDENT_INT(0)-I THEN
|
IF -I /= IDENT_INT(0)-I THEN
|
FAILED ("INCORRECT RESULT FOR ""-"" -" &
|
FAILED ("INCORRECT RESULT FOR ""-"" -" &
|
INTEGER'IMAGE(I+5));
|
INTEGER'IMAGE(I+5));
|
END IF;
|
END IF;
|
|
|
IF "+"(RIGHT => IDENT_INT(I)) /= I THEN
|
IF "+"(RIGHT => IDENT_INT(I)) /= I THEN
|
FAILED ("INCORRECT RESULT FOR ""+"" -" &
|
FAILED ("INCORRECT RESULT FOR ""+"" -" &
|
INTEGER'IMAGE(I+5));
|
INTEGER'IMAGE(I+5));
|
END IF;
|
END IF;
|
END LOOP;
|
END LOOP;
|
|
|
IF -1 /= IDENT_INT(1)-2 THEN
|
IF -1 /= IDENT_INT(1)-2 THEN
|
FAILED ("INCORRECT RESULT FOR ""-"" - 7");
|
FAILED ("INCORRECT RESULT FOR ""-"" - 7");
|
END IF;
|
END IF;
|
|
|
IF "-"(RIGHT => 0) /= IDENT_INT(0) THEN
|
IF "-"(RIGHT => 0) /= IDENT_INT(0) THEN
|
FAILED ("INCORRECT RESULT FOR ""-"" - 8");
|
FAILED ("INCORRECT RESULT FOR ""-"" - 8");
|
END IF;
|
END IF;
|
|
|
IF "-"(RIGHT => "-"(RIGHT => 1)) /= IDENT_INT(1) THEN
|
IF "-"(RIGHT => "-"(RIGHT => 1)) /= IDENT_INT(1) THEN
|
FAILED ("INCORRECT RESULT FOR ""-"" - 9");
|
FAILED ("INCORRECT RESULT FOR ""-"" - 9");
|
END IF;
|
END IF;
|
|
|
IF "+"(RIGHT => 1) /= IDENT_INT(2)-1 THEN
|
IF "+"(RIGHT => 1) /= IDENT_INT(2)-1 THEN
|
FAILED ("INCORRECT RESULT FOR ""+"" - 7");
|
FAILED ("INCORRECT RESULT FOR ""+"" - 7");
|
END IF;
|
END IF;
|
|
|
IF +0 /= IDENT_INT(0) THEN
|
IF +0 /= IDENT_INT(0) THEN
|
FAILED ("INCORRECT RESULT FOR ""+"" - 8");
|
FAILED ("INCORRECT RESULT FOR ""+"" - 8");
|
END IF;
|
END IF;
|
|
|
IF +(-1) /= IDENT_INT(1)-2 THEN
|
IF +(-1) /= IDENT_INT(1)-2 THEN
|
FAILED ("INCORRECT RESULT FOR ""+"" - 9");
|
FAILED ("INCORRECT RESULT FOR ""+"" - 9");
|
END IF;
|
END IF;
|
|
|
FOR I IN (1-2)..INTEGER(1) LOOP
|
FOR I IN (1-2)..INTEGER(1) LOOP
|
IF "-"(RIGHT => D1) /= DT(IDENT_INT(I)) THEN
|
IF "-"(RIGHT => D1) /= DT(IDENT_INT(I)) THEN
|
FAILED ("INCORRECT RESULT FOR ""-"" -" &
|
FAILED ("INCORRECT RESULT FOR ""-"" -" &
|
INTEGER'IMAGE(I+11));
|
INTEGER'IMAGE(I+11));
|
END IF;
|
END IF;
|
|
|
IF +D1 /= DT(IDENT_INT(INTEGER(D1))) THEN
|
IF +D1 /= DT(IDENT_INT(INTEGER(D1))) THEN
|
FAILED ("INCORRECT RESULT FOR ""+"" -" &
|
FAILED ("INCORRECT RESULT FOR ""+"" -" &
|
INTEGER'IMAGE(I+11));
|
INTEGER'IMAGE(I+11));
|
END IF;
|
END IF;
|
D1 := D1 - 1;
|
D1 := D1 - 1;
|
END LOOP;
|
END LOOP;
|
|
|
IF INTEGER'LAST + INTEGER'FIRST = 0 THEN
|
IF INTEGER'LAST + INTEGER'FIRST = 0 THEN
|
IF IDENT_INT(-INTEGER'LAST) /= INTEGER'FIRST THEN
|
IF IDENT_INT(-INTEGER'LAST) /= INTEGER'FIRST THEN
|
FAILED ("-INTEGER'LAST IS NOT EQUAL TO INTEGER'FIRST");
|
FAILED ("-INTEGER'LAST IS NOT EQUAL TO INTEGER'FIRST");
|
END IF;
|
END IF;
|
ELSE
|
ELSE
|
IF IDENT_INT(-INTEGER'LAST) /= INTEGER'FIRST+1 THEN
|
IF IDENT_INT(-INTEGER'LAST) /= INTEGER'FIRST+1 THEN
|
FAILED ("-INTEGER'LAST IS NOT EQUAL TO INTEGER'FIRST+1");
|
FAILED ("-INTEGER'LAST IS NOT EQUAL TO INTEGER'FIRST+1");
|
END IF;
|
END IF;
|
END IF;
|
END IF;
|
|
|
RESULT;
|
RESULT;
|
|
|
END C45411A;
|
END C45411A;
|
|
|