blob: ac926d1f4d4cdf32b97c2c50d4abf04f3e866e10 [file] [log] [blame]
-- C37006A.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.
--*
-- FOR A COMPONENT OF A RECORD, ACCESS, OR PRIVATE TYPE, OR FOR A
-- LIMITED PRIVATE COMPONENT, CHECK THAT A NON-STATIC EXPRESSION CAN
-- BE USED IN A DISCRIMINANT CONSTRAINT OR (EXCEPTING LIMITED PRIVATE
-- COMPONENTS) IN SPECIFYING A DEFAULT INITIAL VALUE.
-- R.WILLIAMS 8/28/86
WITH REPORT; USE REPORT;
PROCEDURE C37006A IS
SUBTYPE INT IS INTEGER RANGE 0 .. 100;
TYPE ARR IS ARRAY (INT RANGE <>) OF INTEGER;
TYPE REC1 (D1, D2 : INT) IS
RECORD
A : ARR (D1 .. D2);
END RECORD;
TYPE REC1_NAME IS ACCESS REC1;
PROCEDURE CHECK (AR : ARR; STR : STRING) IS
BEGIN
IF AR'FIRST /= 1 OR AR'LAST /= 2 THEN
FAILED ( "INCORRECT BOUNDS FOR R.COMP.A IN COMPONENT " &
"OF " & STR & " TYPE");
ELSIF AR /= (3, 4) THEN
FAILED ( "INITIALIZATION OF R.COMP.A IN COMPONENT OF " &
STR & " TYPE FAILED" );
END IF;
END CHECK;
PACKAGE PACK IS
TYPE PRIV (D1, D2 : INT) IS PRIVATE;
TYPE LIM (D1, D2 : INT) IS LIMITED PRIVATE;
FUNCTION PRIV_FUN (PARM1, PARM2 : INTEGER) RETURN PRIV;
PROCEDURE PRIV_CHECK (R : PRIV);
PROCEDURE LIM_CHECK (R : LIM);
PRIVATE
TYPE PRIV (D1, D2 : INT) IS
RECORD
A : ARR (D1 .. D2);
END RECORD;
TYPE LIM (D1, D2 : INT) IS
RECORD
A : ARR (D1 .. D2);
END RECORD;
END PACK;
PACKAGE BODY PACK IS
FUNCTION PRIV_FUN (PARM1, PARM2 : INTEGER) RETURN PRIV IS
BEGIN
RETURN (IDENT_INT (1), IDENT_INT (2),
ARR'(1 => 3, 2 => 4));
END PRIV_FUN;
PROCEDURE PRIV_CHECK (R : PRIV) IS
BEGIN
CHECK (R.A, "PRIVATE TYPE" );
END PRIV_CHECK;
PROCEDURE LIM_CHECK (R : LIM) IS
BEGIN
IF R.A'FIRST /= 1 OR R.A'LAST /= 2 THEN
FAILED ( "INCORRECT BOUNDS FOR R.COMP.A IN " &
"COMPONENT OF LIMITED PRIVATE TYPE");
END IF;
END LIM_CHECK;
END PACK;
USE PACK;
BEGIN
TEST ( "C37006A", "FOR A COMPONENT OF A RECORD, ACCESS, " &
"OR PRIVATE TYPE, OR FOR A LIMITED PRIVATE " &
"COMPONENT, CHECK THAT A NON-STATIC " &
"EXPRESSION CAN BE USED IN A DISCRIMINANT " &
"CONSTRAINT OR (EXCEPTING LIMITED PRIVATE " &
"COMPONENTS) IN SPECIFYING A DEFAULT " &
"INITIAL VALUE" );
BEGIN
DECLARE
TYPE REC2 IS
RECORD
COMP : REC1 (IDENT_INT (1), IDENT_INT (2)) :=
(IDENT_INT (1), IDENT_INT (2),
ARR'(1 => 3, 2 => 4));
END RECORD;
R : REC2;
BEGIN
IF R.COMP.D1 = 1 AND R.COMP.D2 = 2 THEN
CHECK (R.COMP.A, "RECORD");
ELSE
FAILED ( "INCORRECT VALUE FOR DISCRIMINANTS " &
"OF RECORD TYPE COMPONENT" );
END IF;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
FAILED ( "CONSTRAINT_ERROR RAISED IN STATEMENT " &
"SEQUENCE FOLLOWING DECLARATION OF " &
"RECORD TYPE COMPONENT" );
WHEN OTHERS =>
FAILED ( "OTHER EXCEPTION RAISED IN STATEMENT " &
"SEQUENCE FOLLOWING DECLARATION OF " &
"RECORD TYPE COMPONENT" );
END;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
FAILED ( "CONSTRAINT_ERROR RAISED BY DECLARATION " &
"OF RECORD TYPE COMPONENT" );
WHEN OTHERS =>
FAILED ( "OTHER EXCEPTION RAISED BY DECLARATION " &
"OF RECORD TYPE COMPONENT" );
END;
BEGIN
DECLARE
TYPE REC2 IS
RECORD
COMP : REC1_NAME (IDENT_INT (1),
IDENT_INT (2)) :=
NEW REC1'(IDENT_INT (1),
IDENT_INT (2),
ARR'(1 => 3, 2 => 4));
END RECORD;
R : REC2;
BEGIN
IF R.COMP.D1 = 1 AND R.COMP.D2 = 2 THEN
CHECK (R.COMP.A, "ACCESS");
ELSE
FAILED ( "INCORRECT VALUE FOR DISCRIMINANTS " &
"OF ACCESS TYPE COMPONENT" );
END IF;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
FAILED ( "CONSTRAINT_ERROR RAISED IN STATEMENT " &
"SEQUENCE FOLLOWING DECLARATION OF " &
"ACCESS TYPE COMPONENT" );
WHEN OTHERS =>
FAILED ( "OTHER EXCEPTION RAISED IN STATEMENT " &
"SEQUENCE FOLLOWING DECLARATION OF " &
"ACCESS TYPE COMPONENT" );
END;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
FAILED ( "CONSTRAINT_ERROR RAISED BY DECLARATION " &
"OF ACCESS TYPE COMPONENT" );
WHEN OTHERS =>
FAILED ( "OTHER EXCEPTION RAISED BY DECLARATION " &
"OF ACCESS TYPE COMPONENT" );
END;
BEGIN
DECLARE
TYPE REC2 IS
RECORD
COMP : PRIV (IDENT_INT (1), IDENT_INT (2)) :=
PRIV_FUN (IDENT_INT (1),
IDENT_INT (2));
END RECORD;
R : REC2;
BEGIN
IF R.COMP.D1 = 1 AND R.COMP.D2 = 2 THEN
PRIV_CHECK (R.COMP);
ELSE
FAILED ( "INCORRECT VALUE FOR DISCRIMINANTS " &
"OF PRIVATE TYPE COMPONENT" );
END IF;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
FAILED ( "CONSTRAINT_ERROR RAISED IN STATEMENT " &
"SEQUENCE FOLLOWING DECLARATION OF " &
"PRIVATE TYPE COMPONENT" );
WHEN OTHERS =>
FAILED ( "OTHER EXCEPTION RAISED IN STATEMENT " &
"SEQUENCE FOLLOWING DECLARATION OF " &
"PRIVATE TYPE COMPONENT" );
END;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
FAILED ( "CONSTRAINT_ERROR RAISED BY DECLARATION " &
"OF PRIVATE TYPE COMPONENT" );
WHEN OTHERS =>
FAILED ( "OTHER EXCEPTION RAISED BY DECLARATION " &
"OF PRIVATE TYPE COMPONENT" );
END;
BEGIN
DECLARE
TYPE REC2 IS
RECORD
COMP : LIM (IDENT_INT (1), IDENT_INT (2));
END RECORD;
R : REC2;
BEGIN
IF R.COMP.D1 = 1 AND R.COMP.D2 = 2 THEN
LIM_CHECK (R.COMP);
ELSE
FAILED ( "INCORRECT VALUE FOR DISCRIMINANTS " &
"OF LIM PRIV TYPE COMPONENT" );
END IF;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
FAILED ( "CONSTRAINT_ERROR RAISED IN STATEMENT " &
"SEQUENCE FOLLOWING DECLARATION OF " &
" LIM PRIV TYPE COMPONENT" );
WHEN OTHERS =>
FAILED ( "OTHER EXCEPTION RAISED IN STATEMENT " &
"SEQUENCE FOLLOWING DECLARATION OF " &
" LIM PRIV TYPE COMPONENT" );
END;
EXCEPTION
WHEN CONSTRAINT_ERROR =>
FAILED ( "CONSTRAINT_ERROR RAISED BY DECLARATION " &
"OF LIM PRIV TYPE COMPONENT" );
WHEN OTHERS =>
FAILED ( "OTHER EXCEPTION RAISED BY DECLARATION " &
"OF LIM PRIV TYPE COMPONENT" );
END;
RESULT;
END C37006A;