-- CC1221C.ADA
|
-- CC1221C.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:
|
-- FOR A FORMAL INTEGER TYPE, CHECK THAT THE FOLLOWING BASIC
|
-- FOR A FORMAL INTEGER TYPE, CHECK THAT THE FOLLOWING BASIC
|
-- OPERATIONS ARE IMPLICITLY DECLARED AND ARE THEREFORE AVAILABLE
|
-- OPERATIONS ARE IMPLICITLY DECLARED AND ARE THEREFORE AVAILABLE
|
-- WITHIN THE GENERIC UNIT: ATTRIBUTES 'POS, 'VAL, 'PRED, 'SUCC,
|
-- WITHIN THE GENERIC UNIT: ATTRIBUTES 'POS, 'VAL, 'PRED, 'SUCC,
|
-- 'IMAGE, AND 'VALUE.
|
-- 'IMAGE, AND 'VALUE.
|
|
|
-- HISTORY:
|
-- HISTORY:
|
-- BCB 11/12/87 CREATED ORIGINAL TEST FROM SPLIT OF CC1221A.ADA
|
-- BCB 11/12/87 CREATED ORIGINAL TEST FROM SPLIT OF CC1221A.ADA
|
|
|
WITH SYSTEM; USE SYSTEM;
|
WITH SYSTEM; USE SYSTEM;
|
WITH REPORT; USE REPORT;
|
WITH REPORT; USE REPORT;
|
PROCEDURE CC1221C IS
|
PROCEDURE CC1221C IS
|
|
|
SUBTYPE SUBINT IS INTEGER RANGE -100 .. 100;
|
SUBTYPE SUBINT IS INTEGER RANGE -100 .. 100;
|
TYPE NEWINT IS NEW INTEGER;
|
TYPE NEWINT IS NEW INTEGER;
|
TYPE INT IS RANGE -300 .. 300;
|
TYPE INT IS RANGE -300 .. 300;
|
SUBTYPE SINT1 IS INT
|
SUBTYPE SINT1 IS INT
|
RANGE INT (IDENT_INT (-4)) .. INT (IDENT_INT (4));
|
RANGE INT (IDENT_INT (-4)) .. INT (IDENT_INT (4));
|
TYPE INT1 IS RANGE -6 .. 6;
|
TYPE INT1 IS RANGE -6 .. 6;
|
|
|
BEGIN
|
BEGIN
|
TEST ( "CC1221C", "FOR A FORMAL INTEGER TYPE, CHECK THAT THE " &
|
TEST ( "CC1221C", "FOR A FORMAL INTEGER TYPE, CHECK THAT THE " &
|
"FOLLOWING BASIC OPERATIONS ARE IMPLICITLY " &
|
"FOLLOWING BASIC OPERATIONS ARE IMPLICITLY " &
|
"DECLARED AND ARE THEREFORE AVAILABLE " &
|
"DECLARED AND ARE THEREFORE AVAILABLE " &
|
"WITHIN THE GENERIC UNIT: ATTRIBUTES 'POS, " &
|
"WITHIN THE GENERIC UNIT: ATTRIBUTES 'POS, " &
|
"'VAL, 'PRED, 'SUCC, 'IMAGE, AND 'VALUE");
|
"'VAL, 'PRED, 'SUCC, 'IMAGE, AND 'VALUE");
|
|
|
DECLARE -- (C1) CHECKS FOR BASIC OPERATIONS OF A DISCRETE TYPE.
|
DECLARE -- (C1) CHECKS FOR BASIC OPERATIONS OF A DISCRETE TYPE.
|
-- PART III.
|
-- PART III.
|
|
|
GENERIC
|
GENERIC
|
TYPE T IS RANGE <>;
|
TYPE T IS RANGE <>;
|
F : INTEGER;
|
F : INTEGER;
|
PROCEDURE P (STR : STRING);
|
PROCEDURE P (STR : STRING);
|
|
|
PROCEDURE P (STR : STRING) IS
|
PROCEDURE P (STR : STRING) IS
|
I : INTEGER;
|
I : INTEGER;
|
Y : T;
|
Y : T;
|
|
|
FUNCTION IDENT (X : T) RETURN T IS
|
FUNCTION IDENT (X : T) RETURN T IS
|
BEGIN
|
BEGIN
|
IF EQUAL (3, 3) THEN
|
IF EQUAL (3, 3) THEN
|
RETURN X;
|
RETURN X;
|
ELSE
|
ELSE
|
RETURN T'SUCC (T'FIRST);
|
RETURN T'SUCC (T'FIRST);
|
END IF;
|
END IF;
|
END IDENT;
|
END IDENT;
|
|
|
BEGIN
|
BEGIN
|
I := F;
|
I := F;
|
FOR X IN T LOOP
|
FOR X IN T LOOP
|
IF T'VAL (I) /= X THEN
|
IF T'VAL (I) /= X THEN
|
FAILED ( "WRONG VALUE FOR " & STR &
|
FAILED ( "WRONG VALUE FOR " & STR &
|
"'VAL OF " & INTEGER'IMAGE (I));
|
"'VAL OF " & INTEGER'IMAGE (I));
|
END IF;
|
END IF;
|
|
|
IF T'POS (X) /= I THEN
|
IF T'POS (X) /= I THEN
|
FAILED ( "WRONG VALUE FOR " & STR &
|
FAILED ( "WRONG VALUE FOR " & STR &
|
"'POS OF " & T'IMAGE (X));
|
"'POS OF " & T'IMAGE (X));
|
END IF;
|
END IF;
|
|
|
I := I + 1;
|
I := I + 1;
|
END LOOP;
|
END LOOP;
|
|
|
FOR X IN T LOOP
|
FOR X IN T LOOP
|
IF T'SUCC (X) /= T'VAL (T'POS (X) + 1) THEN
|
IF T'SUCC (X) /= T'VAL (T'POS (X) + 1) THEN
|
FAILED ( "WRONG VALUE FOR " & STR &
|
FAILED ( "WRONG VALUE FOR " & STR &
|
"'SUCC OF " & T'IMAGE (X));
|
"'SUCC OF " & T'IMAGE (X));
|
END IF;
|
END IF;
|
|
|
IF T'PRED (X) /= T'VAL (T'POS (X) - 1) THEN
|
IF T'PRED (X) /= T'VAL (T'POS (X) - 1) THEN
|
FAILED ( "WRONG VALUE FOR " & STR &
|
FAILED ( "WRONG VALUE FOR " & STR &
|
"'PRED OF " & T'IMAGE (X));
|
"'PRED OF " & T'IMAGE (X));
|
END IF;
|
END IF;
|
END LOOP;
|
END LOOP;
|
|
|
BEGIN
|
BEGIN
|
Y := T'SUCC (IDENT (T'BASE'LAST));
|
Y := T'SUCC (IDENT (T'BASE'LAST));
|
FAILED ( "NO EXCEPTION RAISED FOR " &
|
FAILED ( "NO EXCEPTION RAISED FOR " &
|
STR & "'SUCC (IDENT (" & STR &
|
STR & "'SUCC (IDENT (" & STR &
|
"'BASE'LAST))" );
|
"'BASE'LAST))" );
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
NULL;
|
NULL;
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ( "WRONG EXCEPTION RAISED FOR " &
|
FAILED ( "WRONG EXCEPTION RAISED FOR " &
|
STR & "'SUCC (IDENT (" & STR &
|
STR & "'SUCC (IDENT (" & STR &
|
"'BASE'LAST))" );
|
"'BASE'LAST))" );
|
END;
|
END;
|
|
|
BEGIN
|
BEGIN
|
Y := T'PRED (IDENT (T'BASE'FIRST));
|
Y := T'PRED (IDENT (T'BASE'FIRST));
|
FAILED ( "NO EXCEPTION RAISED FOR " &
|
FAILED ( "NO EXCEPTION RAISED FOR " &
|
STR & "'PRED (IDENT (" & STR &
|
STR & "'PRED (IDENT (" & STR &
|
"'BASE'FIRST))" );
|
"'BASE'FIRST))" );
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
NULL;
|
NULL;
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ( "WRONG EXCEPTION RAISED FOR " &
|
FAILED ( "WRONG EXCEPTION RAISED FOR " &
|
STR & "'PRED (IDENT (" & STR &
|
STR & "'PRED (IDENT (" & STR &
|
"'BASE'FIRST))" );
|
"'BASE'FIRST))" );
|
END;
|
END;
|
|
|
END P;
|
END P;
|
|
|
PROCEDURE P1 IS NEW P (SUBINT, -100);
|
PROCEDURE P1 IS NEW P (SUBINT, -100);
|
PROCEDURE P2 IS NEW P (SINT1, -4);
|
PROCEDURE P2 IS NEW P (SINT1, -4);
|
PROCEDURE P3 IS NEW P (INT1, -6);
|
PROCEDURE P3 IS NEW P (INT1, -6);
|
|
|
BEGIN
|
BEGIN
|
P1 ( "SUBINT" );
|
P1 ( "SUBINT" );
|
P2 ( "SINT" );
|
P2 ( "SINT" );
|
P3 ( "INT1" );
|
P3 ( "INT1" );
|
END; -- (C1).
|
END; -- (C1).
|
|
|
DECLARE -- (C2) CHECKS FOR BASIC OPERATIONS OF A DISCRETE TYPE.
|
DECLARE -- (C2) CHECKS FOR BASIC OPERATIONS OF A DISCRETE TYPE.
|
-- PART IV.
|
-- PART IV.
|
|
|
GENERIC
|
GENERIC
|
TYPE T IS RANGE <>;
|
TYPE T IS RANGE <>;
|
STR : STRING;
|
STR : STRING;
|
PACKAGE PKG IS END PKG;
|
PACKAGE PKG IS END PKG;
|
|
|
PACKAGE BODY PKG IS
|
PACKAGE BODY PKG IS
|
PROCEDURE P (IM : STRING; VA : T) IS
|
PROCEDURE P (IM : STRING; VA : T) IS
|
BEGIN
|
BEGIN
|
IF T'IMAGE (VA) /= IM THEN
|
IF T'IMAGE (VA) /= IM THEN
|
FAILED ( "INCORRECT RESULTS FOR " & STR &
|
FAILED ( "INCORRECT RESULTS FOR " & STR &
|
"'IMAGE OF " &
|
"'IMAGE OF " &
|
INTEGER'IMAGE (INTEGER (VA)));
|
INTEGER'IMAGE (INTEGER (VA)));
|
END IF;
|
END IF;
|
END P;
|
END P;
|
|
|
PROCEDURE Q (IM : STRING; VA : T) IS
|
PROCEDURE Q (IM : STRING; VA : T) IS
|
BEGIN
|
BEGIN
|
IF T'VALUE (IM) /= VA THEN
|
IF T'VALUE (IM) /= VA THEN
|
FAILED ( "INCORRECT RESULTS FOR " & STR &
|
FAILED ( "INCORRECT RESULTS FOR " & STR &
|
"'VALUE OF " & IM);
|
"'VALUE OF " & IM);
|
END IF;
|
END IF;
|
EXCEPTION
|
EXCEPTION
|
WHEN CONSTRAINT_ERROR =>
|
WHEN CONSTRAINT_ERROR =>
|
FAILED ( "CONSTRAINT_ERROR RAISED FOR " &
|
FAILED ( "CONSTRAINT_ERROR RAISED FOR " &
|
STR &"'VALUE OF " & IM);
|
STR &"'VALUE OF " & IM);
|
WHEN OTHERS =>
|
WHEN OTHERS =>
|
FAILED ( "OTHER EXCEPTION RAISED FOR " &
|
FAILED ( "OTHER EXCEPTION RAISED FOR " &
|
STR &"'VALUE OF " & IM);
|
STR &"'VALUE OF " & IM);
|
|
|
END Q;
|
END Q;
|
|
|
BEGIN
|
BEGIN
|
P (" 2", 2);
|
P (" 2", 2);
|
P ("-1", -1);
|
P ("-1", -1);
|
|
|
Q (" 2", 2);
|
Q (" 2", 2);
|
Q ("-1", -1);
|
Q ("-1", -1);
|
Q (" 2", 2);
|
Q (" 2", 2);
|
Q ("-1 ", -1);
|
Q ("-1 ", -1);
|
END PKG;
|
END PKG;
|
|
|
PACKAGE PKG1 IS NEW PKG (SUBINT, "SUBINT");
|
PACKAGE PKG1 IS NEW PKG (SUBINT, "SUBINT");
|
PACKAGE PKG2 IS NEW PKG (SINT1, "SINT1");
|
PACKAGE PKG2 IS NEW PKG (SINT1, "SINT1");
|
PACKAGE PKG3 IS NEW PKG (INT1, "INT1");
|
PACKAGE PKG3 IS NEW PKG (INT1, "INT1");
|
PACKAGE PKG4 IS NEW PKG (NEWINT, "NEWINT");
|
PACKAGE PKG4 IS NEW PKG (NEWINT, "NEWINT");
|
|
|
BEGIN
|
BEGIN
|
NULL;
|
NULL;
|
END; -- (C2).
|
END; -- (C2).
|
|
|
RESULT;
|
RESULT;
|
END CC1221C;
|
END CC1221C;
|
|
|