1-- C41303S.ADA 2 3-- Grant of Unlimited Rights 4-- 5-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687, 6-- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained 7-- unlimited rights in the software and documentation contained herein. 8-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making 9-- this public release, the Government intends to confer upon all 10-- recipients unlimited rights equal to those held by the Government. 11-- These rights include rights to use, duplicate, release or disclose the 12-- released technical data and computer software in whole or in part, in 13-- any manner and for any purpose whatsoever, and to have or permit others 14-- to do so. 15-- 16-- DISCLAIMER 17-- 18-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR 19-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED 20-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE 21-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE 22-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A 23-- PARTICULAR PURPOSE OF SAID MATERIAL. 24--* 25-- CHECK THAT THE NOTATION L.ALL IS ALLOWED IF L IS THE NAME OF AN 26-- ACCESS OBJECT DESIGNATING A RECORD, AN ARRAY, A SCALAR, OR 27-- ANOTHER ACCESS OBJECT. 28-- CHECK THAT IF A IS AN IDENTIFIER DENOTING AN ACCESS OBJECT WHICH 29-- IN TURN DESIGNATES AN ACCESS OBJECT, THE FORM A.ALL.ALL IS 30-- ACCEPTED. 31 32 33-- THIS OBJECTIVE IS COVERED IN SEVERAL TESTS. IN THE FOLLOWING DIAGRAM, 34-- THE PORTION COVERED BY THE CURRENT TEST IS MARKED BY 'X' . 35 36 37-- || ASSIGNMT | PROC. PARAMETERS 38-- || ():= :=() | IN OUT IN OUT 39-- ========================||=============|==================== 40-- ACC REC || | 41-- --------------||-------------|-------------------- 42-- 1 '.ALL' ACC ARR || | 43-- --------------||-------------|-------------------- 44-- ACC SCLR || | 45-- ========================||=============|==================== 46-- ACC ACC REC || | 47-- --------------||-------------|-------------------- 48-- 1 '.ALL' ACC ACC ARR || | 49-- --------------||-------------|-------------------- 50-- ACC ACC SCLR || | XXXXXXXXX 51-- ========================||=============|==================== 52-- ACC ACC REC || | 53-- --------------||-------------|-------------------- 54-- 2 '.ALL' ACC ACC ARR || | 55-- --------------||-------------|-------------------- 56-- ACC ACC SCLR || | 57-- ============================================================ 58 59 60-- RM 1/28/82 61-- SPS 12/2/82 62 63 64WITH REPORT; 65USE REPORT; 66PROCEDURE C41303S IS 67 68 69BEGIN 70 71 TEST ( "C41303S" , "CHECK THAT THE NOTATION L.ALL IS ALLOWED IF" 72 & " L IS THE NAME OF AN ACCESS OBJECT" 73 & " DESIGNATING ANOTHER ACCESS OBJECT" ); 74 75 76 ------------------------------------------------------------------- 77 --------------- ACCESS TO ACCESS TO SCALAR ---------------------- 78 79 DECLARE 80 81 TYPE NEWINT IS NEW INTEGER ; 82 83 TYPE ACCNEWINT IS ACCESS NEWINT ; 84 85 ACCNEWINT_CONST : ACCNEWINT := NEW NEWINT'( 813 ); 86 ACCNEWINT_VAR : ACCNEWINT := ACCNEWINT_CONST ; 87 ACCNEWINT_VAR0 : ACCNEWINT := ACCNEWINT_CONST ; 88 ACCNEWINT_CONST2 : ACCNEWINT := NEW NEWINT'( 707 ); 89 90 TYPE ACC_ACCNEWINT IS ACCESS ACCNEWINT ; 91 92 ACC_ACCNEWINT_VAR : ACC_ACCNEWINT := NEW ACCNEWINT'( 93 ACCNEWINT_CONST2 94 ); 95 96 ACC_ACCNEWINT_VAR0 : ACC_ACCNEWINT := NEW ACCNEWINT'( 97 ACCNEWINT_CONST2 98 ); 99 100 PROCEDURE R_ASSIGN( R_IN : IN ACCNEWINT ; 101 R_INOUT : IN OUT ACCNEWINT ) IS 102 BEGIN 103 ACCNEWINT_VAR := R_IN ; 104 ACCNEWINT_VAR0 := R_INOUT ; 105 END ; 106 107 108 PROCEDURE L_ASSIGN( L_OUT : OUT ACCNEWINT ; 109 L_INOUT : IN OUT ACCNEWINT ) IS 110 BEGIN 111 L_OUT := ACCNEWINT_CONST ; 112 L_INOUT := ACCNEWINT_CONST ; 113 END ; 114 115 116 BEGIN 117 118 R_ASSIGN( ACC_ACCNEWINT_VAR.ALL , ACC_ACCNEWINT_VAR0.ALL ); 119 120 IF ACCNEWINT_VAR /= ACCNEWINT_CONST2 121 THEN 122 FAILED( "ACC. NEWINT, RIGHT SIDE (1), WRONG VAL." ); 123 END IF; 124 125 IF ACCNEWINT_VAR0 /= ACCNEWINT_CONST2 126 THEN 127 FAILED( "ACC. NEWINT, RIGHT SIDE (2), WRONG VAL." ); 128 END IF; 129 130 131 L_ASSIGN( ACC_ACCNEWINT_VAR.ALL , ACC_ACCNEWINT_VAR0.ALL ); 132 133 IF ACCNEWINT_CONST /= ACC_ACCNEWINT_VAR.ALL 134 THEN 135 FAILED( "ACC. NEWINT, LEFT SIDE (1), WRONG VAL." ); 136 END IF; 137 138 IF ACCNEWINT_CONST /= ACC_ACCNEWINT_VAR0.ALL 139 THEN 140 FAILED( "ACC. NEWINT, LEFT SIDE (2), WRONG VAL." ); 141 END IF; 142 143 144 END ; 145 146 ------------------------------------------------------------------- 147 148 RESULT; 149 150 151END C41303S; 152