blob: 253acc51fdb4acbeefd83e6254614ca956178007 [file] [log] [blame]
-- C32001E.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 IN MULTIPLE OBJECT DECLARATIONS FOR PRIVATE TYPES, THE
-- SUBTYPE INDICATION AND THE INITIALIZATION EXPRESSIONS ARE EVALUATED
-- ONCE FOR EACH NAMED OBJECT THAT IS DECLARED AND THE SUBTYPE
-- INDICATION IS EVALUATED FIRST. ALSO, CHECK THAT THE EVALUATIONS
-- YIELD THE SAME RESULT AS A SEQUENCE OF SINGLE OBJECT DECLARATIONS.
-- RJW 7/18/86
WITH REPORT; USE REPORT;
PROCEDURE C32001E IS
BUMP : ARRAY (1 .. 10) OF INTEGER := (OTHERS => 0);
G1 : ARRAY (5 .. 6) OF INTEGER;
FUNCTION F (I : INTEGER) RETURN INTEGER IS
BEGIN
BUMP (I) := BUMP (I) + 1;
RETURN BUMP (I);
END F;
FUNCTION G (I : INTEGER) RETURN INTEGER IS
BEGIN
BUMP (I) := BUMP (I) + 1;
G1 (I) := BUMP (I);
RETURN BUMP (I);
END G;
BEGIN
TEST ("C32001E", "CHECK THAT IN MULTIPLE OBJECT DECLARATIONS " &
"FOR PRIVATE TYPES, THE SUBTYPE INDICATION " &
"AND THE INITIALIZATION EXPRESSIONS ARE " &
"EVALUATED ONCE FOR EACH NAMED OBJECT THAT " &
"IS DECLARED AND THE SUBTYPE INDICATION IS " &
"EVALUATED FIRST. ALSO, CHECK THAT THE " &
"EVALUATIONS YIELD THE SAME RESULT AS A " &
"SEQUENCE OF SINGLE OBJECT DECLARATIONS" );
DECLARE
PACKAGE PKG1 IS
TYPE PBOOL IS PRIVATE;
TYPE PINT IS PRIVATE;
TYPE PREC (D : INTEGER) IS PRIVATE;
TYPE PARR IS PRIVATE;
TYPE PACC IS PRIVATE;
FUNCTION INIT1 (I : INTEGER) RETURN PBOOL;
FUNCTION INIT2 (I : INTEGER) RETURN PINT;
FUNCTION INIT3 (I : INTEGER) RETURN PREC;
FUNCTION INIT4 (I : INTEGER) RETURN PARR;
FUNCTION INIT5 (I : INTEGER) RETURN PACC;
PROCEDURE CHECK1 (B : PBOOL; I : INTEGER; S : STRING);
PROCEDURE CHECK2 (I : PINT; J : INTEGER; S : STRING);
PROCEDURE CHECK3 (R : PREC; I, J : INTEGER;
S : STRING);
PROCEDURE CHECK4 (A : PARR; I, J : INTEGER;
S : STRING);
PROCEDURE CHECK5 (V : PACC; S : STRING);
PROCEDURE CHECK6 (V : PACC; S : STRING);
PRIVATE
TYPE PBOOL IS NEW BOOLEAN;
TYPE PINT IS NEW INTEGER;
TYPE PREC (D : INTEGER) IS
RECORD
VALUE : INTEGER;
END RECORD;
TYPE PARR IS ARRAY (1 .. 2) OF INTEGER;
TYPE VECTOR IS ARRAY (NATURAL RANGE <>) OF INTEGER;
TYPE PACC IS ACCESS VECTOR;
END PKG1;
PACKAGE BODY PKG1 IS
FUNCTION INIT1 (I : INTEGER) RETURN PBOOL IS
BEGIN
RETURN PBOOL'VAL (F (I) - 1);
END INIT1;
FUNCTION INIT2 (I : INTEGER) RETURN PINT IS
BEGIN
RETURN PINT'VAL (F (I));
END INIT2;
FUNCTION INIT3 (I : INTEGER) RETURN PREC IS
PR : PREC (G1 (I)) := (G1 (I), F (I));
BEGIN
RETURN PR;
END INIT3;
FUNCTION INIT4 (I : INTEGER) RETURN PARR IS
PA : PARR := (1 .. 2 => F (I));
BEGIN
RETURN PA;
END INIT4;
FUNCTION INIT5 (I : INTEGER) RETURN PACC IS
ACCV : PACC := NEW VECTOR'(1 .. F (I) => F (I));
BEGIN
RETURN ACCV;
END INIT5;
PROCEDURE CHECK1 (B : PBOOL; I : INTEGER; S : STRING) IS
BEGIN
IF B /= PBOOL'VAL (I) THEN
FAILED ( S & " HAS AN INCORRECT VALUE OF " &
PBOOL'IMAGE (B));
END IF;
END CHECK1;
PROCEDURE CHECK2 (I : PINT; J : INTEGER; S : STRING) IS
BEGIN
IF I /= PINT'VAL (J) THEN
FAILED ( S & " HAS AN INCORRECT VALUE OF " &
PINT'IMAGE (I));
END IF;
END CHECK2;
PROCEDURE CHECK3 (R : PREC; I, J : INTEGER;
S : STRING) IS
BEGIN
IF R.D /= I THEN
FAILED ( S & ".D HAS AN INCORRECT VALUE OF "
& INTEGER'IMAGE (R.D));
END IF;
IF R.VALUE /= J THEN
FAILED ( S & ".VALUE HAS AN INCORRECT " &
"VALUE OF " &
INTEGER'IMAGE (R.VALUE));
END IF;
END CHECK3;
PROCEDURE CHECK4 (A : PARR; I, J : INTEGER;
S : STRING) IS
BEGIN
IF A /= (I, J) AND A /= (J, I) THEN
FAILED ( S & " HAS AN INCORRECT VALUE" );
END IF;
END CHECK4;
PROCEDURE CHECK5 (V : PACC; S : STRING) IS
BEGIN
IF V'LAST /= 1 THEN
FAILED ( S & " HAS AN INCORRECT UPPER BOUND "
& "OF " & INTEGER'IMAGE (V'LAST));
END IF;
IF V (1) /= 2 THEN
FAILED ( S & " HAS AN INCORRECT COMPONENT " &
"VALUE" );
END IF;
END CHECK5;
PROCEDURE CHECK6 (V : PACC; S : STRING) IS
BEGIN
IF V'LAST /= 3 THEN
FAILED ( S & " HAS AN INCORRECT UPPER BOUND "
& "OF " & INTEGER'IMAGE (V'LAST));
END IF;
IF V.ALL = (4, 5, 6) OR V.ALL = (5, 4, 6) OR
V.ALL = (4, 6, 5) OR V.ALL = (6, 4, 5) OR
V.ALL = (5, 6, 4) OR V.ALL = (6, 5, 4) THEN
NULL;
ELSE
FAILED ( S & " HAS AN INCORRECT COMPONENT " &
"VALUE" );
END IF;
END CHECK6;
END PKG1;
PACKAGE PKG2 IS END PKG2;
PACKAGE BODY PKG2 IS
USE PKG1;
B1, B2 : PBOOL := INIT1 (1);
CB1, CB2 : CONSTANT PBOOL := INIT1 (2);
I1, I2 : PINT := INIT2 (3);
CI1, CI2 : CONSTANT PINT := INIT2 (4);
R1, R2 : PREC (G (5)) := INIT3 (5);
CR1, CR2 : CONSTANT PREC (G (6)) := INIT3 (6);
A1, A2 : PARR := INIT4 (7);
CA1, CA2 : CONSTANT PARR := INIT4 (8);
V1, V2 : PACC := INIT5 (9);
CV1, CV2 : CONSTANT PACC := INIT5 (10);
BEGIN
CHECK1 (B1, 0, "B1");
CHECK1 (B2, 1, "B2");
CHECK1 (CB1, 0, "CB1");
CHECK1 (CB2, 1, "CB2");
CHECK2 (I1, 1, "I1");
CHECK2 (I2, 2, "I2");
CHECK2 (CI1, 1, "CI1");
CHECK2 (CI2, 2, "CI2");
CHECK3 (R1, 1, 2, "R1");
CHECK3 (R2, 3, 4, "R2");
CHECK3 (CR1, 1, 2, "CR1");
CHECK3 (CR2, 3, 4, "CR2");
CHECK4 (A1, 1, 2, "A1");
CHECK4 (A2, 3, 4, "A2");
CHECK4 (CA1, 1, 2, "CA1");
CHECK4 (CA2, 3, 4, "CA2");
CHECK5 (V1, "V1");
CHECK6 (V2, "V2");
CHECK5 (CV1, "CV1");
CHECK6 (CV2, "CV2");
END PKG2;
BEGIN
NULL;
END;
RESULT;
END C32001E;