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