annotate gcc/testsuite/ada/acats/tests/c7/c74004a.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 -- C74004A.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 OPERATIONS DEPENDING ON THE FULL DECLARATION OF A
kono
parents:
diff changeset
27 -- PRIVATE TYPE ARE AVAILABLE WITHIN THE PACKAGE BODY.
kono
parents:
diff changeset
28
kono
parents:
diff changeset
29 -- HISTORY:
kono
parents:
diff changeset
30 -- BCB 04/05/88 CREATED ORIGINAL TEST.
kono
parents:
diff changeset
31 -- PWN 01/31/95 REMOVED INCONSISTENCIES WITH ADA 9X.
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 WITH REPORT; USE REPORT;
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 PROCEDURE C74004A IS
kono
parents:
diff changeset
36
kono
parents:
diff changeset
37 PACKAGE P IS
kono
parents:
diff changeset
38 TYPE PR IS PRIVATE;
kono
parents:
diff changeset
39 TYPE ARR1 IS LIMITED PRIVATE;
kono
parents:
diff changeset
40 TYPE ARR2 IS PRIVATE;
kono
parents:
diff changeset
41 TYPE REC (D : INTEGER) IS PRIVATE;
kono
parents:
diff changeset
42 TYPE ACC IS PRIVATE;
kono
parents:
diff changeset
43 TYPE TSK IS LIMITED PRIVATE;
kono
parents:
diff changeset
44 TYPE FLT IS LIMITED PRIVATE;
kono
parents:
diff changeset
45 TYPE FIX IS LIMITED PRIVATE;
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 TASK TYPE T IS
kono
parents:
diff changeset
48 ENTRY ONE(V : IN OUT INTEGER);
kono
parents:
diff changeset
49 END T;
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 PROCEDURE CHECK (V : ARR2);
kono
parents:
diff changeset
52 PRIVATE
kono
parents:
diff changeset
53 TYPE PR IS NEW INTEGER;
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 TYPE ARR1 IS ARRAY(1..5) OF INTEGER;
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 TYPE ARR2 IS ARRAY(1..5) OF BOOLEAN;
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 TYPE REC (D : INTEGER) IS RECORD
kono
parents:
diff changeset
60 COMP1 : INTEGER;
kono
parents:
diff changeset
61 COMP2 : BOOLEAN;
kono
parents:
diff changeset
62 END RECORD;
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 TYPE ACC IS ACCESS INTEGER;
kono
parents:
diff changeset
65
kono
parents:
diff changeset
66 TYPE TSK IS NEW T;
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 TYPE FLT IS DIGITS 5;
kono
parents:
diff changeset
69
kono
parents:
diff changeset
70 TYPE FIX IS DELTA 2.0**(-1) RANGE -100.0 .. 100.0;
kono
parents:
diff changeset
71 END P;
kono
parents:
diff changeset
72
kono
parents:
diff changeset
73 PACKAGE BODY P IS
kono
parents:
diff changeset
74 X1, X2, X3 : PR;
kono
parents:
diff changeset
75 BOOL : BOOLEAN := IDENT_BOOL(FALSE);
kono
parents:
diff changeset
76 VAL : INTEGER := IDENT_INT(0);
kono
parents:
diff changeset
77 FVAL : FLOAT := 0.0;
kono
parents:
diff changeset
78 ST : STRING(1..2);
kono
parents:
diff changeset
79 O1 : ARR1 := (1,2,3,4,5);
kono
parents:
diff changeset
80 Y1 : ARR2 := (FALSE,TRUE,FALSE,TRUE,FALSE);
kono
parents:
diff changeset
81 Y2 : ARR2 := (OTHERS => TRUE);
kono
parents:
diff changeset
82 Y3 : ARR2 := (OTHERS => FALSE);
kono
parents:
diff changeset
83 Z1 : REC(0) := (0,1,FALSE);
kono
parents:
diff changeset
84 W1, W2 : ACC := NEW INTEGER'(0);
kono
parents:
diff changeset
85 V1 : TSK;
kono
parents:
diff changeset
86
kono
parents:
diff changeset
87 TASK BODY T IS
kono
parents:
diff changeset
88 BEGIN
kono
parents:
diff changeset
89 ACCEPT ONE(V : IN OUT INTEGER) DO
kono
parents:
diff changeset
90 V := IDENT_INT(10);
kono
parents:
diff changeset
91 END ONE;
kono
parents:
diff changeset
92 END T;
kono
parents:
diff changeset
93
kono
parents:
diff changeset
94 PROCEDURE CHECK (V : ARR2) IS
kono
parents:
diff changeset
95 BEGIN
kono
parents:
diff changeset
96 IF V /= (TRUE,FALSE,TRUE,FALSE,TRUE) THEN
kono
parents:
diff changeset
97 FAILED ("IMPROPER VALUE PASSED AS AGGREGATE");
kono
parents:
diff changeset
98 END IF;
kono
parents:
diff changeset
99 END CHECK;
kono
parents:
diff changeset
100 BEGIN
kono
parents:
diff changeset
101 TEST ("C74004A", "CHECK THAT OPERATIONS DEPENDING ON THE " &
kono
parents:
diff changeset
102 "FULL DECLARATION OF A PRIVATE TYPE ARE " &
kono
parents:
diff changeset
103 "AVAILABLE WITHIN THE PACKAGE BODY");
kono
parents:
diff changeset
104
kono
parents:
diff changeset
105 X1 := 10;
kono
parents:
diff changeset
106 X2 := 5;
kono
parents:
diff changeset
107
kono
parents:
diff changeset
108 X3 := X1 + X2;
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 IF X3 /= 15 THEN
kono
parents:
diff changeset
111 FAILED ("IMPROPER RESULT FROM ADDITION OPERATOR");
kono
parents:
diff changeset
112 END IF;
kono
parents:
diff changeset
113
kono
parents:
diff changeset
114 X3 := X1 - X2;
kono
parents:
diff changeset
115
kono
parents:
diff changeset
116 IF X3 /= 5 THEN
kono
parents:
diff changeset
117 FAILED ("IMPROPER RESULT FROM SUBTRACTION OPERATOR");
kono
parents:
diff changeset
118 END IF;
kono
parents:
diff changeset
119
kono
parents:
diff changeset
120 X3 := X1 * X2;
kono
parents:
diff changeset
121
kono
parents:
diff changeset
122 IF X3 /= 50 THEN
kono
parents:
diff changeset
123 FAILED ("IMPROPER RESULT FROM MULTIPLICATION OPERATOR");
kono
parents:
diff changeset
124 END IF;
kono
parents:
diff changeset
125
kono
parents:
diff changeset
126 X3 := X1 / X2;
kono
parents:
diff changeset
127
kono
parents:
diff changeset
128 IF X3 /= 2 THEN
kono
parents:
diff changeset
129 FAILED ("IMPROPER RESULT FROM DIVISION OPERATOR");
kono
parents:
diff changeset
130 END IF;
kono
parents:
diff changeset
131
kono
parents:
diff changeset
132 X3 := X1 ** 2;
kono
parents:
diff changeset
133
kono
parents:
diff changeset
134 IF X3 /= 100 THEN
kono
parents:
diff changeset
135 FAILED ("IMPROPER RESULT FROM EXPONENTIATION OPERATOR");
kono
parents:
diff changeset
136 END IF;
kono
parents:
diff changeset
137
kono
parents:
diff changeset
138 BOOL := X1 < X2;
kono
parents:
diff changeset
139
kono
parents:
diff changeset
140 IF BOOL THEN
kono
parents:
diff changeset
141 FAILED ("IMPROPER RESULT FROM LESS THAN OPERATOR");
kono
parents:
diff changeset
142 END IF;
kono
parents:
diff changeset
143
kono
parents:
diff changeset
144 BOOL := X1 > X2;
kono
parents:
diff changeset
145
kono
parents:
diff changeset
146 IF NOT BOOL THEN
kono
parents:
diff changeset
147 FAILED ("IMPROPER RESULT FROM GREATER THAN OPERATOR");
kono
parents:
diff changeset
148 END IF;
kono
parents:
diff changeset
149
kono
parents:
diff changeset
150 BOOL := X1 <= X2;
kono
parents:
diff changeset
151
kono
parents:
diff changeset
152 IF BOOL THEN
kono
parents:
diff changeset
153 FAILED ("IMPROPER RESULT FROM LESS THAN OR EQUAL TO " &
kono
parents:
diff changeset
154 "OPERATOR");
kono
parents:
diff changeset
155 END IF;
kono
parents:
diff changeset
156
kono
parents:
diff changeset
157 BOOL := X1 >= X2;
kono
parents:
diff changeset
158
kono
parents:
diff changeset
159 IF NOT BOOL THEN
kono
parents:
diff changeset
160 FAILED ("IMPROPER RESULT FROM GREATER THAN OR EQUAL " &
kono
parents:
diff changeset
161 "TO OPERATOR");
kono
parents:
diff changeset
162 END IF;
kono
parents:
diff changeset
163
kono
parents:
diff changeset
164 X3 := X1 MOD X2;
kono
parents:
diff changeset
165
kono
parents:
diff changeset
166 IF X3 /= 0 THEN
kono
parents:
diff changeset
167 FAILED ("IMPROPER RESULT FROM MOD OPERATOR");
kono
parents:
diff changeset
168 END IF;
kono
parents:
diff changeset
169
kono
parents:
diff changeset
170 X3 := X1 REM X2;
kono
parents:
diff changeset
171
kono
parents:
diff changeset
172 IF X3 /= 0 THEN
kono
parents:
diff changeset
173 FAILED ("IMPROPER RESULT FROM REM OPERATOR");
kono
parents:
diff changeset
174 END IF;
kono
parents:
diff changeset
175
kono
parents:
diff changeset
176 X3 := ABS(X1);
kono
parents:
diff changeset
177
kono
parents:
diff changeset
178 IF X3 /= 10 THEN
kono
parents:
diff changeset
179 FAILED ("IMPROPER RESULT FROM ABS OPERATOR - 1");
kono
parents:
diff changeset
180 END IF;
kono
parents:
diff changeset
181
kono
parents:
diff changeset
182 X1 := -10;
kono
parents:
diff changeset
183
kono
parents:
diff changeset
184 X3 := ABS(X1);
kono
parents:
diff changeset
185
kono
parents:
diff changeset
186 IF X3 /= 10 THEN
kono
parents:
diff changeset
187 FAILED ("IMPROPER RESULT FROM ABS OPERATOR - 2");
kono
parents:
diff changeset
188 END IF;
kono
parents:
diff changeset
189
kono
parents:
diff changeset
190 X3 := PR'BASE'FIRST;
kono
parents:
diff changeset
191
kono
parents:
diff changeset
192 IF X3 /= PR(INTEGER'FIRST) THEN
kono
parents:
diff changeset
193 FAILED ("IMPROPER RESULT FROM 'BASE'FIRST");
kono
parents:
diff changeset
194 END IF;
kono
parents:
diff changeset
195
kono
parents:
diff changeset
196 X3 := PR'FIRST;
kono
parents:
diff changeset
197
kono
parents:
diff changeset
198 IF X3 /= PR(INTEGER'FIRST) THEN
kono
parents:
diff changeset
199 FAILED ("IMPROPER RESULT FROM 'FIRST");
kono
parents:
diff changeset
200 END IF;
kono
parents:
diff changeset
201
kono
parents:
diff changeset
202 VAL := PR'WIDTH;
kono
parents:
diff changeset
203
kono
parents:
diff changeset
204 IF NOT EQUAL(VAL,INTEGER'WIDTH) THEN
kono
parents:
diff changeset
205 FAILED ("IMPROPER RESULT FROM 'WIDTH");
kono
parents:
diff changeset
206 END IF;
kono
parents:
diff changeset
207
kono
parents:
diff changeset
208 VAL := PR'POS(X3);
kono
parents:
diff changeset
209
kono
parents:
diff changeset
210 IF NOT EQUAL(VAL,INTEGER'FIRST) THEN
kono
parents:
diff changeset
211 FAILED ("IMPROPER RESULT FROM 'POS");
kono
parents:
diff changeset
212 END IF;
kono
parents:
diff changeset
213
kono
parents:
diff changeset
214 X3 := PR'VAL(VAL);
kono
parents:
diff changeset
215
kono
parents:
diff changeset
216 IF X3 /= PR(INTEGER'FIRST) THEN
kono
parents:
diff changeset
217 FAILED ("IMPROPER RESULT FROM 'VAL");
kono
parents:
diff changeset
218 END IF;
kono
parents:
diff changeset
219
kono
parents:
diff changeset
220 X3 := PR'SUCC(X2);
kono
parents:
diff changeset
221
kono
parents:
diff changeset
222 IF X3 /= 6 THEN
kono
parents:
diff changeset
223 FAILED ("IMPROPER RESULT FROM 'SUCC");
kono
parents:
diff changeset
224 END IF;
kono
parents:
diff changeset
225
kono
parents:
diff changeset
226 X3 := PR'PRED(X2);
kono
parents:
diff changeset
227
kono
parents:
diff changeset
228 IF X3 /= 4 THEN
kono
parents:
diff changeset
229 FAILED ("IMPROPER RESULT FROM 'PRED");
kono
parents:
diff changeset
230 END IF;
kono
parents:
diff changeset
231
kono
parents:
diff changeset
232 ST := PR'IMAGE(X3);
kono
parents:
diff changeset
233
kono
parents:
diff changeset
234 IF ST /= INTEGER'IMAGE(INTEGER(X3)) THEN
kono
parents:
diff changeset
235 FAILED ("IMPROPER RESULT FROM 'IMAGE");
kono
parents:
diff changeset
236 END IF;
kono
parents:
diff changeset
237
kono
parents:
diff changeset
238 X3 := PR'VALUE(ST);
kono
parents:
diff changeset
239
kono
parents:
diff changeset
240 IF X3 /= PR(INTEGER'VALUE(ST)) THEN
kono
parents:
diff changeset
241 FAILED ("IMPROPER RESULT FROM 'VALUE");
kono
parents:
diff changeset
242 END IF;
kono
parents:
diff changeset
243
kono
parents:
diff changeset
244 CHECK ((TRUE,FALSE,TRUE,FALSE,TRUE));
kono
parents:
diff changeset
245
kono
parents:
diff changeset
246 IF O1(2) /= IDENT_INT(2) THEN
kono
parents:
diff changeset
247 FAILED ("IMPROPER VALUE FROM INDEXING");
kono
parents:
diff changeset
248 END IF;
kono
parents:
diff changeset
249
kono
parents:
diff changeset
250 IF O1(2..4) /= (2,3,4) THEN
kono
parents:
diff changeset
251 FAILED ("IMPROPER VALUES FROM SLICING");
kono
parents:
diff changeset
252 END IF;
kono
parents:
diff changeset
253
kono
parents:
diff changeset
254 IF VAL IN O1'RANGE THEN
kono
parents:
diff changeset
255 FAILED ("IMPROPER RESULT FROM 'RANGE");
kono
parents:
diff changeset
256 END IF;
kono
parents:
diff changeset
257
kono
parents:
diff changeset
258 VAL := O1'LENGTH;
kono
parents:
diff changeset
259
kono
parents:
diff changeset
260 IF NOT EQUAL(VAL,5) THEN
kono
parents:
diff changeset
261 FAILED ("IMPROPER RESULT FROM 'LENGTH");
kono
parents:
diff changeset
262 END IF;
kono
parents:
diff changeset
263
kono
parents:
diff changeset
264 Y3 := Y1(1..2) & Y2(3..5);
kono
parents:
diff changeset
265
kono
parents:
diff changeset
266 IF Y3 /= (FALSE,TRUE,TRUE,TRUE,TRUE) THEN
kono
parents:
diff changeset
267 FAILED ("IMPROPER RESULT FROM CATENATION");
kono
parents:
diff changeset
268 END IF;
kono
parents:
diff changeset
269
kono
parents:
diff changeset
270 Y3 := NOT Y1;
kono
parents:
diff changeset
271
kono
parents:
diff changeset
272 IF Y3 /= (TRUE,FALSE,TRUE,FALSE,TRUE) THEN
kono
parents:
diff changeset
273 FAILED ("IMPROPER RESULT FROM NOT OPERATOR");
kono
parents:
diff changeset
274 END IF;
kono
parents:
diff changeset
275
kono
parents:
diff changeset
276 Y3 := Y1 AND Y2;
kono
parents:
diff changeset
277
kono
parents:
diff changeset
278 IF Y3 /= (FALSE,TRUE,FALSE,TRUE,FALSE) THEN
kono
parents:
diff changeset
279 FAILED ("IMPROPER RESULT FROM AND OPERATOR");
kono
parents:
diff changeset
280 END IF;
kono
parents:
diff changeset
281
kono
parents:
diff changeset
282 Y3 := Y1 OR Y2;
kono
parents:
diff changeset
283
kono
parents:
diff changeset
284 IF Y3 /= (TRUE,TRUE,TRUE,TRUE,TRUE) THEN
kono
parents:
diff changeset
285 FAILED ("IMPROPER RESULT FROM OR OPERATOR");
kono
parents:
diff changeset
286 END IF;
kono
parents:
diff changeset
287
kono
parents:
diff changeset
288 Y3 := Y1 XOR Y2;
kono
parents:
diff changeset
289
kono
parents:
diff changeset
290 IF Y3 /= (TRUE,FALSE,TRUE,FALSE,TRUE) THEN
kono
parents:
diff changeset
291 FAILED ("IMPROPER RESULT FROM XOR OPERATOR");
kono
parents:
diff changeset
292 END IF;
kono
parents:
diff changeset
293
kono
parents:
diff changeset
294 VAL := Z1.COMP1;
kono
parents:
diff changeset
295
kono
parents:
diff changeset
296 IF NOT EQUAL(VAL,1) THEN
kono
parents:
diff changeset
297 FAILED ("IMPROPER RESULT FROM SELECTION OF RECORD " &
kono
parents:
diff changeset
298 "COMPONENTS");
kono
parents:
diff changeset
299 END IF;
kono
parents:
diff changeset
300
kono
parents:
diff changeset
301 W1 := NEW INTEGER'(0);
kono
parents:
diff changeset
302
kono
parents:
diff changeset
303 IF NOT EQUAL(W1.ALL,0) THEN
kono
parents:
diff changeset
304 FAILED ("IMPROPER RESULT FROM ALLOCATION");
kono
parents:
diff changeset
305 END IF;
kono
parents:
diff changeset
306
kono
parents:
diff changeset
307 W1 := NULL;
kono
parents:
diff changeset
308
kono
parents:
diff changeset
309 IF W1 /= NULL THEN
kono
parents:
diff changeset
310 FAILED ("IMPROPER RESULT FROM NULL LITERAL");
kono
parents:
diff changeset
311 END IF;
kono
parents:
diff changeset
312
kono
parents:
diff changeset
313 VAL := W2.ALL;
kono
parents:
diff changeset
314
kono
parents:
diff changeset
315 IF NOT EQUAL(VAL,0) THEN
kono
parents:
diff changeset
316 FAILED ("IMPROPER RESULT FROM SELECTED COMPONENT");
kono
parents:
diff changeset
317 END IF;
kono
parents:
diff changeset
318
kono
parents:
diff changeset
319 BOOL := V1'CALLABLE;
kono
parents:
diff changeset
320
kono
parents:
diff changeset
321 IF NOT BOOL THEN
kono
parents:
diff changeset
322 FAILED ("IMPROPER RESULT FROM 'CALLABLE");
kono
parents:
diff changeset
323 END IF;
kono
parents:
diff changeset
324
kono
parents:
diff changeset
325 BOOL := V1'TERMINATED;
kono
parents:
diff changeset
326
kono
parents:
diff changeset
327 IF BOOL THEN
kono
parents:
diff changeset
328 FAILED ("IMPROPER RESULT FROM 'TERMINATED");
kono
parents:
diff changeset
329 END IF;
kono
parents:
diff changeset
330
kono
parents:
diff changeset
331 V1.ONE(VAL);
kono
parents:
diff changeset
332
kono
parents:
diff changeset
333 IF NOT EQUAL(VAL,10) THEN
kono
parents:
diff changeset
334 FAILED ("IMPROPER RESULT RETURNED FROM ENTRY SELECTION");
kono
parents:
diff changeset
335 END IF;
kono
parents:
diff changeset
336
kono
parents:
diff changeset
337 IF NOT (FLT(1.0) IN FLT) THEN
kono
parents:
diff changeset
338 FAILED ("IMPROPER RESULT FROM IMPLICIT CONVERSION");
kono
parents:
diff changeset
339 END IF;
kono
parents:
diff changeset
340
kono
parents:
diff changeset
341 VAL := FLT'DIGITS;
kono
parents:
diff changeset
342
kono
parents:
diff changeset
343 IF NOT EQUAL(VAL,5) THEN
kono
parents:
diff changeset
344 FAILED ("IMPROPER RESULT FROM 'DIGITS");
kono
parents:
diff changeset
345 END IF;
kono
parents:
diff changeset
346
kono
parents:
diff changeset
347 BOOL := FLT'MACHINE_ROUNDS;
kono
parents:
diff changeset
348
kono
parents:
diff changeset
349 BOOL := FLT'MACHINE_OVERFLOWS;
kono
parents:
diff changeset
350
kono
parents:
diff changeset
351 VAL := FLT'MACHINE_RADIX;
kono
parents:
diff changeset
352
kono
parents:
diff changeset
353 VAL := FLT'MACHINE_MANTISSA;
kono
parents:
diff changeset
354
kono
parents:
diff changeset
355 VAL := FLT'MACHINE_EMAX;
kono
parents:
diff changeset
356
kono
parents:
diff changeset
357 VAL := FLT'MACHINE_EMIN;
kono
parents:
diff changeset
358
kono
parents:
diff changeset
359 FVAL := FIX'DELTA;
kono
parents:
diff changeset
360
kono
parents:
diff changeset
361 IF FVAL /= 2.0**(-1) THEN
kono
parents:
diff changeset
362 FAILED ("IMPROPER RESULT FROM 'DELTA");
kono
parents:
diff changeset
363 END IF;
kono
parents:
diff changeset
364
kono
parents:
diff changeset
365 VAL := FIX'FORE;
kono
parents:
diff changeset
366
kono
parents:
diff changeset
367 VAL := FIX'AFT;
kono
parents:
diff changeset
368
kono
parents:
diff changeset
369 END P;
kono
parents:
diff changeset
370
kono
parents:
diff changeset
371 USE P;
kono
parents:
diff changeset
372
kono
parents:
diff changeset
373 BEGIN
kono
parents:
diff changeset
374 RESULT;
kono
parents:
diff changeset
375 END C74004A;