1-- C41303W.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 || | 51-- ========================||=============|==================== 52-- ACC ACC REC || | 53-- --------------||-------------|-------------------- 54-- 2 '.ALL' ACC ACC ARR || | 55-- --------------||-------------|-------------------- 56-- ACC ACC SCLR || | XXXXXXXXX 57-- ============================================================ 58 59 60-- RM 1/29/82 61-- SPS 12/2/82 62 63 64WITH REPORT; 65USE REPORT; 66PROCEDURE C41303W IS 67 68 69BEGIN 70 71 TEST ( "C41303W" , "CHECK THAT IF A IS AN IDENTIFIER DENOTING" & 72 " AN ACCESS OBJECT WHICH IN TURN DESIGNATES" & 73 " AN ACCESS OBJECT, THE FORM A.ALL.ALL IS" & 74 " ACCEPTED" ); 75 76 77 ------------------------------------------------------------------- 78 --------------- ACCESS TO ACCESS TO SCALAR ---------------------- 79 80 DECLARE 81 82 TYPE NEWINT IS NEW INTEGER ; 83 84 NEWINT_CONST : NEWINT := ( 813 ); 85 NEWINT_VAR : NEWINT := NEWINT_CONST ; 86 NEWINT_VAR0 : NEWINT := NEWINT_CONST ; 87 NEWINT_CONST2 : NEWINT := ( 707 ); 88 89 TYPE ACCNEWINT IS ACCESS NEWINT ; 90 91 TYPE ACC_ACCNEWINT IS ACCESS ACCNEWINT ; 92 93 ACC_ACCNEWINT_VAR : ACC_ACCNEWINT := NEW ACCNEWINT'( 94 NEW NEWINT' ( 95 NEWINT_CONST2 96 ) 97 ); 98 99 ACC_ACCNEWINT_VAR0 : ACC_ACCNEWINT := NEW ACCNEWINT'( 100 NEW NEWINT' ( 101 NEWINT_CONST2 102 ) 103 ); 104 105 PROCEDURE R_ASSIGN( R_IN : IN NEWINT ; 106 R_INOUT : IN OUT NEWINT ) IS 107 BEGIN 108 NEWINT_VAR := R_IN ; 109 NEWINT_VAR0 := R_INOUT ; 110 END ; 111 112 113 PROCEDURE L_ASSIGN( L_OUT : OUT NEWINT ; 114 L_INOUT : IN OUT NEWINT ) IS 115 BEGIN 116 L_OUT := NEWINT_CONST ; 117 L_INOUT := NEWINT_CONST ; 118 END ; 119 120 121 BEGIN 122 123 124 R_ASSIGN( ACC_ACCNEWINT_VAR.ALL.ALL , 125 ACC_ACCNEWINT_VAR0.ALL.ALL ); 126 127 IF NEWINT_VAR /= NEWINT_CONST2 128 THEN 129 FAILED( "ACC2 NEWINT, RIGHT SIDE (1), WRONG VAL." ); 130 END IF; 131 132 IF NEWINT_VAR0 /= NEWINT_CONST2 133 THEN 134 FAILED( "ACC2 NEWINT, RIGHT SIDE (2), WRONG VAL." ); 135 END IF; 136 137 138 L_ASSIGN( ACC_ACCNEWINT_VAR.ALL.ALL , 139 ACC_ACCNEWINT_VAR0.ALL.ALL ); 140 141 IF NEWINT_CONST /= ACC_ACCNEWINT_VAR.ALL.ALL 142 THEN 143 FAILED( "ACC2 NEWINT, LEFT SIDE (1), WRONG VAL." ); 144 END IF; 145 146 IF NEWINT_CONST /= ACC_ACCNEWINT_VAR0.ALL.ALL 147 THEN 148 FAILED( "ACC2 NEWINT, LEFT SIDE (2), WRONG VAL." ); 149 END IF; 150 151 152 END ; 153 154 ------------------------------------------------------------------- 155 156 RESULT; 157 158 159END C41303W; 160