Mercurial > hg > CbC > CbC_gcc
comparison gcc/testsuite/ada/acats/tests/c4/c41303o.ada @ 111:04ced10e8804
gcc 7
author | kono |
---|---|
date | Fri, 27 Oct 2017 22:46:09 +0900 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
68:561a7518be6b | 111:04ced10e8804 |
---|---|
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 | |
64 WITH REPORT; | |
65 USE REPORT; | |
66 PROCEDURE C41303O IS | |
67 | |
68 | |
69 BEGIN | |
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 | |
145 END C41303O; |