1-- C41303O.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 || | XXXXXXXXX 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 || | 57-- ============================================================ 58 59 60-- RM 1/27/82 61-- SPS 12/2/82 62 63 64WITH REPORT; 65USE REPORT; 66PROCEDURE C41303O IS 67 68 69BEGIN 70 71 TEST ( "C41303O" , "CHECK THAT L.ALL , WHERE L IS THE NAME OF" 72 & " AN ACCESS OBJECT DESIGNATING A RECORD, AN" 73 & " ARRAY, OR A SCALAR, IS ALLOWED AS" 74 & " ACTUAL PARAMETER OF ANY MODE" ); 75 76 77 ------------------------------------------------------------------- 78 -------------------- 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 88 TYPE ACC_NEWINT IS ACCESS NEWINT ; 89 90 ACC_NEWINT_VAR : ACC_NEWINT := NEW NEWINT'( 707 ); 91 ACC_NEWINT_VAR0 : ACC_NEWINT := NEW NEWINT'( 707 ); 92 93 94 PROCEDURE R_ASSIGN( R_IN : IN NEWINT ; 95 R_INOUT : IN OUT NEWINT ) IS 96 BEGIN 97 NEWINT_VAR := R_IN ; 98 NEWINT_VAR0 := R_INOUT ; 99 END ; 100 101 102 PROCEDURE L_ASSIGN( L_OUT : OUT NEWINT ; 103 L_INOUT : IN OUT NEWINT ) IS 104 BEGIN 105 L_OUT := NEWINT_CONST ; 106 L_INOUT := NEWINT_CONST ; 107 END ; 108 109 110 BEGIN 111 112 R_ASSIGN( ACC_NEWINT_VAR.ALL , ACC_NEWINT_VAR0.ALL ); 113 114 IF NEWINT_VAR /= ( 707 ) 115 THEN 116 FAILED( "ACC. NEWINT, RIGHT SIDE (1), WRONG VAL." ); 117 END IF; 118 119 IF NEWINT_VAR0 /= ( 707 ) 120 THEN 121 FAILED( "ACC. NEWINT, RIGHT SIDE (2), WRONG VAL." ); 122 END IF; 123 124 125 L_ASSIGN( ACC_NEWINT_VAR.ALL , ACC_NEWINT_VAR0.ALL ); 126 127 IF ACC_NEWINT_VAR.ALL /= 813 128 THEN 129 FAILED( "ACC. NEWINT, LEFT SIDE (1), WRONG VAL." ); 130 END IF; 131 132 IF ACC_NEWINT_VAR0.ALL /= 813 133 THEN 134 FAILED( "ACC. NEWINT, LEFT SIDE (2), WRONG VAL." ); 135 END IF; 136 137 138 END ; 139 140 ------------------------------------------------------------------- 141 142 RESULT; 143 144 145END C41303O; 146