[multiple changes]
[gcc.git] / gcc / ada / atree.h
1 /****************************************************************************
2 * *
3 * GNAT COMPILER COMPONENTS *
4 * *
5 * A T R E E *
6 * *
7 * C Header File *
8 * *
9 * Copyright (C) 1992-2010, Free Software Foundation, Inc. *
10 * *
11 * GNAT is free software; you can redistribute it and/or modify it under *
12 * terms of the GNU General Public License as published by the Free Soft- *
13 * ware Foundation; either version 3, or (at your option) any later ver- *
14 * sion. GNAT is distributed in the hope that it will be useful, but WITH- *
15 * OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY *
16 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License *
17 * for more details. You should have received a copy of the GNU General *
18 * Public License distributed with GNAT; see file COPYING3. If not, go to *
19 * http://www.gnu.org/licenses for a complete copy of the license. *
20 * *
21 * GNAT was originally developed by the GNAT team at New York University. *
22 * Extensive contributions were provided by Ada Core Technologies Inc. *
23 * *
24 ****************************************************************************/
25
26 /* This is the C header corresponding to the Ada package specification for
27 Atree. It also contains the implementations of inlined functions from the
28 package body for Atree. It was generated manually from atree.ads and
29 atree.adb and must be kept synchronized with changes in these files.
30
31 Note that only routines for reading the tree are included, since the tree
32 transformer is not supposed to modify the tree in any way. */
33
34 /* Structure used for the first part of the node in the case where we have
35 an Nkind. */
36
37 struct NFK
38 {
39 Boolean is_extension : 1;
40 Boolean pflag1 : 1;
41 Boolean pflag2 : 1;
42 Boolean in_list : 1;
43 Boolean has_aspects : 1;
44 Boolean rewrite_ins : 1;
45 Boolean analyzed : 1;
46 Boolean c_f_s : 1;
47 Boolean error_posted : 1;
48
49 Boolean flag4 : 1;
50 Boolean flag5 : 1;
51 Boolean flag6 : 1;
52 Boolean flag7 : 1;
53 Boolean flag8 : 1;
54 Boolean flag9 : 1;
55 Boolean flag10 : 1;
56
57 Boolean flag11 : 1;
58 Boolean flag12 : 1;
59 Boolean flag13 : 1;
60 Boolean flag14 : 1;
61 Boolean flag15 : 1;
62 Boolean flag16 : 1;
63 Boolean flag17 : 1;
64 Boolean flag18 : 1;
65
66 unsigned char kind;
67 };
68
69 /* Structure for the first part of a node when Nkind is not present by
70 extra flag bits are. */
71
72 struct NFNK
73 {
74 Boolean is_extension : 1;
75 Boolean pflag1 : 1;
76 Boolean pflag2 : 1;
77 Boolean in_list : 1;
78 Boolean has_aspects : 1;
79 Boolean rewrite_ins : 1;
80 Boolean analyzed : 1;
81 Boolean c_f_s : 1;
82 Boolean error_posted : 1;
83
84 Boolean flag4 : 1;
85 Boolean flag5 : 1;
86 Boolean flag6 : 1;
87 Boolean flag7 : 1;
88 Boolean flag8 : 1;
89 Boolean flag9 : 1;
90 Boolean flag10 : 1;
91
92 Boolean flag11 : 1;
93 Boolean flag12 : 1;
94 Boolean flag13 : 1;
95 Boolean flag14 : 1;
96 Boolean flag15 : 1;
97 Boolean flag16 : 1;
98 Boolean flag17 : 1;
99 Boolean flag18 : 1;
100
101 Boolean flag65 : 1;
102 Boolean flag66 : 1;
103 Boolean flag67 : 1;
104 Boolean flag68 : 1;
105 Boolean flag69 : 1;
106 Boolean flag70 : 1;
107 Boolean flag71 : 1;
108 Boolean flag72 : 1;
109 };
110
111 /* Structure used for extra flags in third component overlaying Field12 */
112 struct Flag_Word
113 {
114 Boolean flag73 : 1;
115 Boolean flag74 : 1;
116 Boolean flag75 : 1;
117 Boolean flag76 : 1;
118 Boolean flag77 : 1;
119 Boolean flag78 : 1;
120 Boolean flag79 : 1;
121 Boolean flag80 : 1;
122 Boolean flag81 : 1;
123 Boolean flag82 : 1;
124 Boolean flag83 : 1;
125 Boolean flag84 : 1;
126 Boolean flag85 : 1;
127 Boolean flag86 : 1;
128 Boolean flag87 : 1;
129 Boolean flag88 : 1;
130 Boolean flag89 : 1;
131 Boolean flag90 : 1;
132 Boolean flag91 : 1;
133 Boolean flag92 : 1;
134 Boolean flag93 : 1;
135 Boolean flag94 : 1;
136 Boolean flag95 : 1;
137 Boolean flag96 : 1;
138 Short convention : 8;
139 };
140
141 /* Structure used for extra flags in fourth component overlaying Field12 */
142 struct Flag_Word2
143 {
144 Boolean flag97 : 1;
145 Boolean flag98 : 1;
146 Boolean flag99 : 1;
147 Boolean flag100 : 1;
148 Boolean flag101 : 1;
149 Boolean flag102 : 1;
150 Boolean flag103 : 1;
151 Boolean flag104 : 1;
152 Boolean flag105 : 1;
153 Boolean flag106 : 1;
154 Boolean flag107 : 1;
155 Boolean flag108 : 1;
156 Boolean flag109 : 1;
157 Boolean flag110 : 1;
158 Boolean flag111 : 1;
159 Boolean flag112 : 1;
160 Boolean flag113 : 1;
161 Boolean flag114 : 1;
162 Boolean flag115 : 1;
163 Boolean flag116 : 1;
164 Boolean flag117 : 1;
165 Boolean flag118 : 1;
166 Boolean flag119 : 1;
167 Boolean flag120 : 1;
168 Boolean flag121 : 1;
169 Boolean flag122 : 1;
170 Boolean flag123 : 1;
171 Boolean flag124 : 1;
172 Boolean flag125 : 1;
173 Boolean flag126 : 1;
174 Boolean flag127 : 1;
175 Boolean flag128 : 1;
176 };
177
178 /* Structure used for extra flags in fourth component overlaying Field11 */
179 struct Flag_Word3
180 {
181 Boolean flag152 : 1;
182 Boolean flag153 : 1;
183 Boolean flag154 : 1;
184 Boolean flag155 : 1;
185 Boolean flag156 : 1;
186 Boolean flag157 : 1;
187 Boolean flag158 : 1;
188 Boolean flag159 : 1;
189
190 Boolean flag160 : 1;
191 Boolean flag161 : 1;
192 Boolean flag162 : 1;
193 Boolean flag163 : 1;
194 Boolean flag164 : 1;
195 Boolean flag165 : 1;
196 Boolean flag166 : 1;
197 Boolean flag167 : 1;
198
199 Boolean flag168 : 1;
200 Boolean flag169 : 1;
201 Boolean flag170 : 1;
202 Boolean flag171 : 1;
203 Boolean flag172 : 1;
204 Boolean flag173 : 1;
205 Boolean flag174 : 1;
206 Boolean flag175 : 1;
207
208 Boolean flag176 : 1;
209 Boolean flag177 : 1;
210 Boolean flag178 : 1;
211 Boolean flag179 : 1;
212 Boolean flag180 : 1;
213 Boolean flag181 : 1;
214 Boolean flag182 : 1;
215 Boolean flag183 : 1;
216 };
217
218 /* Structure used for extra flags in fifth component overlaying Field12 */
219 struct Flag_Word4
220 {
221 Boolean flag184 : 1;
222 Boolean flag185 : 1;
223 Boolean flag186 : 1;
224 Boolean flag187 : 1;
225 Boolean flag188 : 1;
226 Boolean flag189 : 1;
227 Boolean flag190 : 1;
228 Boolean flag191 : 1;
229
230 Boolean flag192 : 1;
231 Boolean flag193 : 1;
232 Boolean flag194 : 1;
233 Boolean flag195 : 1;
234 Boolean flag196 : 1;
235 Boolean flag197 : 1;
236 Boolean flag198 : 1;
237 Boolean flag199 : 1;
238
239 Boolean flag200 : 1;
240 Boolean flag201 : 1;
241 Boolean flag202 : 1;
242 Boolean flag203 : 1;
243 Boolean flag204 : 1;
244 Boolean flag205 : 1;
245 Boolean flag206 : 1;
246 Boolean flag207 : 1;
247
248 Boolean flag208 : 1;
249 Boolean flag209 : 1;
250 Boolean flag210 : 1;
251 Boolean flag211 : 1;
252 Boolean flag212 : 1;
253 Boolean flag213 : 1;
254 Boolean flag214 : 1;
255 Boolean flag215 : 1;
256 };
257
258 struct Non_Extended
259 {
260 Source_Ptr sloc;
261 Int link;
262 Int field1;
263 Int field2;
264 Int field3;
265 Int field4;
266 Int field5;
267 };
268
269 /* The Following structure corresponds to variant with is_extension = True. */
270 struct Extended
271 {
272 Int field6;
273 Int field7;
274 Int field8;
275 Int field9;
276 Int field10;
277 union
278 {
279 Int field11;
280 struct Flag_Word3 fw3;
281 } X;
282
283 union
284 {
285 Int field12;
286 struct Flag_Word fw;
287 struct Flag_Word2 fw2;
288 struct Flag_Word4 fw4;
289 } U;
290 };
291
292 /* A tree node itself. */
293
294 struct Node
295 {
296 union kind
297 {
298 struct NFK K;
299 struct NFNK NK;
300 } U;
301
302 union variant
303 {
304 struct Non_Extended NX;
305 struct Extended EX;
306 } V;
307 };
308
309 /* The actual tree is an array of nodes. The pointer to this array is passed
310 as a parameter to the tree transformer procedure and stored in the global
311 variable Nodes_Ptr after adjusting it by subtracting Node_First_Entry, so
312 that Node_Id values can be used as subscripts. */
313 extern struct Node *Nodes_Ptr;
314
315 #define Parent atree__parent
316 extern Node_Id Parent (Node_Id);
317
318 /* Overloaded Functions:
319
320 These functions are overloaded in the original Ada source, but there is
321 only one corresponding C function, which works as described below. */
322
323 /* Type used for union of Node_Id, List_Id, Elist_Id. */
324 typedef Int Tree_Id;
325
326 /* These two functions can only be used for Node_Id and List_Id values and
327 they work in the C version because Empty = No_List = 0. */
328
329 static Boolean No (Tree_Id);
330 static Boolean Present (Tree_Id);
331
332 INLINE Boolean
333 No (Tree_Id N)
334 {
335 return N == Empty;
336 }
337
338 INLINE Boolean
339 Present (Tree_Id N)
340 {
341 return N != Empty;
342 }
343
344 extern Node_Id Parent (Tree_Id);
345
346 #define Current_Error_Node atree__current_error_node
347 extern Node_Id Current_Error_Node;
348
349 /* Node Access Functions: */
350
351 #define Nkind(N) ((Node_Kind) (Nodes_Ptr[(N) - First_Node_Id].U.K.kind))
352 #define Ekind(N) ((Entity_Kind) (Nodes_Ptr[N + 1].U.K.kind))
353 #define Sloc(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.sloc)
354 #define Paren_Count(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.pflag1 \
355 + 2 * Nodes_Ptr[(N) - First_Node_Id].U.K.pflag2)
356
357 #define Field1(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.field1)
358 #define Field2(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.field2)
359 #define Field3(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.field3)
360 #define Field4(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.field4)
361 #define Field5(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.field5)
362 #define Field6(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.field6)
363 #define Field7(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.field7)
364 #define Field8(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.field8)
365 #define Field9(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.field9)
366 #define Field10(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.field10)
367 #define Field11(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.X.field11)
368 #define Field12(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.U.field12)
369 #define Field13(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.field6)
370 #define Field14(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.field7)
371 #define Field15(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.field8)
372 #define Field16(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.field9)
373 #define Field17(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.field10)
374 #define Field18(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.X.field11)
375 #define Field19(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.field6)
376 #define Field20(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.field7)
377 #define Field21(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.field8)
378 #define Field22(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.field9)
379 #define Field23(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.field10)
380 #define Field24(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.field6)
381 #define Field25(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.field7)
382 #define Field26(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.field8)
383 #define Field27(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.field9)
384 #define Field28(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.field10)
385 #define Field29(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.field11)
386
387 #define Node1(N) Field1 (N)
388 #define Node2(N) Field2 (N)
389 #define Node3(N) Field3 (N)
390 #define Node4(N) Field4 (N)
391 #define Node5(N) Field5 (N)
392 #define Node6(N) Field6 (N)
393 #define Node7(N) Field7 (N)
394 #define Node8(N) Field8 (N)
395 #define Node9(N) Field9 (N)
396 #define Node10(N) Field10 (N)
397 #define Node11(N) Field11 (N)
398 #define Node12(N) Field12 (N)
399 #define Node13(N) Field13 (N)
400 #define Node14(N) Field14 (N)
401 #define Node15(N) Field15 (N)
402 #define Node16(N) Field16 (N)
403 #define Node17(N) Field17 (N)
404 #define Node18(N) Field18 (N)
405 #define Node19(N) Field19 (N)
406 #define Node20(N) Field20 (N)
407 #define Node21(N) Field21 (N)
408 #define Node22(N) Field22 (N)
409 #define Node23(N) Field23 (N)
410 #define Node24(N) Field24 (N)
411 #define Node25(N) Field25 (N)
412 #define Node26(N) Field26 (N)
413 #define Node27(N) Field27 (N)
414 #define Node28(N) Field28 (N)
415 #define Node29(N) Field29 (N)
416
417 #define List1(N) Field1 (N)
418 #define List2(N) Field2 (N)
419 #define List3(N) Field3 (N)
420 #define List4(N) Field4 (N)
421 #define List5(N) Field5 (N)
422 #define List10(N) Field10 (N)
423 #define List14(N) Field14 (N)
424
425 #define Elist1(N) Field1 (N)
426 #define Elist2(N) Field2 (N)
427 #define Elist3(N) Field3 (N)
428 #define Elist4(N) Field4 (N)
429 #define Elist8(N) Field8 (N)
430 #define Elist13(N) Field13 (N)
431 #define Elist15(N) Field15 (N)
432 #define Elist16(N) Field16 (N)
433 #define Elist18(N) Field18 (N)
434 #define Elist21(N) Field21 (N)
435 #define Elist23(N) Field23 (N)
436 #define Elist25(N) Field25 (N)
437 #define Elist26(N) Field26 (N)
438
439 #define Name1(N) Field1 (N)
440 #define Name2(N) Field2 (N)
441
442 #define Char_Code2(N) (Field2 (N) - Char_Code_Bias)
443
444 #define Str3(N) Field3 (N)
445
446 #define Uint2(N) ((Field2 (N) == 0) ? Uint_0 : Field2 (N))
447 #define Uint3(N) ((Field3 (N) == 0) ? Uint_0 : Field3 (N))
448 #define Uint4(N) ((Field4 (N) == 0) ? Uint_0 : Field4 (N))
449 #define Uint5(N) ((Field5 (N) == 0) ? Uint_0 : Field5 (N))
450 #define Uint8(N) ((Field8 (N) == 0) ? Uint_0 : Field8 (N))
451 #define Uint9(N) ((Field9 (N) == 0) ? Uint_0 : Field9 (N))
452 #define Uint10(N) ((Field10 (N) == 0) ? Uint_0 : Field10 (N))
453 #define Uint11(N) ((Field11 (N) == 0) ? Uint_0 : Field11 (N))
454 #define Uint12(N) ((Field12 (N) == 0) ? Uint_0 : Field12 (N))
455 #define Uint13(N) ((Field13 (N) == 0) ? Uint_0 : Field13 (N))
456 #define Uint14(N) ((Field14 (N) == 0) ? Uint_0 : Field14 (N))
457 #define Uint15(N) ((Field15 (N) == 0) ? Uint_0 : Field15 (N))
458 #define Uint16(N) ((Field16 (N) == 0) ? Uint_0 : Field16 (N))
459 #define Uint17(N) ((Field17 (N) == 0) ? Uint_0 : Field17 (N))
460 #define Uint22(N) ((Field22 (N) == 0) ? Uint_0 : Field22 (N))
461
462 #define Ureal3(N) Field3 (N)
463 #define Ureal18(N) Field18 (N)
464 #define Ureal21(N) Field21 (N)
465
466 #define Analyzed(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.analyzed)
467 #define Comes_From_Source(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.c_f_s)
468 #define Error_Posted(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.error_posted)
469 #define Has_Aspects(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.has_aspects)
470 #define Convention(N) \
471 (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.convention)
472
473 #define Flag4(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag4)
474 #define Flag5(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag5)
475 #define Flag6(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag6)
476 #define Flag7(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag7)
477 #define Flag8(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag8)
478 #define Flag9(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag9)
479 #define Flag10(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag10)
480 #define Flag11(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag11)
481 #define Flag12(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag12)
482 #define Flag13(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag13)
483 #define Flag14(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag14)
484 #define Flag15(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag15)
485 #define Flag16(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag16)
486 #define Flag17(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag17)
487 #define Flag18(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag18)
488
489 #define Flag19(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.in_list)
490 #define Flag20(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.has_aspects)
491 #define Flag21(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.rewrite_ins)
492 #define Flag22(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.analyzed)
493 #define Flag23(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.c_f_s)
494 #define Flag24(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.error_posted)
495 #define Flag25(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag4)
496 #define Flag26(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag5)
497 #define Flag27(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag6)
498 #define Flag28(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag7)
499 #define Flag29(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag8)
500 #define Flag30(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag9)
501 #define Flag31(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag10)
502 #define Flag32(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag11)
503 #define Flag33(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag12)
504 #define Flag34(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag13)
505 #define Flag35(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag14)
506 #define Flag36(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag15)
507 #define Flag37(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag16)
508 #define Flag38(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag17)
509 #define Flag39(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag18)
510
511 #define Flag40(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.in_list)
512 #define Flag41(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.has_aspects)
513 #define Flag42(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.rewrite_ins)
514 #define Flag43(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.analyzed)
515 #define Flag44(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.c_f_s)
516 #define Flag45(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.error_posted)
517 #define Flag46(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag4)
518 #define Flag47(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag5)
519 #define Flag48(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag6)
520 #define Flag49(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag7)
521 #define Flag50(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag8)
522 #define Flag51(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag9)
523 #define Flag52(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag10)
524 #define Flag53(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag11)
525 #define Flag54(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag12)
526 #define Flag55(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag13)
527 #define Flag56(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag14)
528 #define Flag57(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag15)
529 #define Flag58(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag16)
530 #define Flag59(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag17)
531 #define Flag60(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag18)
532 #define Flag61(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.pflag1)
533 #define Flag62(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.pflag2)
534 #define Flag63(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.pflag1)
535 #define Flag64(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.pflag2)
536
537 #define Flag65(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag65)
538 #define Flag66(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag66)
539 #define Flag67(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag67)
540 #define Flag68(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag68)
541 #define Flag69(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag69)
542 #define Flag70(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag70)
543 #define Flag71(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag71)
544 #define Flag72(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag72)
545
546 #define Flag73(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag73)
547 #define Flag74(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag74)
548 #define Flag75(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag75)
549 #define Flag76(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag76)
550 #define Flag77(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag77)
551 #define Flag78(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag78)
552 #define Flag79(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag79)
553 #define Flag80(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag80)
554 #define Flag81(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag81)
555 #define Flag82(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag82)
556 #define Flag83(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag83)
557 #define Flag84(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag84)
558 #define Flag85(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag85)
559 #define Flag86(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag86)
560 #define Flag87(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag87)
561 #define Flag88(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag88)
562 #define Flag89(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag89)
563 #define Flag90(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag90)
564 #define Flag91(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag91)
565 #define Flag92(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag92)
566 #define Flag93(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag93)
567 #define Flag94(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag94)
568 #define Flag95(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag95)
569 #define Flag96(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag96)
570 #define Flag97(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag97)
571 #define Flag98(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag98)
572 #define Flag99(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag99)
573 #define Flag100(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag100)
574 #define Flag101(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag101)
575 #define Flag102(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag102)
576 #define Flag103(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag103)
577 #define Flag104(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag104)
578 #define Flag105(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag105)
579 #define Flag106(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag106)
580 #define Flag107(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag107)
581 #define Flag108(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag108)
582 #define Flag109(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag109)
583 #define Flag110(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag110)
584 #define Flag111(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag111)
585 #define Flag112(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag112)
586 #define Flag113(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag113)
587 #define Flag114(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag114)
588 #define Flag115(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag115)
589 #define Flag116(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag116)
590 #define Flag117(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag117)
591 #define Flag118(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag118)
592 #define Flag119(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag119)
593 #define Flag120(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag120)
594 #define Flag121(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag121)
595 #define Flag122(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag122)
596 #define Flag123(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag123)
597 #define Flag124(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag124)
598 #define Flag125(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag125)
599 #define Flag126(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag126)
600 #define Flag127(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag127)
601 #define Flag128(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag128)
602
603 #define Flag129(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.in_list)
604 #define Flag130(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.has_aspects)
605 #define Flag131(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.rewrite_ins)
606 #define Flag132(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.analyzed)
607 #define Flag133(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.c_f_s)
608 #define Flag134(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.error_posted)
609 #define Flag135(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag4)
610 #define Flag136(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag5)
611 #define Flag137(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag6)
612 #define Flag138(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag7)
613 #define Flag139(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag8)
614 #define Flag140(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag9)
615 #define Flag141(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag10)
616 #define Flag142(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag11)
617 #define Flag143(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag12)
618 #define Flag144(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag13)
619 #define Flag145(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag14)
620 #define Flag146(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag15)
621 #define Flag147(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag16)
622 #define Flag148(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag17)
623 #define Flag149(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag18)
624 #define Flag150(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.pflag1)
625 #define Flag151(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.pflag2)
626
627 #define Flag152(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag152)
628 #define Flag153(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag153)
629 #define Flag154(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag154)
630 #define Flag155(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag155)
631 #define Flag156(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag156)
632 #define Flag157(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag157)
633 #define Flag158(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag158)
634 #define Flag159(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag159)
635 #define Flag160(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag160)
636 #define Flag161(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag161)
637 #define Flag162(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag162)
638 #define Flag163(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag163)
639 #define Flag164(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag164)
640 #define Flag165(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag165)
641 #define Flag166(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag166)
642 #define Flag167(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag167)
643 #define Flag168(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag168)
644 #define Flag169(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag169)
645 #define Flag170(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag170)
646 #define Flag171(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag171)
647 #define Flag172(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag172)
648 #define Flag173(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag173)
649 #define Flag174(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag174)
650 #define Flag175(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag175)
651 #define Flag176(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag176)
652 #define Flag177(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag177)
653 #define Flag178(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag178)
654 #define Flag179(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag179)
655 #define Flag180(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag180)
656 #define Flag181(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag181)
657 #define Flag182(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag182)
658 #define Flag183(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag183)
659
660 #define Flag184(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag184)
661 #define Flag185(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag185)
662 #define Flag186(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag186)
663 #define Flag187(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag187)
664 #define Flag188(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag188)
665 #define Flag189(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag189)
666 #define Flag190(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag190)
667 #define Flag191(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag191)
668 #define Flag192(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag192)
669 #define Flag193(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag193)
670 #define Flag194(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag194)
671 #define Flag195(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag195)
672 #define Flag196(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag196)
673 #define Flag197(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag197)
674 #define Flag198(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag198)
675 #define Flag199(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag199)
676 #define Flag200(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag200)
677 #define Flag201(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag201)
678 #define Flag202(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag202)
679 #define Flag203(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag203)
680 #define Flag204(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag204)
681 #define Flag205(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag205)
682 #define Flag206(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag206)
683 #define Flag207(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag207)
684 #define Flag208(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag208)
685 #define Flag209(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag209)
686 #define Flag210(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag210)
687 #define Flag211(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag211)
688 #define Flag212(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag212)
689 #define Flag213(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag213)
690 #define Flag214(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag214)
691 #define Flag215(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw4.flag215)
692
693 #define Flag216(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.in_list)
694 #define Flag217(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.has_aspects)
695 #define Flag218(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.rewrite_ins)
696 #define Flag219(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.analyzed)
697 #define Flag220(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.c_f_s)
698 #define Flag221(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.error_posted)
699 #define Flag222(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag4)
700 #define Flag223(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag5)
701 #define Flag224(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag6)
702 #define Flag225(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag7)
703 #define Flag226(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag8)
704 #define Flag227(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag9)
705 #define Flag228(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag10)
706 #define Flag229(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag11)
707 #define Flag230(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag12)
708 #define Flag231(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag13)
709 #define Flag232(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag14)
710 #define Flag233(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag15)
711 #define Flag234(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag16)
712 #define Flag235(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag17)
713 #define Flag236(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.flag18)
714 #define Flag237(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.pflag1)
715 #define Flag238(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.K.pflag2)
716
717 #define Flag239(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.NK.flag65)
718 #define Flag240(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.NK.flag66)
719 #define Flag241(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.NK.flag67)
720 #define Flag242(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.NK.flag68)
721 #define Flag243(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.NK.flag69)
722 #define Flag244(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.NK.flag70)
723 #define Flag245(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.NK.flag71)
724 #define Flag246(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.NK.flag72)
725
726 #define Flag247(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.NK.flag65)
727 #define Flag248(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.NK.flag66)
728 #define Flag249(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.NK.flag67)
729 #define Flag250(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.NK.flag68)
730 #define Flag251(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.NK.flag69)
731 #define Flag252(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.NK.flag70)
732 #define Flag253(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.NK.flag71)
733 #define Flag254(N) (Nodes_Ptr[(N) - First_Node_Id + 4].U.NK.flag72)
734