1-- C41303M.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      ||             |     XXXXXXXXX
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 ||             |
57--      ============================================================
58
59
60-- RM  1/22/82
61-- RM  1/26/82
62-- SPS 12/2/82
63
64
65WITH REPORT;
66USE REPORT;
67PROCEDURE C41303M IS
68
69
70BEGIN
71
72     TEST ( "C41303M" , "CHECK THAT  L.ALL  , WHERE  L  IS THE NAME OF"
73                      & " AN ACCESS OBJECT DESIGNATING A RECORD, AN"
74                      & " ARRAY, OR A SCALAR,  IS ALLOWED AS"
75                      & " ACTUAL PARAMETER OF ANY MODE" );
76
77
78     -------------------------------------------------------------------
79     --------------------  ACCESS TO RECORD  ---------------------------
80
81     DECLARE
82
83          TYPE  REC  IS
84
85               RECORD
86                    A , B , C : INTEGER ;
87               END RECORD ;
88
89          REC_CONST    :  REC  :=  ( 7 , 8 , 9 );
90          REC_VAR      :  REC  :=    REC_CONST  ;
91          REC_VAR0     :  REC  :=    REC_CONST  ;
92
93          TYPE  ACC_REC  IS  ACCESS REC ;
94
95          ACC_REC_VAR  :  ACC_REC  :=  NEW REC'( 17 , 18 , 19 );
96          ACC_REC_VAR0 :  ACC_REC  :=  NEW REC'( 17 , 18 , 19 );
97
98
99          PROCEDURE  R_ASSIGN( R_IN    : IN      REC ;
100                               R_INOUT : IN OUT  REC )  IS
101          BEGIN
102               REC_VAR   :=  R_IN    ;
103               REC_VAR0  :=  R_INOUT ;
104          END ;
105
106
107          PROCEDURE  L_ASSIGN( L_OUT   :    OUT  REC ;
108                               L_INOUT : IN OUT  REC )  IS
109          BEGIN
110               L_OUT   :=  REC_CONST ;
111               L_INOUT :=  REC_CONST ;
112          END ;
113
114     BEGIN
115
116          R_ASSIGN( ACC_REC_VAR.ALL , ACC_REC_VAR0.ALL );
117
118          IF  REC_VAR /= ( 17 , 18 , 19 )
119          THEN
120               FAILED( "ACC. RECORD, RIGHT SIDE (1), WRONG VAL.");
121          END IF;
122
123          IF  REC_VAR0 /= ( 17 , 18 , 19 )
124          THEN
125               FAILED( "ACC. RECORD, RIGHT SIDE (2), WRONG VAL.");
126          END IF;
127
128
129          L_ASSIGN( ACC_REC_VAR.ALL , ACC_REC_VAR0.ALL );
130
131          IF  ACC_REC_VAR.ALL /= ( 7 , 8 , 9 )
132          THEN
133              FAILED( "ACC. RECORD, LEFT SIDE (1), WRONG VAL." );
134          END IF;
135
136
137          IF  ACC_REC_VAR0.ALL /= ( 7 , 8 , 9 )
138          THEN
139               FAILED( "ACC. RECORD, LEFT SIDE (2), WRONG VAL." );
140          END IF;
141
142
143     END ;
144
145     -------------------------------------------------------------------
146
147     RESULT;
148
149
150END C41303M;
151