| -- C48004D.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 RECORD, PRIVATE, |
| -- OR LIMITED TYPE WITHOUT DISCRIMINANTS. |
| |
| -- RM 01/12/80 |
| -- JBG 03/03/83 |
| -- EG 07/05/84 |
| |
| WITH REPORT; |
| |
| PROCEDURE C48004D IS |
| |
| USE REPORT; |
| |
| BEGIN |
| |
| TEST("C48004D","CHECK THAT THE FORM 'NEW T' IS PERMITTED IF T " & |
| "IS A RECORD, PRIVATE, OR LIMITED TYPE WITHOUT " & |
| "DISCRIMINANTS"); |
| |
| DECLARE |
| |
| TYPE TC IS |
| RECORD |
| C : INTEGER := 18; |
| END RECORD; |
| TYPE ATC IS ACCESS TC; |
| VC : ATC; |
| |
| PACKAGE P IS |
| TYPE PRIV IS PRIVATE; |
| TYPE LPRIV IS LIMITED PRIVATE; |
| TYPE A_PRIV IS ACCESS PRIV; |
| TYPE A_LPRIV IS ACCESS LPRIV; |
| PROCEDURE CHECK( X: A_PRIV ); |
| PROCEDURE LCHECK( X: A_LPRIV ); |
| PROCEDURE LRCHECK( X: LPRIV ); |
| PRIVATE |
| TYPE PRIV IS |
| RECORD |
| Q : INTEGER := 19; |
| END RECORD; |
| TYPE LPRIV IS |
| RECORD |
| Q : INTEGER := 20; |
| END RECORD; |
| END P; |
| |
| |
| VP : P.A_PRIV; |
| VLP : P.A_LPRIV; |
| |
| TYPE LCR IS |
| RECORD |
| C : P.LPRIV; |
| END RECORD; |
| TYPE A_LCR IS ACCESS LCR; |
| VLCR : A_LCR; |
| |
| PACKAGE BODY P IS |
| |
| PROCEDURE CHECK( X: A_PRIV ) IS |
| BEGIN |
| IF X.Q /= 19 THEN FAILED( "WRONG VALUES - C2" ); |
| END IF; |
| END CHECK; |
| |
| PROCEDURE LCHECK( X: A_LPRIV ) IS |
| BEGIN |
| IF X.Q /= 20 THEN FAILED( "WRONG VALUES - C3" ); |
| END IF; |
| END LCHECK; |
| |
| PROCEDURE LRCHECK (X : LPRIV) IS |
| BEGIN |
| IF X.Q /= 20 THEN |
| FAILED ("WRONG VALUES - C4"); |
| END IF; |
| END LRCHECK; |
| |
| END P; |
| |
| BEGIN |
| |
| VC := NEW TC; |
| IF VC.C /= 18 THEN FAILED( "WRONG VALUES - C1" ); |
| END IF; |
| |
| VP := NEW P.PRIV; |
| P.CHECK( VP ); |
| VLP := NEW P.LPRIV; |
| P.LCHECK( VLP ); |
| |
| VLCR := NEW LCR; |
| P.LRCHECK( VLCR.ALL.C ); |
| |
| END; |
| |
| RESULT; |
| |
| END C48004D; |