Daily bump.
[official-gcc.git] / gcc / ada / atree.h
blob9dda243499c614d9a43a963ebe138ce482b4fcaa
1 /****************************************************************************
2 * *
3 * GNAT COMPILER COMPONENTS *
4 * *
5 * A T R E E *
6 * *
7 * C Header File *
8 * *
9 * Copyright (C) 1992-2007, 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 ****************************************************************************/
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.
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. */
34 /* Structure used for the first part of the node in the case where we have
35 an Nkind. */
37 struct NFK
39 Boolean is_extension : 1;
40 Boolean pflag1 : 1;
41 Boolean pflag2 : 1;
42 Boolean in_list : 1;
43 Boolean rewrite_sub : 1;
44 Boolean rewrite_ins : 1;
45 Boolean analyzed : 1;
46 Boolean c_f_s : 1;
48 Boolean error_posted : 1;
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;
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;
66 unsigned char kind;
69 /* Structure for the first part of a node when Nkind is not present by
70 extra flag bits are. */
72 struct NFNK
74 Boolean is_extension : 1;
75 Boolean pflag1 : 1;
76 Boolean pflag2 : 1;
77 Boolean in_list : 1;
78 Boolean rewrite_sub : 1;
79 Boolean rewrite_ins : 1;
80 Boolean analyzed : 1;
81 Boolean c_f_s : 1;
83 Boolean error_posted : 1;
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;
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;
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;
111 /* Structure used for extra flags in third component overlaying Field12 */
112 struct Flag_Word
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;
141 /* Structure used for extra flags in fourth component overlaying Field12 */
142 struct Flag_Word2
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;
178 /* Structure used for extra flags in fourth component overlaying Field11 */
179 struct Flag_Word3
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;
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;
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;
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;
218 /* Structure used for extra flags in fifth component overlaying Field11 */
219 struct Flag_Word4
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;
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;
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;
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;
258 /* Structure used for extra flags in fifth component overlaying Field12 */
259 struct Flag_Word5
261 Boolean flag216 : 1;
262 Boolean flag217 : 1;
263 Boolean flag218 : 1;
264 Boolean flag219 : 1;
265 Boolean flag220 : 1;
266 Boolean flag221 : 1;
267 Boolean flag222 : 1;
268 Boolean flag223 : 1;
270 Boolean flag224 : 1;
271 Boolean flag225 : 1;
272 Boolean flag226 : 1;
273 Boolean flag227 : 1;
274 Boolean flag228 : 1;
275 Boolean flag229 : 1;
276 Boolean flag230 : 1;
277 Boolean flag231 : 1;
279 Boolean flag232 : 1;
280 Boolean flag233 : 1;
281 Boolean flag234 : 1;
282 Boolean flag235 : 1;
283 Boolean flag236 : 1;
284 Boolean flag237 : 1;
285 Boolean flag238 : 1;
286 Boolean flag239 : 1;
288 Boolean flag240 : 1;
289 Boolean flag241 : 1;
290 Boolean flag242 : 1;
291 Boolean flag243 : 1;
292 Boolean flag244 : 1;
293 Boolean flag245 : 1;
294 Boolean flag246 : 1;
295 Boolean flag247 : 1;
298 struct Non_Extended
300 Source_Ptr sloc;
301 Int link;
302 Int field1;
303 Int field2;
304 Int field3;
305 Int field4;
306 Int field5;
309 /* The Following structure corresponds to variant with is_extension = True. */
310 struct Extended
312 Int field6;
313 Int field7;
314 Int field8;
315 Int field9;
316 Int field10;
317 union
319 Int field11;
320 struct Flag_Word3 fw3;
321 struct Flag_Word4 fw4;
322 } X;
324 union
326 Int field12;
327 struct Flag_Word fw;
328 struct Flag_Word2 fw2;
329 struct Flag_Word5 fw5;
330 } U;
333 /* A tree node itself. */
335 struct Node
337 union kind
339 struct NFK K;
340 struct NFNK NK;
341 } U;
343 union variant
345 struct Non_Extended NX;
346 struct Extended EX;
347 } V;
350 /* The actual tree is an array of nodes. The pointer to this array is passed
351 as a parameter to the tree transformer procedure and stored in the global
352 variable Nodes_Ptr after adjusting it by subtracting Node_First_Entry, so
353 that Node_Id values can be used as subscripts. */
354 extern struct Node *Nodes_Ptr;
356 #define Parent atree__parent
357 extern Node_Id Parent (Node_Id);
359 /* Overloaded Functions:
361 These functions are overloaded in the original Ada source, but there is
362 only one corresponding C function, which works as described below. */
364 /* Type used for union of Node_Id, List_Id, Elist_Id. */
365 typedef Int Tree_Id;
367 /* These two functions can only be used for Node_Id and List_Id values and
368 they work in the C version because Empty = No_List = 0. */
370 static Boolean No (Tree_Id);
371 static Boolean Present (Tree_Id);
373 INLINE Boolean
374 No (Tree_Id N)
376 return N == Empty;
379 INLINE Boolean
380 Present (Tree_Id N)
382 return N != Empty;
385 extern Node_Id Parent (Tree_Id);
387 #define Current_Error_Node atree__current_error_node
388 extern Node_Id Current_Error_Node;
390 /* Node Access Functions: */
392 #define Nkind(N) ((Node_Kind) (Nodes_Ptr[(N) - First_Node_Id].U.K.kind))
393 #define Ekind(N) ((Entity_Kind) (Nodes_Ptr[N + 1].U.K.kind))
394 #define Sloc(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.sloc)
395 #define Paren_Count(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.pflag1 \
396 + 2 * Nodes_Ptr[(N) - First_Node_Id].U.K.pflag2)
398 #define Field1(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.field1)
399 #define Field2(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.field2)
400 #define Field3(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.field3)
401 #define Field4(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.field4)
402 #define Field5(N) (Nodes_Ptr[(N) - First_Node_Id].V.NX.field5)
403 #define Field6(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.field6)
404 #define Field7(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.field7)
405 #define Field8(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.field8)
406 #define Field9(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.field9)
407 #define Field10(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.field10)
408 #define Field11(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.X.field11)
409 #define Field12(N) (Nodes_Ptr[(N) - First_Node_Id + 1].V.EX.U.field12)
410 #define Field13(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.field6)
411 #define Field14(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.field7)
412 #define Field15(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.field8)
413 #define Field16(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.field9)
414 #define Field17(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.field10)
415 #define Field18(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.X.field11)
416 #define Field19(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.field6)
417 #define Field20(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.field7)
418 #define Field21(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.field8)
419 #define Field22(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.field9)
420 #define Field23(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.field10)
421 #define Field24(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.field6)
422 #define Field25(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.field7)
423 #define Field26(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.field8)
424 #define Field27(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.field9)
425 #define Field28(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.field10)
427 #define Node1(N) Field1 (N)
428 #define Node2(N) Field2 (N)
429 #define Node3(N) Field3 (N)
430 #define Node4(N) Field4 (N)
431 #define Node5(N) Field5 (N)
432 #define Node6(N) Field6 (N)
433 #define Node7(N) Field7 (N)
434 #define Node8(N) Field8 (N)
435 #define Node9(N) Field9 (N)
436 #define Node10(N) Field10 (N)
437 #define Node11(N) Field11 (N)
438 #define Node12(N) Field12 (N)
439 #define Node13(N) Field13 (N)
440 #define Node14(N) Field14 (N)
441 #define Node15(N) Field15 (N)
442 #define Node16(N) Field16 (N)
443 #define Node17(N) Field17 (N)
444 #define Node18(N) Field18 (N)
445 #define Node19(N) Field19 (N)
446 #define Node20(N) Field20 (N)
447 #define Node21(N) Field21 (N)
448 #define Node22(N) Field22 (N)
449 #define Node23(N) Field23 (N)
450 #define Node24(N) Field24 (N)
451 #define Node25(N) Field25 (N)
452 #define Node26(N) Field26 (N)
453 #define Node27(N) Field27 (N)
454 #define Node28(N) Field28 (N)
456 #define List1(N) Field1 (N)
457 #define List2(N) Field2 (N)
458 #define List3(N) Field3 (N)
459 #define List4(N) Field4 (N)
460 #define List5(N) Field5 (N)
461 #define List10(N) Field10 (N)
462 #define List14(N) Field14 (N)
464 #define Elist1(N) Field1 (N)
465 #define Elist2(N) Field2 (N)
466 #define Elist3(N) Field3 (N)
467 #define Elist4(N) Field4 (N)
468 #define Elist8(N) Field8 (N)
469 #define Elist13(N) Field13 (N)
470 #define Elist15(N) Field15 (N)
471 #define Elist16(N) Field16 (N)
472 #define Elist18(N) Field18 (N)
473 #define Elist21(N) Field21 (N)
474 #define Elist23(N) Field23 (N)
475 #define Elist25(N) Field25 (N)
477 #define Name1(N) Field1 (N)
478 #define Name2(N) Field2 (N)
480 #define Char_Code2(N) (Field2 (N) - Char_Code_Bias)
482 #define Str3(N) Field3 (N)
484 #define Uint2(N) ((Field2 (N) == 0) ? Uint_0 : Field2 (N))
485 #define Uint3(N) ((Field3 (N) == 0) ? Uint_0 : Field3 (N))
486 #define Uint4(N) ((Field4 (N) == 0) ? Uint_0 : Field4 (N))
487 #define Uint5(N) ((Field5 (N) == 0) ? Uint_0 : Field5 (N))
488 #define Uint8(N) ((Field8 (N) == 0) ? Uint_0 : Field8 (N))
489 #define Uint9(N) ((Field9 (N) == 0) ? Uint_0 : Field9 (N))
490 #define Uint10(N) ((Field10 (N) == 0) ? Uint_0 : Field10 (N))
491 #define Uint11(N) ((Field11 (N) == 0) ? Uint_0 : Field11 (N))
492 #define Uint12(N) ((Field12 (N) == 0) ? Uint_0 : Field12 (N))
493 #define Uint13(N) ((Field13 (N) == 0) ? Uint_0 : Field13 (N))
494 #define Uint14(N) ((Field14 (N) == 0) ? Uint_0 : Field14 (N))
495 #define Uint15(N) ((Field15 (N) == 0) ? Uint_0 : Field15 (N))
496 #define Uint16(N) ((Field16 (N) == 0) ? Uint_0 : Field16 (N))
497 #define Uint17(N) ((Field17 (N) == 0) ? Uint_0 : Field17 (N))
498 #define Uint22(N) ((Field22 (N) == 0) ? Uint_0 : Field22 (N))
500 #define Ureal3(N) Field3 (N)
501 #define Ureal18(N) Field18 (N)
502 #define Ureal21(N) Field21 (N)
504 #define Analyzed(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.analyzed)
505 #define Comes_From_Source(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.c_f_s)
506 #define Error_Posted(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.error_posted)
507 #define Convention(N) \
508 (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.convention)
510 #define Flag4(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag4)
511 #define Flag5(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag5)
512 #define Flag6(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag6)
513 #define Flag7(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag7)
514 #define Flag8(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag8)
515 #define Flag9(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag9)
516 #define Flag10(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag10)
517 #define Flag11(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag11)
518 #define Flag12(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag12)
519 #define Flag13(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag13)
520 #define Flag14(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag14)
521 #define Flag15(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag15)
522 #define Flag16(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag16)
523 #define Flag17(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag17)
524 #define Flag18(N) (Nodes_Ptr[(N) - First_Node_Id].U.K.flag18)
526 #define Flag19(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.in_list)
527 #define Flag20(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.rewrite_sub)
528 #define Flag21(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.rewrite_ins)
529 #define Flag22(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.analyzed)
530 #define Flag23(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.c_f_s)
531 #define Flag24(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.error_posted)
532 #define Flag25(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag4)
533 #define Flag26(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag5)
534 #define Flag27(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag6)
535 #define Flag28(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag7)
536 #define Flag29(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag8)
537 #define Flag30(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag9)
538 #define Flag31(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag10)
539 #define Flag32(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag11)
540 #define Flag33(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag12)
541 #define Flag34(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag13)
542 #define Flag35(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag14)
543 #define Flag36(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag15)
544 #define Flag37(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag16)
545 #define Flag38(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag17)
546 #define Flag39(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.flag18)
548 #define Flag40(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.in_list)
549 #define Flag41(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.rewrite_sub)
550 #define Flag42(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.rewrite_ins)
551 #define Flag43(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.analyzed)
552 #define Flag44(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.c_f_s)
553 #define Flag45(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.error_posted)
554 #define Flag46(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag4)
555 #define Flag47(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag5)
556 #define Flag48(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag6)
557 #define Flag49(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag7)
558 #define Flag50(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag8)
559 #define Flag51(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag9)
560 #define Flag52(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag10)
561 #define Flag53(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag11)
562 #define Flag54(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag12)
563 #define Flag55(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag13)
564 #define Flag56(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag14)
565 #define Flag57(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag15)
566 #define Flag58(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag16)
567 #define Flag59(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag17)
568 #define Flag60(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.flag18)
569 #define Flag61(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.pflag1)
570 #define Flag62(N) (Nodes_Ptr[(N) - First_Node_Id + 1].U.K.pflag2)
571 #define Flag63(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.pflag1)
572 #define Flag64(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.K.pflag2)
574 #define Flag65(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag65)
575 #define Flag66(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag66)
576 #define Flag67(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag67)
577 #define Flag68(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag68)
578 #define Flag69(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag69)
579 #define Flag70(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag70)
580 #define Flag71(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag71)
581 #define Flag72(N) (Nodes_Ptr[(N) - First_Node_Id + 2].U.NK.flag72)
583 #define Flag73(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag73)
584 #define Flag74(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag74)
585 #define Flag75(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag75)
586 #define Flag76(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag76)
587 #define Flag77(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag77)
588 #define Flag78(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag78)
589 #define Flag79(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag79)
590 #define Flag80(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag80)
591 #define Flag81(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag81)
592 #define Flag82(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag82)
593 #define Flag83(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag83)
594 #define Flag84(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag84)
595 #define Flag85(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag85)
596 #define Flag86(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag86)
597 #define Flag87(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag87)
598 #define Flag88(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag88)
599 #define Flag89(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag89)
600 #define Flag90(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag90)
601 #define Flag91(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag91)
602 #define Flag92(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag92)
603 #define Flag93(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag93)
604 #define Flag94(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag94)
605 #define Flag95(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag95)
606 #define Flag96(N) (Nodes_Ptr[(N) - First_Node_Id + 2].V.EX.U.fw.flag96)
607 #define Flag97(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag97)
608 #define Flag98(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag98)
609 #define Flag99(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag99)
610 #define Flag100(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag100)
611 #define Flag101(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag101)
612 #define Flag102(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag102)
613 #define Flag103(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag103)
614 #define Flag104(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag104)
615 #define Flag105(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag105)
616 #define Flag106(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag106)
617 #define Flag107(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag107)
618 #define Flag108(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag108)
619 #define Flag109(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag109)
620 #define Flag110(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag110)
621 #define Flag111(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag111)
622 #define Flag112(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag112)
623 #define Flag113(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag113)
624 #define Flag114(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag114)
625 #define Flag115(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag115)
626 #define Flag116(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag116)
627 #define Flag117(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag117)
628 #define Flag118(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag118)
629 #define Flag119(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag119)
630 #define Flag120(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag120)
631 #define Flag121(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag121)
632 #define Flag122(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag122)
633 #define Flag123(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag123)
634 #define Flag124(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag124)
635 #define Flag125(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag125)
636 #define Flag126(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag126)
637 #define Flag127(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag127)
638 #define Flag128(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.U.fw2.flag128)
640 #define Flag129(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.in_list)
641 #define Flag130(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.rewrite_sub)
642 #define Flag131(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.rewrite_ins)
643 #define Flag132(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.analyzed)
644 #define Flag133(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.c_f_s)
645 #define Flag134(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.error_posted)
646 #define Flag135(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag4)
647 #define Flag136(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag5)
648 #define Flag137(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag6)
649 #define Flag138(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag7)
650 #define Flag139(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag8)
651 #define Flag140(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag9)
652 #define Flag141(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag10)
653 #define Flag142(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag11)
654 #define Flag143(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag12)
655 #define Flag144(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag13)
656 #define Flag145(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag14)
657 #define Flag146(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag15)
658 #define Flag147(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag16)
659 #define Flag148(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag17)
660 #define Flag149(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.flag18)
661 #define Flag150(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.pflag1)
662 #define Flag151(N) (Nodes_Ptr[(N) - First_Node_Id + 3].U.K.pflag2)
664 #define Flag152(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag152)
665 #define Flag153(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag153)
666 #define Flag154(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag154)
667 #define Flag155(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag155)
668 #define Flag156(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag156)
669 #define Flag157(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag157)
670 #define Flag158(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag158)
671 #define Flag159(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag159)
672 #define Flag160(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag160)
673 #define Flag161(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag161)
674 #define Flag162(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag162)
675 #define Flag163(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag163)
676 #define Flag164(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag164)
677 #define Flag165(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag165)
678 #define Flag166(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag166)
679 #define Flag167(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag167)
680 #define Flag168(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag168)
681 #define Flag169(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag169)
682 #define Flag170(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag170)
683 #define Flag171(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag171)
684 #define Flag172(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag172)
685 #define Flag173(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag173)
686 #define Flag174(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag174)
687 #define Flag175(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag175)
688 #define Flag176(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag176)
689 #define Flag177(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag177)
690 #define Flag178(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag178)
691 #define Flag179(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag179)
692 #define Flag180(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag180)
693 #define Flag181(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag181)
694 #define Flag182(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag182)
695 #define Flag183(N) (Nodes_Ptr[(N) - First_Node_Id + 3].V.EX.X.fw3.flag183)
697 #define Flag184(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag184)
698 #define Flag185(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag185)
699 #define Flag186(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag186)
700 #define Flag187(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag187)
701 #define Flag188(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag188)
702 #define Flag189(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag189)
703 #define Flag190(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag190)
704 #define Flag191(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag191)
705 #define Flag192(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag192)
706 #define Flag193(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag193)
707 #define Flag194(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag194)
708 #define Flag195(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag195)
709 #define Flag196(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag196)
710 #define Flag197(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag197)
711 #define Flag198(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag198)
712 #define Flag199(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag199)
713 #define Flag200(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag200)
714 #define Flag201(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag201)
715 #define Flag202(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag202)
716 #define Flag203(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag203)
717 #define Flag204(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag204)
718 #define Flag205(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag205)
719 #define Flag206(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag206)
720 #define Flag207(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag207)
721 #define Flag208(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag208)
722 #define Flag209(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag209)
723 #define Flag210(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag210)
724 #define Flag211(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag211)
725 #define Flag212(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag212)
726 #define Flag213(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag213)
727 #define Flag214(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag214)
728 #define Flag215(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.X.fw4.flag215)
730 #define Flag216(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag216)
731 #define Flag217(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag217)
732 #define Flag218(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag218)
733 #define Flag219(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag219)
734 #define Flag220(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag220)
735 #define Flag221(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag221)
736 #define Flag222(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag222)
737 #define Flag223(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag223)
738 #define Flag224(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag224)
739 #define Flag225(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag225)
740 #define Flag226(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag226)
741 #define Flag227(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag227)
742 #define Flag228(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag228)
743 #define Flag229(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag229)
744 #define Flag230(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag230)
745 #define Flag231(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag231)
746 #define Flag232(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag232)
747 #define Flag233(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag233)
748 #define Flag234(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag234)
749 #define Flag235(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag235)
750 #define Flag236(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag236)
751 #define Flag237(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag237)
752 #define Flag238(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag238)
753 #define Flag239(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag239)
754 #define Flag240(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag240)
755 #define Flag241(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag241)
756 #define Flag242(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag242)
757 #define Flag243(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag243)
758 #define Flag244(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag244)
759 #define Flag245(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag245)
760 #define Flag246(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag246)
761 #define Flag247(N) (Nodes_Ptr[(N) - First_Node_Id + 4].V.EX.U.fw5.flag247)