annotate gcc/testsuite/ada/acats/tests/c6/c64005d0.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 -- C64005D0M.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 -- CHECK THAT NESTED SUBPROGRAMS CAN BE CALLED RECURSIVELY AND THAT
kono
parents:
diff changeset
26 -- NON-LOCAL VARIABLES AND FORMAL PARAMETERS ARE PROPERLY ACCESSED FROM
kono
parents:
diff changeset
27 -- WITHIN RECURSIVE INVOCATIONS. THIS TEST CHECKS THAT EVERY DISPLAY OR
kono
parents:
diff changeset
28 -- STATIC CHAIN LEVEL CAN BE ACCESSED.
kono
parents:
diff changeset
29
kono
parents:
diff changeset
30 -- THIS TEST USES 3 LEVELS OF NESTED RECURSIVE PROCEDURES (SEPARATELY
kono
parents:
diff changeset
31 -- COMPILED AS SUBUNITS).
kono
parents:
diff changeset
32
kono
parents:
diff changeset
33 -- SEPARATE FILES ARE:
kono
parents:
diff changeset
34 -- C64005D0M THE MAIN PROCEDURE.
kono
parents:
diff changeset
35 -- C64005DA A RECURSIVE PROCEDURE SUBUNIT OF C64005D0M.
kono
parents:
diff changeset
36 -- C64005DB A RECURSIVE PROCEDURE SUBUNIT OF C64005DA.
kono
parents:
diff changeset
37 -- C64005DC A RECURSIVE PROCEDURE SUBUNIT OF C64005DB.
kono
parents:
diff changeset
38
kono
parents:
diff changeset
39 -- JRK 7/30/84
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 WITH REPORT; USE REPORT;
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 PROCEDURE C64005D0M IS
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 SUBTYPE LEVEL IS CHARACTER RANGE 'A' .. 'C';
kono
parents:
diff changeset
46 SUBTYPE CALL IS CHARACTER RANGE '1' .. '3';
kono
parents:
diff changeset
47
kono
parents:
diff changeset
48 MAX_LEV : CONSTANT := LEVEL'POS (LEVEL'LAST) -
kono
parents:
diff changeset
49 LEVEL'POS (LEVEL'FIRST) + 1;
kono
parents:
diff changeset
50 T_LEN : CONSTANT := 2 * (1 + 3 * (MAX_LEV +
kono
parents:
diff changeset
51 MAX_LEV*(MAX_LEV+1)/2*2)) + 1;
kono
parents:
diff changeset
52 G_LEN : CONSTANT := 2 + 4 * MAX_LEV;
kono
parents:
diff changeset
53
kono
parents:
diff changeset
54 TYPE TRACE IS
kono
parents:
diff changeset
55 RECORD
kono
parents:
diff changeset
56 E : NATURAL := 0;
kono
parents:
diff changeset
57 S : STRING (1 .. T_LEN);
kono
parents:
diff changeset
58 END RECORD;
kono
parents:
diff changeset
59
kono
parents:
diff changeset
60 V : CHARACTER := IDENT_CHAR ('<');
kono
parents:
diff changeset
61 L : CHARACTER := IDENT_CHAR ('>');
kono
parents:
diff changeset
62 T : TRACE;
kono
parents:
diff changeset
63 G : STRING (1 .. G_LEN);
kono
parents:
diff changeset
64
kono
parents:
diff changeset
65 PROCEDURE C64005DA (L : LEVEL; C : CALL; T : IN OUT TRACE) IS
kono
parents:
diff changeset
66 SEPARATE;
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 BEGIN
kono
parents:
diff changeset
69 TEST ("C64005D", "CHECK THAT NON-LOCAL VARIABLES AND FORMAL " &
kono
parents:
diff changeset
70 "PARAMETERS AT ALL LEVELS OF NESTED " &
kono
parents:
diff changeset
71 "RECURSIVE PROCEDURES ARE ACCESSIBLE (FOR " &
kono
parents:
diff changeset
72 "3 LEVELS OF SEPARATELY COMPILED SUBUNITS)");
kono
parents:
diff changeset
73
kono
parents:
diff changeset
74 -- APPEND V TO T.
kono
parents:
diff changeset
75 T.S (T.E+1) := V;
kono
parents:
diff changeset
76 T.E := T.E + 1;
kono
parents:
diff changeset
77
kono
parents:
diff changeset
78 C64005DA (IDENT_CHAR(LEVEL'FIRST), IDENT_CHAR('1'), T);
kono
parents:
diff changeset
79
kono
parents:
diff changeset
80 -- APPEND L TO T.
kono
parents:
diff changeset
81 T.S (T.E+1) := L;
kono
parents:
diff changeset
82 T.E := T.E + 1;
kono
parents:
diff changeset
83
kono
parents:
diff changeset
84 COMMENT ("FINAL CALL TRACE LENGTH IS: " & INTEGER'IMAGE(T.E));
kono
parents:
diff changeset
85 COMMENT ("FINAL CALL TRACE IS: " & T.S(1..T.E));
kono
parents:
diff changeset
86 COMMENT ("GLOBAL SNAPSHOT IS: " & G);
kono
parents:
diff changeset
87
kono
parents:
diff changeset
88 -- CHECK THAT T AND G ARE CORRECT BY COMPUTING THEM ITERATIVELY.
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 DECLARE
kono
parents:
diff changeset
91 SUBTYPE LC_LEVEL IS CHARACTER RANGE ASCII.LC_A ..
kono
parents:
diff changeset
92 CHARACTER'VAL (CHARACTER'POS(ASCII.LC_A) + MAX_LEV - 1);
kono
parents:
diff changeset
93
kono
parents:
diff changeset
94 CT : TRACE;
kono
parents:
diff changeset
95 CG : STRING (1 .. G_LEN);
kono
parents:
diff changeset
96 BEGIN
kono
parents:
diff changeset
97 COMMENT ("CORRECT FINAL CALL TRACE LENGTH IS: " &
kono
parents:
diff changeset
98 INTEGER'IMAGE(T_LEN));
kono
parents:
diff changeset
99
kono
parents:
diff changeset
100 IF T.E /= IDENT_INT (T_LEN) THEN
kono
parents:
diff changeset
101 FAILED ("WRONG FINAL CALL TRACE LENGTH");
kono
parents:
diff changeset
102
kono
parents:
diff changeset
103 ELSE CT.S (CT.E+1) := '<';
kono
parents:
diff changeset
104 CT.E := CT.E + 1;
kono
parents:
diff changeset
105
kono
parents:
diff changeset
106 FOR I IN LC_LEVEL LOOP
kono
parents:
diff changeset
107 CT.S (CT.E+1) := '<';
kono
parents:
diff changeset
108 CT.E := CT.E + 1;
kono
parents:
diff changeset
109
kono
parents:
diff changeset
110 FOR J IN LC_LEVEL'FIRST .. I LOOP
kono
parents:
diff changeset
111 CT.S (CT.E+1) := J;
kono
parents:
diff changeset
112 CT.S (CT.E+2) := '1';
kono
parents:
diff changeset
113 CT.E := CT.E + 2;
kono
parents:
diff changeset
114 END LOOP;
kono
parents:
diff changeset
115 END LOOP;
kono
parents:
diff changeset
116
kono
parents:
diff changeset
117 FOR I IN LC_LEVEL LOOP
kono
parents:
diff changeset
118 CT.S (CT.E+1) := '<';
kono
parents:
diff changeset
119 CT.E := CT.E + 1;
kono
parents:
diff changeset
120
kono
parents:
diff changeset
121 FOR J IN LC_LEVEL'FIRST .. LC_LEVEL'PRED(I) LOOP
kono
parents:
diff changeset
122 CT.S (CT.E+1) := J;
kono
parents:
diff changeset
123 CT.S (CT.E+2) := '3';
kono
parents:
diff changeset
124 CT.E := CT.E + 2;
kono
parents:
diff changeset
125 END LOOP;
kono
parents:
diff changeset
126
kono
parents:
diff changeset
127 CT.S (CT.E+1) := I;
kono
parents:
diff changeset
128 CT.S (CT.E+2) := '2';
kono
parents:
diff changeset
129 CT.E := CT.E + 2;
kono
parents:
diff changeset
130
kono
parents:
diff changeset
131 CT.S (CT.E+1) := '<';
kono
parents:
diff changeset
132 CT.E := CT.E + 1;
kono
parents:
diff changeset
133
kono
parents:
diff changeset
134 FOR J IN LC_LEVEL'FIRST .. I LOOP
kono
parents:
diff changeset
135 CT.S (CT.E+1) := J;
kono
parents:
diff changeset
136 CT.S (CT.E+2) := '3';
kono
parents:
diff changeset
137 CT.E := CT.E + 2;
kono
parents:
diff changeset
138 END LOOP;
kono
parents:
diff changeset
139 END LOOP;
kono
parents:
diff changeset
140
kono
parents:
diff changeset
141 CT.S (CT.E+1) := '=';
kono
parents:
diff changeset
142 CT.E := CT.E + 1;
kono
parents:
diff changeset
143
kono
parents:
diff changeset
144 FOR I IN REVERSE LEVEL LOOP
kono
parents:
diff changeset
145 FOR J IN REVERSE LEVEL'FIRST .. I LOOP
kono
parents:
diff changeset
146 CT.S (CT.E+1) := J;
kono
parents:
diff changeset
147 CT.S (CT.E+2) := '3';
kono
parents:
diff changeset
148 CT.E := CT.E + 2;
kono
parents:
diff changeset
149 END LOOP;
kono
parents:
diff changeset
150
kono
parents:
diff changeset
151 CT.S (CT.E+1) := '>';
kono
parents:
diff changeset
152 CT.E := CT.E + 1;
kono
parents:
diff changeset
153
kono
parents:
diff changeset
154 CT.S (CT.E+1) := I;
kono
parents:
diff changeset
155 CT.S (CT.E+2) := '2';
kono
parents:
diff changeset
156 CT.E := CT.E + 2;
kono
parents:
diff changeset
157
kono
parents:
diff changeset
158 FOR J IN REVERSE LEVEL'FIRST .. LEVEL'PRED(I) LOOP
kono
parents:
diff changeset
159 CT.S (CT.E+1) := J;
kono
parents:
diff changeset
160 CT.S (CT.E+2) := '3';
kono
parents:
diff changeset
161 CT.E := CT.E + 2;
kono
parents:
diff changeset
162 END LOOP;
kono
parents:
diff changeset
163
kono
parents:
diff changeset
164 CT.S (CT.E+1) := '>';
kono
parents:
diff changeset
165 CT.E := CT.E + 1;
kono
parents:
diff changeset
166 END LOOP;
kono
parents:
diff changeset
167
kono
parents:
diff changeset
168 FOR I IN REVERSE LEVEL LOOP
kono
parents:
diff changeset
169 FOR J IN REVERSE LEVEL'FIRST .. I LOOP
kono
parents:
diff changeset
170 CT.S (CT.E+1) := J;
kono
parents:
diff changeset
171 CT.S (CT.E+2) := '1';
kono
parents:
diff changeset
172 CT.E := CT.E + 2;
kono
parents:
diff changeset
173 END LOOP;
kono
parents:
diff changeset
174
kono
parents:
diff changeset
175 CT.S (CT.E+1) := '>';
kono
parents:
diff changeset
176 CT.E := CT.E + 1;
kono
parents:
diff changeset
177 END LOOP;
kono
parents:
diff changeset
178
kono
parents:
diff changeset
179 CT.S (CT.E+1) := '>';
kono
parents:
diff changeset
180 CT.E := CT.E + 1;
kono
parents:
diff changeset
181
kono
parents:
diff changeset
182 IF CT.E /= IDENT_INT (T_LEN) THEN
kono
parents:
diff changeset
183 FAILED ("WRONG ITERATIVE TRACE LENGTH");
kono
parents:
diff changeset
184
kono
parents:
diff changeset
185 ELSE COMMENT ("CORRECT FINAL CALL TRACE IS: " & CT.S);
kono
parents:
diff changeset
186
kono
parents:
diff changeset
187 IF T.S /= CT.S THEN
kono
parents:
diff changeset
188 FAILED ("WRONG FINAL CALL TRACE");
kono
parents:
diff changeset
189 END IF;
kono
parents:
diff changeset
190 END IF;
kono
parents:
diff changeset
191 END IF;
kono
parents:
diff changeset
192
kono
parents:
diff changeset
193 DECLARE
kono
parents:
diff changeset
194 E : NATURAL := 0;
kono
parents:
diff changeset
195 BEGIN
kono
parents:
diff changeset
196 CG (1..2) := "<>";
kono
parents:
diff changeset
197 E := E + 2;
kono
parents:
diff changeset
198
kono
parents:
diff changeset
199 FOR I IN LEVEL LOOP
kono
parents:
diff changeset
200 CG (E+1) := LC_LEVEL'VAL (LEVEL'POS(I) -
kono
parents:
diff changeset
201 LEVEL'POS(LEVEL'FIRST) +
kono
parents:
diff changeset
202 LC_LEVEL'POS
kono
parents:
diff changeset
203 (LC_LEVEL'FIRST));
kono
parents:
diff changeset
204 CG (E+2) := '3';
kono
parents:
diff changeset
205 CG (E+3) := I;
kono
parents:
diff changeset
206 CG (E+4) := '3';
kono
parents:
diff changeset
207 E := E + 4;
kono
parents:
diff changeset
208 END LOOP;
kono
parents:
diff changeset
209
kono
parents:
diff changeset
210 COMMENT ("CORRECT GLOBAL SNAPSHOT IS: " & CG);
kono
parents:
diff changeset
211
kono
parents:
diff changeset
212 IF G /= CG THEN
kono
parents:
diff changeset
213 FAILED ("WRONG GLOBAL SNAPSHOT");
kono
parents:
diff changeset
214 END IF;
kono
parents:
diff changeset
215 END;
kono
parents:
diff changeset
216 END;
kono
parents:
diff changeset
217
kono
parents:
diff changeset
218 RESULT;
kono
parents:
diff changeset
219 END C64005D0M;