blob: 0ba6c07b040088129bfad191279b90d24812c302 [file] [log] [blame]
-- C48004B.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 THE FORM "NEW T" IS PERMITTED IF T IS A CONSTRAINED
-- RECORD, PRIVATE, OR LIMITED PRIVATE TYPE.
-- RM 01/12/80
-- JBG 03/03/83
-- EG 07/05/84
WITH REPORT;
PROCEDURE C48004B IS
USE REPORT;
BEGIN
TEST("C48004B","CHECK THAT THE FORM 'NEW T' IS PERMITTED IF " &
"T IS A CONSTRAINED RECORD, PRIVATE, OR " &
"LIMITED PRIVATE TYPE");
DECLARE
TYPE TB0(A , B : INTEGER ) IS
RECORD
C : INTEGER := 7;
END RECORD;
SUBTYPE TB IS TB0( 2 , 3 );
TYPE ATB IS ACCESS TB0;
VB : ATB;
TYPE TBB0( A , B : INTEGER := 5 ) IS
RECORD
C : INTEGER := 6;
END RECORD;
SUBTYPE TBB IS TBB0( 4 , 5 );
TYPE ATBB IS ACCESS TBB0;
VBB : ATBB;
PACKAGE P IS
TYPE PRIV0( A , B : INTEGER ) IS PRIVATE;
TYPE LPRIV0( A , B : INTEGER := 1 ) IS LIMITED PRIVATE;
FUNCTION FUN(LP : LPRIV0) RETURN INTEGER;
PRIVATE
TYPE PRIV0( A , B : INTEGER ) IS
RECORD
Q : INTEGER;
END RECORD;
TYPE LPRIV0( A , B : INTEGER := 1 ) IS
RECORD
Q : INTEGER := 7;
END RECORD;
END P;
USE P;
SUBTYPE PRIV IS P.PRIV0( 12 , 13 );
TYPE A_PRIV IS ACCESS P.PRIV0;
VP : A_PRIV;
TYPE A_LPRIV IS ACCESS LPRIV0;
VLP : A_LPRIV;
TYPE LCR(A, B : INTEGER := 4) IS
RECORD
C : P.LPRIV0;
END RECORD;
SUBTYPE SLCR IS LCR(1, 2);
TYPE A_SLCR IS ACCESS SLCR;
VSLCR : A_SLCR;
PACKAGE BODY P IS
FUNCTION FUN(LP : LPRIV0) RETURN INTEGER IS
BEGIN
RETURN LP.Q;
END FUN;
END P;
BEGIN
VB := NEW TB;
IF ( VB.A /= IDENT_INT(2) OR
VB.B /= 3 OR
VB.C /= 7 ) THEN FAILED( "WRONG VALUES - B1" );
END IF;
VBB := NEW TBB0;
IF ( VBB.A /= IDENT_INT(5) OR
VBB.B /= 5 OR
VBB.C /= 6 ) THEN
FAILED( "WRONG VALUES - B2" );
END IF;
VP := NEW PRIV;
IF ( VP.A /= IDENT_INT(12) OR
VP.B /= 13 ) THEN
FAILED( "WRONG VALUES - B3" );
END IF;
VLP := NEW LPRIV0;
IF ( VLP.A /= IDENT_INT(1) OR
VLP.B /= 1 OR
P.FUN(VLP.ALL) /= IDENT_INT(7) ) THEN
FAILED( "WRONG VALUES - B4" );
END IF;
VSLCR := NEW SLCR;
IF ( VSLCR.A /= IDENT_INT(1) OR
VSLCR.B /= IDENT_INT(2) OR
P.FUN(VSLCR.C) /= IDENT_INT(7) ) THEN
FAILED ("WRONG VALUES - B5");
END IF;
END;
RESULT;
END C48004B;