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