annotate gcc/testsuite/ada/acats/tests/c4/c41103b.ada @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 -- C41103B.ADA
kono
parents:
diff changeset
2
kono
parents:
diff changeset
3 -- Grant of Unlimited Rights
kono
parents:
diff changeset
4 --
kono
parents:
diff changeset
5 -- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
kono
parents:
diff changeset
6 -- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
kono
parents:
diff changeset
7 -- unlimited rights in the software and documentation contained herein.
kono
parents:
diff changeset
8 -- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
kono
parents:
diff changeset
9 -- this public release, the Government intends to confer upon all
kono
parents:
diff changeset
10 -- recipients unlimited rights equal to those held by the Government.
kono
parents:
diff changeset
11 -- These rights include rights to use, duplicate, release or disclose the
kono
parents:
diff changeset
12 -- released technical data and computer software in whole or in part, in
kono
parents:
diff changeset
13 -- any manner and for any purpose whatsoever, and to have or permit others
kono
parents:
diff changeset
14 -- to do so.
kono
parents:
diff changeset
15 --
kono
parents:
diff changeset
16 -- DISCLAIMER
kono
parents:
diff changeset
17 --
kono
parents:
diff changeset
18 -- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
kono
parents:
diff changeset
19 -- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
kono
parents:
diff changeset
20 -- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
kono
parents:
diff changeset
21 -- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
kono
parents:
diff changeset
22 -- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
kono
parents:
diff changeset
23 -- PARTICULAR PURPOSE OF SAID MATERIAL.
kono
parents:
diff changeset
24 --*
kono
parents:
diff changeset
25 -- OBJECTIVE:
kono
parents:
diff changeset
26 -- CHECK THAT THE NAME IN AN INDEXED_COMPONENT MAY BE:
kono
parents:
diff changeset
27 -- AN IDENTIFIER DENOTING AN ARRAY OBJECT - N1;
kono
parents:
diff changeset
28 -- AN IDENTIFIER DENOTING AN ACCESS OBJECT WHOSE VALUE
kono
parents:
diff changeset
29 -- DESIGNATES AN ARRAY OBJECT - N2;
kono
parents:
diff changeset
30 -- A FUNCTION CALL DELIVERING AN ARRAY OBJECT USING
kono
parents:
diff changeset
31 -- PREDEFINED FUNCTIONS - &, AND THE LOGICAL OPERATORS
kono
parents:
diff changeset
32 -- A USER-DEFINED FUNCTION - F1;
kono
parents:
diff changeset
33 -- A FUNCTION CALL DELIVERING AN ACCESS VALUE THAT
kono
parents:
diff changeset
34 -- DESIGNATES AN ARRAY - F2;
kono
parents:
diff changeset
35 -- A SLICE (CHECKING UPPER AND LOWER BOUND COMPONENTS) - N3;
kono
parents:
diff changeset
36 -- AN INDEXED COMPONENT DENOTING AN ARRAY OBJECT
kono
parents:
diff changeset
37 -- (ARRAY OF ARRAYS) - N4;
kono
parents:
diff changeset
38 -- AN IDENTIFIER PREFIXED BY THE NAME OF THE INNERMOST UNIT
kono
parents:
diff changeset
39 -- ENCLOSING ITS DECLARATION - C41103B.N1;
kono
parents:
diff changeset
40 -- A RECORD COMPONENT (OF A RECORD CONTAINING ONE OR MORE
kono
parents:
diff changeset
41 -- ARRAYS WHOSE BOUNDS DEPEND ON A DISCRIMINANT) - N5.
kono
parents:
diff changeset
42 -- CHECK THAT THE APPROPRIATE COMPONENT IS ACCESSED (FOR
kono
parents:
diff changeset
43 -- DYNAMIC INDICES).
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 -- HISTORY:
kono
parents:
diff changeset
46 -- WKB 08/05/81 CREATED ORIGINAL TEST.
kono
parents:
diff changeset
47 -- SPS 10/26/82
kono
parents:
diff changeset
48 -- BCB 08/02/88 MODIFIED HEADER FORMAT AND ADDED CALLS TO THE
kono
parents:
diff changeset
49 -- LOGICAL OPERATORS.
kono
parents:
diff changeset
50 -- BCB 04/16/90 MODIFIED SLICE TEST TO INCLUDE A READING OF THE
kono
parents:
diff changeset
51 -- COMPONENT DESIGNATED BY THE LOWER BOUND OF THE
kono
parents:
diff changeset
52 -- SLICE. ADDED TEST FOR PREFIX OF INDEXED COMPONENT
kono
parents:
diff changeset
53 -- HAVING A LIMITED TYPE.
kono
parents:
diff changeset
54 -- PWN 11/30/94 SUBTYPE QUALIFIED LITERALS FOR ADA 9X.
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 WITH REPORT;
kono
parents:
diff changeset
57 USE REPORT;
kono
parents:
diff changeset
58 PROCEDURE C41103B IS
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 TYPE A1 IS ARRAY (INTEGER RANGE 1..4) OF INTEGER;
kono
parents:
diff changeset
61 N1 : A1 := (1,2,3,4);
kono
parents:
diff changeset
62
kono
parents:
diff changeset
63 BEGIN
kono
parents:
diff changeset
64 TEST ("C41103B", "CHECK THAT AN INDEXED_COMPONENT MAY BE OF " &
kono
parents:
diff changeset
65 "CERTAIN FORMS AND THAT THE APPROPRIATE " &
kono
parents:
diff changeset
66 "COMPONENT IS ACCESSED (FOR DYNAMIC INDICES)");
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 DECLARE
kono
parents:
diff changeset
69
kono
parents:
diff changeset
70 TYPE A2 IS ARRAY (INTEGER RANGE 1..4) OF BOOLEAN;
kono
parents:
diff changeset
71 TYPE A3 IS ACCESS A1;
kono
parents:
diff changeset
72 TYPE A4 IS ARRAY (INTEGER RANGE 1..4) OF A1;
kono
parents:
diff changeset
73 TYPE R (LENGTH : INTEGER) IS
kono
parents:
diff changeset
74 RECORD
kono
parents:
diff changeset
75 S : STRING (1..LENGTH);
kono
parents:
diff changeset
76 END RECORD;
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78 N2 : A3 := NEW A1' (1,2,3,4);
kono
parents:
diff changeset
79 N3 : ARRAY (1..7) OF INTEGER := (1,2,3,4,5,6,7);
kono
parents:
diff changeset
80 N4 : A4 := (1 => (1,2,3,4), 2 => (5,6,7,8),
kono
parents:
diff changeset
81 3 => (9,10,11,12), 4 => (13,14,15,16));
kono
parents:
diff changeset
82 N5 : R(4) := (LENGTH => 4, S => "ABCD");
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 M2A : A2 := (TRUE,FALSE,TRUE,FALSE);
kono
parents:
diff changeset
85 M2B : A2 := (TRUE,TRUE,FALSE,FALSE);
kono
parents:
diff changeset
86
kono
parents:
diff changeset
87 FUNCTION F1 RETURN A2 IS
kono
parents:
diff changeset
88 BEGIN
kono
parents:
diff changeset
89 RETURN (FALSE,FALSE,TRUE,FALSE);
kono
parents:
diff changeset
90 END F1;
kono
parents:
diff changeset
91
kono
parents:
diff changeset
92 FUNCTION F2 RETURN A3 IS
kono
parents:
diff changeset
93 BEGIN
kono
parents:
diff changeset
94 RETURN N2;
kono
parents:
diff changeset
95 END F2;
kono
parents:
diff changeset
96
kono
parents:
diff changeset
97 PROCEDURE P1 (X : IN INTEGER; Y : IN OUT INTEGER;
kono
parents:
diff changeset
98 Z : OUT INTEGER; W : IN STRING) IS
kono
parents:
diff changeset
99 BEGIN
kono
parents:
diff changeset
100 IF X /= 2 THEN
kono
parents:
diff changeset
101 FAILED ("WRONG VALUE FOR IN PARAMETER - " & W);
kono
parents:
diff changeset
102 END IF;
kono
parents:
diff changeset
103 IF Y /= 3 THEN
kono
parents:
diff changeset
104 FAILED ("WRONG VALUE FOR IN OUT PARAMETER - " & W);
kono
parents:
diff changeset
105 END IF;
kono
parents:
diff changeset
106 Y := 8;
kono
parents:
diff changeset
107 Z := 9;
kono
parents:
diff changeset
108 END P1;
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 PROCEDURE P2 (X : CHARACTER) IS
kono
parents:
diff changeset
111 BEGIN
kono
parents:
diff changeset
112 IF X /= 'C' THEN
kono
parents:
diff changeset
113 FAILED ("WRONG VALUE FOR IN PARAMETER - '&'");
kono
parents:
diff changeset
114 END IF;
kono
parents:
diff changeset
115 END P2;
kono
parents:
diff changeset
116
kono
parents:
diff changeset
117 PROCEDURE P3 (X : BOOLEAN) IS
kono
parents:
diff changeset
118 BEGIN
kono
parents:
diff changeset
119 IF X /= TRUE THEN
kono
parents:
diff changeset
120 FAILED ("WRONG VALUE FOR IN PARAMETER - F1");
kono
parents:
diff changeset
121 END IF;
kono
parents:
diff changeset
122 END P3;
kono
parents:
diff changeset
123
kono
parents:
diff changeset
124 PROCEDURE P5 (X : IN CHARACTER; Y : IN OUT CHARACTER;
kono
parents:
diff changeset
125 Z : OUT CHARACTER) IS
kono
parents:
diff changeset
126 BEGIN
kono
parents:
diff changeset
127 IF X /= 'A' THEN
kono
parents:
diff changeset
128 FAILED ("WRONG VALUE FOR IN PARAMETER - N5");
kono
parents:
diff changeset
129 END IF;
kono
parents:
diff changeset
130 IF Y /= 'D' THEN
kono
parents:
diff changeset
131 FAILED ("WRONG VALUE FOR IN OUT PARAMETER - N5");
kono
parents:
diff changeset
132 END IF;
kono
parents:
diff changeset
133 Y := 'Y';
kono
parents:
diff changeset
134 Z := 'Z';
kono
parents:
diff changeset
135 END P5;
kono
parents:
diff changeset
136
kono
parents:
diff changeset
137 PROCEDURE P6 (X : BOOLEAN) IS
kono
parents:
diff changeset
138 BEGIN
kono
parents:
diff changeset
139 IF X /= TRUE THEN
kono
parents:
diff changeset
140 FAILED ("WRONG VALUE FOR IN PARAMETER - NOT");
kono
parents:
diff changeset
141 END IF;
kono
parents:
diff changeset
142 END P6;
kono
parents:
diff changeset
143
kono
parents:
diff changeset
144 PROCEDURE P7 (X : BOOLEAN) IS
kono
parents:
diff changeset
145 BEGIN
kono
parents:
diff changeset
146 IF X /= TRUE THEN
kono
parents:
diff changeset
147 FAILED ("WRONG VALUE FOR IN PARAMETER - AND");
kono
parents:
diff changeset
148 END IF;
kono
parents:
diff changeset
149 END P7;
kono
parents:
diff changeset
150
kono
parents:
diff changeset
151 PROCEDURE P8 (X : BOOLEAN) IS
kono
parents:
diff changeset
152 BEGIN
kono
parents:
diff changeset
153 IF X /= TRUE THEN
kono
parents:
diff changeset
154 FAILED ("WRONG VALUE FOR IN PARAMETER - OR");
kono
parents:
diff changeset
155 END IF;
kono
parents:
diff changeset
156 END P8;
kono
parents:
diff changeset
157
kono
parents:
diff changeset
158 PROCEDURE P9 (X : BOOLEAN) IS
kono
parents:
diff changeset
159 BEGIN
kono
parents:
diff changeset
160 IF X /= TRUE THEN
kono
parents:
diff changeset
161 FAILED ("WRONG VALUE FOR IN PARAMETER - XOR");
kono
parents:
diff changeset
162 END IF;
kono
parents:
diff changeset
163 END P9;
kono
parents:
diff changeset
164
kono
parents:
diff changeset
165 BEGIN
kono
parents:
diff changeset
166
kono
parents:
diff changeset
167 IF N1(IDENT_INT(2)) /= 2 THEN
kono
parents:
diff changeset
168 FAILED ("WRONG VALUE FOR EXPRESSION - N1");
kono
parents:
diff changeset
169 END IF;
kono
parents:
diff changeset
170 N1(IDENT_INT(2)) := 7;
kono
parents:
diff changeset
171 IF N1 /= (1,7,3,4) THEN
kono
parents:
diff changeset
172 FAILED ("WRONG TARGET FOR ASSIGNMENT - N1");
kono
parents:
diff changeset
173 END IF;
kono
parents:
diff changeset
174 N1 := (1,2,3,4);
kono
parents:
diff changeset
175 P1 (N1(IDENT_INT(2)), N1(IDENT_INT(3)),
kono
parents:
diff changeset
176 N1(IDENT_INT(1)), "N1");
kono
parents:
diff changeset
177 IF N1 /= (9,2,8,4) THEN
kono
parents:
diff changeset
178 FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - N1");
kono
parents:
diff changeset
179 END IF;
kono
parents:
diff changeset
180
kono
parents:
diff changeset
181 IF N2(IDENT_INT(3)) /= 3 THEN
kono
parents:
diff changeset
182 FAILED ("WRONG VALUE FOR EXPRESSION - N2");
kono
parents:
diff changeset
183 END IF;
kono
parents:
diff changeset
184 N2(IDENT_INT(3)) := 7;
kono
parents:
diff changeset
185 IF N2.ALL /= (1,2,7,4) THEN
kono
parents:
diff changeset
186 FAILED ("WRONG TARGET FOR ASSIGNMENT - N2");
kono
parents:
diff changeset
187 END IF;
kono
parents:
diff changeset
188 N2.ALL := (2,1,4,3);
kono
parents:
diff changeset
189 P1 (N2(IDENT_INT(1)), N2(IDENT_INT(4)),
kono
parents:
diff changeset
190 N2(IDENT_INT(2)), "N2");
kono
parents:
diff changeset
191 IF N2.ALL /= (2,9,4,8) THEN
kono
parents:
diff changeset
192 FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - N2");
kono
parents:
diff changeset
193 END IF;
kono
parents:
diff changeset
194
kono
parents:
diff changeset
195 IF "&" (STRING'("AB"), STRING'("CDEF"))(IDENT_INT(5))
kono
parents:
diff changeset
196 /= CHARACTER'('E') THEN
kono
parents:
diff changeset
197 FAILED ("WRONG VALUE FOR EXPRESSION - '&'");
kono
parents:
diff changeset
198 END IF;
kono
parents:
diff changeset
199 P2 ("&" ("AB", "CD")(IDENT_INT(3)));
kono
parents:
diff changeset
200
kono
parents:
diff changeset
201 IF "NOT" (M2A)(IDENT_INT(4)) /= TRUE THEN
kono
parents:
diff changeset
202 FAILED ("WRONG VALUE FOR EXPRESSION - 'NOT'");
kono
parents:
diff changeset
203 END IF;
kono
parents:
diff changeset
204 P6 ("NOT" (M2A)(IDENT_INT(4)));
kono
parents:
diff changeset
205
kono
parents:
diff changeset
206 IF "AND" (M2A,M2B)(IDENT_INT(3)) /= FALSE THEN
kono
parents:
diff changeset
207 FAILED ("WRONG VALUE FOR EXPRESSION - 'AND'");
kono
parents:
diff changeset
208 END IF;
kono
parents:
diff changeset
209 P7 ("AND" (M2A,M2B)(IDENT_INT(1)));
kono
parents:
diff changeset
210
kono
parents:
diff changeset
211 IF "OR" (M2A,M2B)(IDENT_INT(3)) /= TRUE THEN
kono
parents:
diff changeset
212 FAILED ("WRONG VALUE FOR EXPRESSION - 'OR'");
kono
parents:
diff changeset
213 END IF;
kono
parents:
diff changeset
214 P8 ("OR" (M2A,M2B)(IDENT_INT(3)));
kono
parents:
diff changeset
215
kono
parents:
diff changeset
216 IF "XOR" (M2A,M2B)(IDENT_INT(1)) /= FALSE THEN
kono
parents:
diff changeset
217 FAILED ("WRONG VALUE FOR EXPRESSION - 'XOR'");
kono
parents:
diff changeset
218 END IF;
kono
parents:
diff changeset
219 P9 ("XOR" (M2A,M2B)(IDENT_INT(3)));
kono
parents:
diff changeset
220
kono
parents:
diff changeset
221 IF F1(IDENT_INT(3)) /= TRUE THEN
kono
parents:
diff changeset
222 FAILED ("WRONG VALUE FOR EXPRESSION - F1");
kono
parents:
diff changeset
223 END IF;
kono
parents:
diff changeset
224 P3 (F1(IDENT_INT(3)));
kono
parents:
diff changeset
225
kono
parents:
diff changeset
226 N2 := NEW A1'(1,2,3,4);
kono
parents:
diff changeset
227 IF F2(IDENT_INT(2)) /= 2 THEN
kono
parents:
diff changeset
228 FAILED ("WRONG VALUE FOR EXPRESSION - F2");
kono
parents:
diff changeset
229 END IF;
kono
parents:
diff changeset
230 F2(IDENT_INT(3)) := 7;
kono
parents:
diff changeset
231 IF N2.ALL /= (1,2,7,4) THEN
kono
parents:
diff changeset
232 FAILED ("WRONG TARGET FOR ASSIGNMENT - F2");
kono
parents:
diff changeset
233 END IF;
kono
parents:
diff changeset
234 N2.ALL := (1,2,3,4);
kono
parents:
diff changeset
235 P1 (F2(IDENT_INT(2)), F2(IDENT_INT(3)),
kono
parents:
diff changeset
236 F2(IDENT_INT(1)), "F2");
kono
parents:
diff changeset
237 IF N2.ALL /= (9,2,8,4) THEN
kono
parents:
diff changeset
238 FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - F2");
kono
parents:
diff changeset
239 END IF;
kono
parents:
diff changeset
240
kono
parents:
diff changeset
241 IF N3(2..5)(IDENT_INT(2)) /= 2 THEN
kono
parents:
diff changeset
242 FAILED ("WRONG VALUE FOR EXPRESSION (LOWER BOUND) - N3");
kono
parents:
diff changeset
243 END IF;
kono
parents:
diff changeset
244 IF N3(2..5)(IDENT_INT(5)) /= 5 THEN
kono
parents:
diff changeset
245 FAILED ("WRONG VALUE FOR EXPRESSION (UPPER BOUND) - N3");
kono
parents:
diff changeset
246 END IF;
kono
parents:
diff changeset
247 N3(2..5)(IDENT_INT(2)) := 8;
kono
parents:
diff changeset
248 IF N3 /= (1,8,3,4,5,6,7) THEN
kono
parents:
diff changeset
249 FAILED ("WRONG TARGET FOR ASSIGNMENT - N3");
kono
parents:
diff changeset
250 END IF;
kono
parents:
diff changeset
251 N3 := (5,3,4,2,1,6,7);
kono
parents:
diff changeset
252 P1 (N3(2..5)(IDENT_INT(4)), N3(2..5)(IDENT_INT(2)),
kono
parents:
diff changeset
253 N3(2..5)(IDENT_INT(5)), "N3");
kono
parents:
diff changeset
254 IF N3 /= (5,8,4,2,9,6,7) THEN
kono
parents:
diff changeset
255 FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - N3");
kono
parents:
diff changeset
256 END IF;
kono
parents:
diff changeset
257
kono
parents:
diff changeset
258 IF N4(1)(IDENT_INT(2)) /= 2 THEN
kono
parents:
diff changeset
259 FAILED ("WRONG VALUE FOR EXPRESSION - N4");
kono
parents:
diff changeset
260 END IF;
kono
parents:
diff changeset
261 N4(3)(IDENT_INT(1)) := 20;
kono
parents:
diff changeset
262 IF N4 /= ((1,2,3,4),(5,6,7,8),(20,10,11,12),
kono
parents:
diff changeset
263 (13,14,15,16)) THEN
kono
parents:
diff changeset
264 FAILED ("WRONG TARGET FOR ASSIGNMENT - N4");
kono
parents:
diff changeset
265 END IF;
kono
parents:
diff changeset
266 N4 := (1 => (0,6,4,2), 2 => (10,11,12,13),
kono
parents:
diff changeset
267 3 => (14,15,16,17), 4 => (7,5,3,1));
kono
parents:
diff changeset
268 P1 (N4(1)(IDENT_INT(4)), N4(4)(IDENT_INT(3)),
kono
parents:
diff changeset
269 N4(2)(IDENT_INT(1)), "N4");
kono
parents:
diff changeset
270 IF N4 /= ((0,6,4,2),(9,11,12,13),(14,15,16,17),
kono
parents:
diff changeset
271 (7,5,8,1)) THEN
kono
parents:
diff changeset
272 FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - N4");
kono
parents:
diff changeset
273 END IF;
kono
parents:
diff changeset
274
kono
parents:
diff changeset
275 N1 := (1,2,3,4);
kono
parents:
diff changeset
276 IF C41103B.N1(IDENT_INT(2)) /= 2 THEN
kono
parents:
diff changeset
277 FAILED ("WRONG VALUE FOR EXPRESSION - C41103B.N1");
kono
parents:
diff changeset
278 END IF;
kono
parents:
diff changeset
279 C41103B.N1(IDENT_INT(2)) := 7;
kono
parents:
diff changeset
280 IF N1 /= (1,7,3,4) THEN
kono
parents:
diff changeset
281 FAILED ("WRONG TARGET FOR ASSIGNMENT - C41103B.N1");
kono
parents:
diff changeset
282 END IF;
kono
parents:
diff changeset
283 N1 := (1,2,3,4);
kono
parents:
diff changeset
284 P1 (C41103B.N1(IDENT_INT(2)), C41103B.N1(IDENT_INT(3)),
kono
parents:
diff changeset
285 C41103B.N1(IDENT_INT(1)), "C41103B.N1");
kono
parents:
diff changeset
286 IF N1 /= (9,2,8,4) THEN
kono
parents:
diff changeset
287 FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER " &
kono
parents:
diff changeset
288 "- C41103B.N1");
kono
parents:
diff changeset
289 END IF;
kono
parents:
diff changeset
290
kono
parents:
diff changeset
291 IF N5.S(IDENT_INT(3)) /= 'C' THEN
kono
parents:
diff changeset
292 FAILED ("WRONG VALUE FOR EXPRESSION - N5");
kono
parents:
diff changeset
293 END IF;
kono
parents:
diff changeset
294 N5.S(IDENT_INT(4)) := 'X';
kono
parents:
diff changeset
295 IF N5.S /= "ABCX" THEN
kono
parents:
diff changeset
296 FAILED ("WRONG TARGET FOR ASSIGNMENT - N5");
kono
parents:
diff changeset
297 END IF;
kono
parents:
diff changeset
298 N5.S := "ABCD";
kono
parents:
diff changeset
299 P5 (N5.S(IDENT_INT(1)), N5.S(IDENT_INT(4)),
kono
parents:
diff changeset
300 N5.S(IDENT_INT(2)));
kono
parents:
diff changeset
301 IF N5.S /= "AZCY" THEN
kono
parents:
diff changeset
302 FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - N5");
kono
parents:
diff changeset
303 END IF;
kono
parents:
diff changeset
304
kono
parents:
diff changeset
305 DECLARE
kono
parents:
diff changeset
306 PACKAGE P IS
kono
parents:
diff changeset
307 TYPE LIM IS LIMITED PRIVATE;
kono
parents:
diff changeset
308 PROCEDURE INIT (V : OUT LIM; X,Y,Z : INTEGER);
kono
parents:
diff changeset
309 PROCEDURE ASSIGN (ONE : OUT LIM; TWO : LIM);
kono
parents:
diff changeset
310 FUNCTION "=" (ONE,TWO : LIM) RETURN BOOLEAN;
kono
parents:
diff changeset
311 PRIVATE
kono
parents:
diff changeset
312 TYPE LIM IS ARRAY(1..3) OF INTEGER;
kono
parents:
diff changeset
313 END P;
kono
parents:
diff changeset
314
kono
parents:
diff changeset
315 USE P;
kono
parents:
diff changeset
316
kono
parents:
diff changeset
317 TYPE A IS ARRAY(1..3) OF LIM;
kono
parents:
diff changeset
318
kono
parents:
diff changeset
319 H : A;
kono
parents:
diff changeset
320
kono
parents:
diff changeset
321 N6 : LIM;
kono
parents:
diff changeset
322
kono
parents:
diff changeset
323 PACKAGE BODY P IS
kono
parents:
diff changeset
324 PROCEDURE INIT (V : OUT LIM; X,Y,Z : INTEGER) IS
kono
parents:
diff changeset
325 BEGIN
kono
parents:
diff changeset
326 V := (X,Y,Z);
kono
parents:
diff changeset
327 END INIT;
kono
parents:
diff changeset
328
kono
parents:
diff changeset
329 PROCEDURE ASSIGN (ONE : OUT LIM; TWO : LIM) IS
kono
parents:
diff changeset
330 BEGIN
kono
parents:
diff changeset
331 ONE := TWO;
kono
parents:
diff changeset
332 END ASSIGN;
kono
parents:
diff changeset
333
kono
parents:
diff changeset
334 FUNCTION "=" (ONE,TWO : LIM) RETURN BOOLEAN IS
kono
parents:
diff changeset
335 BEGIN
kono
parents:
diff changeset
336 IF ONE(1) = TWO(1) AND ONE(2) = TWO(2) AND
kono
parents:
diff changeset
337 ONE(3) = TWO(3) THEN
kono
parents:
diff changeset
338 RETURN TRUE;
kono
parents:
diff changeset
339 ELSE
kono
parents:
diff changeset
340 RETURN FALSE;
kono
parents:
diff changeset
341 END IF;
kono
parents:
diff changeset
342 END "=";
kono
parents:
diff changeset
343 END P;
kono
parents:
diff changeset
344
kono
parents:
diff changeset
345 FUNCTION FR RETURN A IS
kono
parents:
diff changeset
346 BEGIN
kono
parents:
diff changeset
347 RETURN H;
kono
parents:
diff changeset
348 END FR;
kono
parents:
diff changeset
349
kono
parents:
diff changeset
350 BEGIN
kono
parents:
diff changeset
351 INIT (H(1),1,2,3);
kono
parents:
diff changeset
352 INIT (H(2),4,5,6);
kono
parents:
diff changeset
353 INIT (H(3),7,8,9);
kono
parents:
diff changeset
354 INIT (N6,0,0,0);
kono
parents:
diff changeset
355
kono
parents:
diff changeset
356 ASSIGN (N6,FR(2));
kono
parents:
diff changeset
357
kono
parents:
diff changeset
358 IF N6 /= FR(2) THEN
kono
parents:
diff changeset
359 FAILED ("WRONG VALUE FROM LIMITED COMPONENT TYPE");
kono
parents:
diff changeset
360 END IF;
kono
parents:
diff changeset
361
kono
parents:
diff changeset
362 END;
kono
parents:
diff changeset
363 END;
kono
parents:
diff changeset
364
kono
parents:
diff changeset
365 RESULT;
kono
parents:
diff changeset
366 END C41103B;