1 ------------------------------------------------------------------------------
3 -- GNAT COMPILER COMPONENTS --
9 -- Copyright (C) 1992-2019, Free Software Foundation, Inc. --
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. --
18 -- As a special exception under Section 7 of GPL version 3, you are granted --
19 -- additional permissions described in the GCC Runtime Library Exception, --
20 -- version 3.1, as published by the Free Software Foundation. --
22 -- You should have received a copy of the GNU General Public License and --
23 -- a copy of the GCC Runtime Library Exception along with this program; --
24 -- see the files COPYING3 and COPYING.RUNTIME respectively. If not, see --
25 -- <http://www.gnu.org/licenses/>. --
27 -- GNAT was originally developed by the GNAT team at New York University. --
28 -- Extensive contributions were provided by Ada Core Technologies Inc. --
30 ------------------------------------------------------------------------------
32 pragma Style_Checks
(All_Checks
);
33 -- Turn off subprogram ordering check for this package
35 -- WARNING: There is a C version of this package. Any changes to this source
36 -- file must be properly reflected in the file atree.h which is a C header
37 -- file containing equivalent definitions for use by gigi.
39 with Aspects
; use Aspects
;
40 with Debug
; use Debug
;
41 with Nlists
; use Nlists
;
43 with Output
; use Output
;
44 with Sinput
; use Sinput
;
45 with Tree_IO
; use Tree_IO
;
47 with GNAT
.Heap_Sort_G
;
51 Ignored_Ghost_Recording_Proc
: Ignored_Ghost_Record_Proc
:= null;
52 -- This soft link captures the procedure invoked during the creation of an
53 -- ignored Ghost node or entity.
55 Locked
: Boolean := False;
56 -- Compiling with assertions enabled, node contents modifications are
57 -- permitted only when this switch is set to False; compiling without
58 -- assertions this lock has no effect.
60 Reporting_Proc
: Report_Proc
:= null;
61 -- Record argument to last call to Set_Reporting_Proc
63 Rewriting_Proc
: Rewrite_Proc
:= null;
64 -- This soft link captures the procedure invoked during a node rewrite
70 -- Suppose you find that node 12345 is messed up. You might want to find
71 -- the code that created that node. There are two ways to do this:
73 -- One way is to set a conditional breakpoint on New_Node_Debugging_Output
75 -- break nnd if n = 12345
76 -- and run gnat1 again from the beginning.
78 -- The other way is to set a breakpoint near the beginning (e.g. on
79 -- gnat1drv), and run. Then set Watch_Node (nickname "ww") to 12345 in gdb:
81 -- and set a breakpoint on New_Node_Breakpoint (nickname "nn"). Continue.
83 -- Either way, gnat1 will stop when node 12345 is created, or certain other
84 -- interesting operations are performed, such as Rewrite. To see exactly
85 -- which operations, search for "pragma Debug" below.
87 -- The second method is much faster if the amount of Ada code being
90 ww
: Node_Id
'Base := Node_Id
'First - 1;
91 pragma Export
(Ada
, ww
); -- trick the optimizer
92 Watch_Node
: Node_Id
'Base renames ww
;
93 -- Node to "watch"; that is, whenever a node is created, we check if it
94 -- is equal to Watch_Node, and if so, call New_Node_Breakpoint. You have
95 -- presumably set a breakpoint on New_Node_Breakpoint. Note that the
96 -- initial value of Node_Id'First - 1 ensures that by default, no node
97 -- will be equal to Watch_Node.
100 pragma Export
(Ada
, nn
);
101 procedure New_Node_Breakpoint
renames nn
;
102 -- This doesn't do anything interesting; it's just for setting breakpoint
103 -- on as explained above.
105 procedure nnd
(N
: Node_Id
);
106 pragma Export
(Ada
, nnd
);
107 procedure New_Node_Debugging_Output
(N
: Node_Id
) renames nnd
;
108 -- For debugging. If debugging is turned on, New_Node and New_Entity call
109 -- this. If debug flag N is turned on, this prints out the new node.
111 -- If Node = Watch_Node, this prints out the new node and calls
112 -- New_Node_Breakpoint. Otherwise, does nothing.
114 procedure Node_Debug_Output
(Op
: String; N
: Node_Id
);
115 -- Called by nnd; writes Op followed by information about N
117 procedure Print_Statistics
;
118 pragma Export
(Ada
, Print_Statistics
);
119 -- Print various statistics on the tables maintained by the package
121 -----------------------------
122 -- Local Objects and Types --
123 -----------------------------
126 -- Count allocated nodes for Num_Nodes function
128 use Unchecked_Access
;
129 -- We are allowed to see these from within our own body
131 use Atree_Private_Part
;
132 -- We are also allowed to see our private data structures
134 -- Functions used to store Entity_Kind value in Nkind field
136 -- The following declarations are used to store flags 65-72 in the
137 -- Nkind field of the third component of an extended (entity) node.
139 type Flag_Byte
is record
150 pragma Pack
(Flag_Byte
);
151 for Flag_Byte
'Size use 8;
153 type Flag_Byte_Ptr
is access all Flag_Byte
;
154 type Node_Kind_Ptr
is access all Node_Kind
;
156 function To_Flag_Byte
is new
157 Unchecked_Conversion
(Node_Kind
, Flag_Byte
);
159 function To_Flag_Byte_Ptr
is new
160 Unchecked_Conversion
(Node_Kind_Ptr
, Flag_Byte_Ptr
);
162 -- The following declarations are used to store flags 239-246 in the
163 -- Nkind field of the fourth component of an extended (entity) node.
165 type Flag_Byte2
is record
176 pragma Pack
(Flag_Byte2
);
177 for Flag_Byte2
'Size use 8;
179 type Flag_Byte2_Ptr
is access all Flag_Byte2
;
181 function To_Flag_Byte2
is new
182 Unchecked_Conversion
(Node_Kind
, Flag_Byte2
);
184 function To_Flag_Byte2_Ptr
is new
185 Unchecked_Conversion
(Node_Kind_Ptr
, Flag_Byte2_Ptr
);
187 -- The following declarations are used to store flags 247-254 in the
188 -- Nkind field of the fifth component of an extended (entity) node.
190 type Flag_Byte3
is record
201 pragma Pack
(Flag_Byte3
);
202 for Flag_Byte3
'Size use 8;
204 type Flag_Byte3_Ptr
is access all Flag_Byte3
;
206 function To_Flag_Byte3
is new
207 Unchecked_Conversion
(Node_Kind
, Flag_Byte3
);
209 function To_Flag_Byte3_Ptr
is new
210 Unchecked_Conversion
(Node_Kind_Ptr
, Flag_Byte3_Ptr
);
212 -- The following declarations are used to store flags 310-317 in the
213 -- Nkind field of the sixth component of an extended (entity) node.
215 type Flag_Byte4
is record
226 pragma Pack
(Flag_Byte4
);
227 for Flag_Byte4
'Size use 8;
229 type Flag_Byte4_Ptr
is access all Flag_Byte4
;
231 function To_Flag_Byte4
is new
232 Unchecked_Conversion
(Node_Kind
, Flag_Byte4
);
234 function To_Flag_Byte4_Ptr
is new
235 Unchecked_Conversion
(Node_Kind_Ptr
, Flag_Byte4_Ptr
);
237 -- The following declarations are used to store flags 73-96 and the
238 -- Convention field in the Field12 field of the third component of an
239 -- extended (Entity) node.
241 type Flag_Word
is record
269 Convention
: Convention_Id
;
272 pragma Pack
(Flag_Word
);
273 for Flag_Word
'Size use 32;
274 for Flag_Word
'Alignment use 4;
276 type Flag_Word_Ptr
is access all Flag_Word
;
277 type Union_Id_Ptr
is access all Union_Id
;
279 function To_Flag_Word
is new
280 Unchecked_Conversion
(Union_Id
, Flag_Word
);
282 function To_Flag_Word_Ptr
is new
283 Unchecked_Conversion
(Union_Id_Ptr
, Flag_Word_Ptr
);
285 -- The following declarations are used to store flags 97-128 in the
286 -- Field12 field of the fourth component of an extended (entity) node.
288 type Flag_Word2
is record
326 pragma Pack
(Flag_Word2
);
327 for Flag_Word2
'Size use 32;
328 for Flag_Word2
'Alignment use 4;
330 type Flag_Word2_Ptr
is access all Flag_Word2
;
332 function To_Flag_Word2
is new
333 Unchecked_Conversion
(Union_Id
, Flag_Word2
);
335 function To_Flag_Word2_Ptr
is new
336 Unchecked_Conversion
(Union_Id_Ptr
, Flag_Word2_Ptr
);
338 -- The following declarations are used to store flags 152-183 in the
339 -- Field11 field of the fourth component of an extended (entity) node.
341 type Flag_Word3
is record
379 pragma Pack
(Flag_Word3
);
380 for Flag_Word3
'Size use 32;
381 for Flag_Word3
'Alignment use 4;
383 type Flag_Word3_Ptr
is access all Flag_Word3
;
385 function To_Flag_Word3
is new
386 Unchecked_Conversion
(Union_Id
, Flag_Word3
);
388 function To_Flag_Word3_Ptr
is new
389 Unchecked_Conversion
(Union_Id_Ptr
, Flag_Word3_Ptr
);
391 -- The following declarations are used to store flags 184-215 in the
392 -- Field12 field of the fifth component of an extended (entity) node.
394 type Flag_Word4
is record
432 pragma Pack
(Flag_Word4
);
433 for Flag_Word4
'Size use 32;
434 for Flag_Word4
'Alignment use 4;
436 type Flag_Word4_Ptr
is access all Flag_Word4
;
438 function To_Flag_Word4
is new
439 Unchecked_Conversion
(Union_Id
, Flag_Word4
);
441 function To_Flag_Word4_Ptr
is new
442 Unchecked_Conversion
(Union_Id_Ptr
, Flag_Word4_Ptr
);
444 -- The following declarations are used to store flags 255-286 in the
445 -- Field12 field of the sixth component of an extended (entity) node.
447 type Flag_Word5
is record
485 pragma Pack
(Flag_Word5
);
486 for Flag_Word5
'Size use 32;
487 for Flag_Word5
'Alignment use 4;
489 type Flag_Word5_Ptr
is access all Flag_Word5
;
491 function To_Flag_Word5
is new
492 Unchecked_Conversion
(Union_Id
, Flag_Word5
);
494 function To_Flag_Word5_Ptr
is new
495 Unchecked_Conversion
(Union_Id_Ptr
, Flag_Word5_Ptr
);
497 --------------------------------------------------
498 -- Implementation of Tree Substitution Routines --
499 --------------------------------------------------
501 -- A separate table keeps track of the mapping between rewritten nodes
502 -- and their corresponding original tree nodes. Rewrite makes an entry
503 -- in this table for use by Original_Node. By default, if no call is
504 -- Rewrite, the entry in this table points to the original unwritten node.
506 -- Note: eventually, this should be a field in the Node directly, but
507 -- for now we do not want to disturb the efficiency of a power of 2
510 package Orig_Nodes
is new Table
.Table
(
511 Table_Component_Type
=> Node_Id
,
512 Table_Index_Type
=> Node_Id
'Base,
513 Table_Low_Bound
=> First_Node_Id
,
514 Table_Initial
=> Alloc
.Nodes_Initial
,
515 Table_Increment
=> Alloc
.Nodes_Increment
,
516 Release_Threshold
=> Alloc
.Nodes_Release_Threshold
,
517 Table_Name
=> "Orig_Nodes");
519 --------------------------
520 -- Paren_Count Handling --
521 --------------------------
523 -- As noted in the spec, the paren count in a sub-expression node has
524 -- four possible values 0,1,2, and 3. The value 3 really means 3 or more,
525 -- and we use an auxiliary serially scanned table to record the actual
526 -- count. A serial search is fine, only pathological programs will use
527 -- entries in this table. Normal programs won't use it at all.
529 type Paren_Count_Entry
is record
531 -- The node to which this count applies
533 Count
: Nat
range 3 .. Nat
'Last;
534 -- The count of parentheses, which will be in the indicated range
537 package Paren_Counts
is new Table
.Table
(
538 Table_Component_Type
=> Paren_Count_Entry
,
539 Table_Index_Type
=> Int
,
540 Table_Low_Bound
=> 0,
542 Table_Increment
=> 200,
543 Table_Name
=> "Paren_Counts");
545 -----------------------
546 -- Local Subprograms --
547 -----------------------
549 function Allocate_Initialize_Node
551 With_Extension
: Boolean) return Node_Id
;
552 -- Allocate a new node or node extension. If Src is not empty, the
553 -- information for the newly-allocated node is copied from it.
555 procedure Fix_Parents
(Ref_Node
, Fix_Node
: Node_Id
);
556 -- Fix up parent pointers for the syntactic children of Fix_Node after a
557 -- copy, setting them to Fix_Node when they pointed to Ref_Node.
559 procedure Mark_New_Ghost_Node
(N
: Node_Or_Entity_Id
);
560 -- Mark arbitrary node or entity N as Ghost when it is created within a
563 ------------------------------
564 -- Allocate_Initialize_Node --
565 ------------------------------
567 function Allocate_Initialize_Node
569 With_Extension
: Boolean) return Node_Id
575 and then not Has_Extension
(Src
)
576 and then With_Extension
577 and then Src
= Nodes
.Last
581 -- We are allocating a new node, or extending a node other than
585 if Present
(Src
) then
586 Nodes
.Append
(Nodes
.Table
(Src
));
587 Flags
.Append
(Flags
.Table
(Src
));
589 Nodes
.Append
(Default_Node
);
590 Flags
.Append
(Default_Flags
);
593 New_Id
:= Nodes
.Last
;
594 Orig_Nodes
.Append
(New_Id
);
595 Node_Count
:= Node_Count
+ 1;
598 -- Clear Check_Actuals to False
600 Set_Check_Actuals
(New_Id
, False);
602 -- Specifically copy Paren_Count to deal with creating new table entry
603 -- if the parentheses count is at the maximum possible value already.
605 if Present
(Src
) and then Nkind
(Src
) in N_Subexpr
then
606 Set_Paren_Count
(New_Id
, Paren_Count
(Src
));
609 -- Set extension nodes if required
611 if With_Extension
then
612 if Present
(Src
) and then Has_Extension
(Src
) then
613 for J
in 1 .. Num_Extension_Nodes
loop
614 Nodes
.Append
(Nodes
.Table
(Src
+ J
));
615 Flags
.Append
(Flags
.Table
(Src
+ J
));
618 for J
in 1 .. Num_Extension_Nodes
loop
619 Nodes
.Append
(Default_Node_Extension
);
620 Flags
.Append
(Default_Flags
);
625 Orig_Nodes
.Set_Last
(Nodes
.Last
);
626 Allocate_List_Tables
(Nodes
.Last
);
628 -- Invoke the reporting procedure (if available)
630 if Reporting_Proc
/= null then
631 Reporting_Proc
.all (Target
=> New_Id
, Source
=> Src
);
635 end Allocate_Initialize_Node
;
641 function Analyzed
(N
: Node_Id
) return Boolean is
643 pragma Assert
(N
<= Nodes
.Last
);
644 return Nodes
.Table
(N
).Analyzed
;
647 --------------------------
648 -- Basic_Set_Convention --
649 --------------------------
651 procedure Basic_Set_Convention
(E
: Entity_Id
; Val
: Convention_Id
) is
653 pragma Assert
(Nkind
(E
) in N_Entity
);
656 (Nodes.Table (E + 2).Field12'Unrestricted_Access)).Convention := Val;
657 end Basic_Set_Convention;
663 function Check_Actuals (N : Node_Id) return Boolean is
665 return Flags.Table (N).Check_Actuals;
668 --------------------------
669 -- Check_Error_Detected --
670 --------------------------
672 procedure Check_Error_Detected is
674 -- An anomaly has been detected which is assumed to be a consequence of
675 -- a previous serious error or configurable run time violation. Raise
676 -- an exception if no such error has been detected.
678 if Serious_Errors_Detected = 0
679 and then Configurable_Run_Time_Violations = 0
683 end Check_Error_Detected;
689 procedure Change_Node (N : Node_Id; New_Node_Kind : Node_Kind) is
691 -- Flags table attributes
693 Save_CA : constant Boolean := Flags.Table (N).Check_Actuals;
694 Save_Is_IGN : constant Boolean := Flags.Table (N).Is_Ignored_Ghost_Node;
696 -- Nodes table attributes
698 Save_CFS : constant Boolean := Nodes.Table (N).Comes_From_Source;
699 Save_In_List : constant Boolean := Nodes.Table (N).In_List;
700 Save_Link : constant Union_Id := Nodes.Table (N).Link;
701 Save_Posted : constant Boolean := Nodes.Table (N).Error_Posted;
702 Save_Sloc : constant Source_Ptr := Sloc (N);
704 Par_Count : Nat := 0;
707 if Nkind (N) in N_Subexpr then
708 Par_Count := Paren_Count (N);
711 Nodes.Table (N) := Default_Node;
712 Nodes.Table (N).Sloc := Save_Sloc;
713 Nodes.Table (N).In_List := Save_In_List;
714 Nodes.Table (N).Link := Save_Link;
715 Nodes.Table (N).Comes_From_Source := Save_CFS;
716 Nodes.Table (N).Nkind := New_Node_Kind;
717 Nodes.Table (N).Error_Posted := Save_Posted;
719 Flags.Table (N) := Default_Flags;
720 Flags.Table (N).Check_Actuals := Save_CA;
721 Flags.Table (N).Is_Ignored_Ghost_Node := Save_Is_IGN;
723 if New_Node_Kind in N_Subexpr then
724 Set_Paren_Count (N, Par_Count);
728 -----------------------
729 -- Comes_From_Source --
730 -----------------------
732 function Comes_From_Source (N : Node_Id) return Boolean is
734 pragma Assert (N <= Nodes.Last);
735 return Nodes.Table (N).Comes_From_Source;
736 end Comes_From_Source;
742 function Convention (E : Entity_Id) return Convention_Id is
744 pragma Assert (Nkind (E) in N_Entity);
745 return To_Flag_Word (Nodes.Table (E + 2).Field12).Convention;
752 procedure Copy_Node (Source : Node_Id; Destination : Node_Id) is
753 Save_In_List : constant Boolean := Nodes.Table (Destination).In_List;
754 Save_Link : constant Union_Id := Nodes.Table (Destination).Link;
757 pragma Debug (New_Node_Debugging_Output (Source));
758 pragma Debug (New_Node_Debugging_Output (Destination));
760 Nodes.Table (Destination) := Nodes.Table (Source);
761 Nodes.Table (Destination).In_List := Save_In_List;
762 Nodes.Table (Destination).Link := Save_Link;
764 Flags.Table (Destination) := Flags.Table (Source);
766 -- Specifically set Paren_Count to make sure auxiliary table entry
767 -- gets correctly made if the parentheses count is at the max value.
769 if Nkind (Destination) in N_Subexpr then
770 Set_Paren_Count (Destination, Paren_Count (Source));
773 -- Deal with copying extension nodes if present. No need to copy flags
774 -- table entries, since they are always zero for extending components.
776 pragma Assert (Has_Extension (Source) = Has_Extension (Destination));
778 if Has_Extension (Source) then
779 for J in 1 .. Num_Extension_Nodes loop
780 Nodes.Table (Destination + J) := Nodes.Table (Source + J);
785 ------------------------
786 -- Copy_Separate_List --
787 ------------------------
789 function Copy_Separate_List (Source : List_Id) return List_Id is
790 Result : constant List_Id := New_List;
794 Nod := First (Source);
795 while Present (Nod) loop
796 Append (Copy_Separate_Tree (Nod), Result);
801 end Copy_Separate_List;
803 ------------------------
804 -- Copy_Separate_Tree --
805 ------------------------
807 function Copy_Separate_Tree (Source : Node_Id) return Node_Id is
810 function Copy_Entity (E : Entity_Id) return Entity_Id;
811 -- Copy Entity, copying only the Ekind and Chars fields
813 function Copy_List (List : List_Id) return List_Id;
816 function Possible_Copy (Field : Union_Id) return Union_Id;
817 -- Given a field, returns a copy of the node or list if its parent is
818 -- the current source node, and otherwise returns the input.
824 function Copy_Entity (E : Entity_Id) return Entity_Id is
828 -- Build appropriate node
830 case N_Entity (Nkind (E)) is
831 when N_Defining_Identifier =>
832 New_Ent := New_Entity (N_Defining_Identifier, Sloc (E));
834 when N_Defining_Character_Literal =>
835 New_Ent := New_Entity (N_Defining_Character_Literal, Sloc (E));
837 when N_Defining_Operator_Symbol =>
838 New_Ent := New_Entity (N_Defining_Operator_Symbol, Sloc (E));
841 Set_Chars (New_Ent, Chars (E));
842 -- Set_Comes_From_Source (New_Ent, Comes_From_Source (E));
850 function Copy_List (List : List_Id) return List_Id is
855 if List = No_List then
862 while Present (E) loop
863 if Has_Extension (E) then
864 Append (Copy_Entity (E), NL);
866 Append (Copy_Separate_Tree (E), NL);
880 function Possible_Copy (Field : Union_Id) return Union_Id is
884 if Field in Node_Range then
885 New_N := Union_Id (Copy_Separate_Tree (Node_Id (Field)));
887 if Parent (Node_Id (Field)) = Source then
888 Set_Parent (Node_Id (New_N), New_Id);
893 elsif Field in List_Range then
894 New_N := Union_Id (Copy_List (List_Id (Field)));
896 if Parent (List_Id (Field)) = Source then
897 Set_Parent (List_Id (New_N), New_Id);
907 -- Start of processing for Copy_Separate_Tree
910 if Source <= Empty_Or_Error then
913 elsif Has_Extension (Source) then
914 return Copy_Entity (Source);
917 New_Id := New_Copy (Source);
919 -- Recursively copy descendants
921 Set_Field1 (New_Id, Possible_Copy (Field1 (New_Id)));
922 Set_Field2 (New_Id, Possible_Copy (Field2 (New_Id)));
923 Set_Field3 (New_Id, Possible_Copy (Field3 (New_Id)));
924 Set_Field4 (New_Id, Possible_Copy (Field4 (New_Id)));
925 Set_Field5 (New_Id, Possible_Copy (Field5 (New_Id)));
927 -- Explicitly copy the aspect specifications as those do not reside
930 if Permits_Aspect_Specifications (Source)
931 and then Has_Aspects (Source)
933 Set_Aspect_Specifications
934 (New_Id, Copy_List (Aspect_Specifications (Source)));
937 -- Set Entity field to Empty to ensure that no entity references
938 -- are shared between the two, if the source is already analyzed.
940 if Nkind (New_Id) in N_Has_Entity
941 or else Nkind (New_Id) = N_Freeze_Entity
943 Set_Entity (New_Id, Empty);
946 -- Reset all Etype fields and Analyzed flags, because input tree may
947 -- have been fully or partially analyzed.
949 if Nkind (New_Id) in N_Has_Etype then
950 Set_Etype (New_Id, Empty);
953 Set_Analyzed (New_Id, False);
955 -- Rather special case, if we have an expanded name, then change
956 -- it back into a selected component, so that the tree looks the
957 -- way it did coming out of the parser. This will change back
958 -- when we analyze the selected component node.
960 if Nkind (New_Id) = N_Expanded_Name then
962 -- The following code is a bit kludgy. It would be cleaner to
963 -- Add an entry Change_Expanded_Name_To_Selected_Component to
964 -- Sinfo.CN, but that's an earthquake, because it has the wrong
965 -- license, and Atree is used outside the compiler, e.g. in the
966 -- binder and in ASIS, so we don't want to add that dependency.
968 -- Consequently we have no choice but to hold our noses and do
969 -- the change manually. At least we are Atree, so this odd use
970 -- of Atree.Unchecked_Access is at least all in the family.
972 -- Change the node type
974 Atree.Unchecked_Access.Set_Nkind (New_Id, N_Selected_Component);
976 -- Clear the Chars field which is not present in a selected
977 -- component node, so we don't want a junk value around.
979 Set_Node1 (New_Id, Empty);
982 -- All done, return copied node
986 end Copy_Separate_Tree;
992 function Ekind (E : Entity_Id) return Entity_Kind is
994 pragma Assert (Nkind (E) in N_Entity);
995 return N_To_E (Nodes.Table (E + 1).Nkind);
1005 V2 : Entity_Kind) return Boolean
1008 return T = V1 or else
1016 V3 : Entity_Kind) return Boolean
1019 return T = V1 or else
1029 V4 : Entity_Kind) return Boolean
1032 return T = V1 or else
1044 V5 : Entity_Kind) return Boolean
1047 return T = V1 or else
1061 V6 : Entity_Kind) return Boolean
1064 return T = V1 or else
1080 V7 : Entity_Kind) return Boolean
1083 return T = V1 or else
1101 V8 : Entity_Kind) return Boolean
1104 return T = V1 or else
1124 V9 : Entity_Kind) return Boolean
1127 return T = V1 or else
1149 V10 : Entity_Kind) return Boolean
1152 return T = V1 or else
1176 V11 : Entity_Kind) return Boolean
1179 return T = V1 or else
1195 V2 : Entity_Kind) return Boolean
1198 return Ekind_In (Ekind (E), V1, V2);
1205 V3 : Entity_Kind) return Boolean
1208 return Ekind_In (Ekind (E), V1, V2, V3);
1216 V4 : Entity_Kind) return Boolean
1219 return Ekind_In (Ekind (E), V1, V2, V3, V4);
1228 V5 : Entity_Kind) return Boolean
1231 return Ekind_In (Ekind (E), V1, V2, V3, V4, V5);
1241 V6 : Entity_Kind) return Boolean
1244 return Ekind_In (Ekind (E), V1, V2, V3, V4, V5, V6);
1255 V7 : Entity_Kind) return Boolean
1258 return Ekind_In (Ekind (E), V1, V2, V3, V4, V5, V6, V7);
1270 V8 : Entity_Kind) return Boolean
1273 return Ekind_In (Ekind (E), V1, V2, V3, V4, V5, V6, V7, V8);
1286 V9 : Entity_Kind) return Boolean
1289 return Ekind_In (Ekind (E), V1, V2, V3, V4, V5, V6, V7, V8, V9);
1303 V10 : Entity_Kind) return Boolean
1306 return Ekind_In (Ekind (E), V1, V2, V3, V4, V5, V6, V7, V8, V9, V10);
1321 V11 : Entity_Kind) return Boolean
1325 Ekind_In (Ekind (E), V1, V2, V3, V4, V5, V6, V7, V8, V9, V10, V11);
1332 function Error_Posted (N : Node_Id) return Boolean is
1334 pragma Assert (N <= Nodes.Last);
1335 return Nodes.Table (N).Error_Posted;
1338 -----------------------
1339 -- Exchange_Entities --
1340 -----------------------
1342 procedure Exchange_Entities (E1 : Entity_Id; E2 : Entity_Id) is
1343 Temp_Ent : Node_Record;
1344 Temp_Flg : Flags_Byte;
1347 pragma Debug (New_Node_Debugging_Output (E1));
1348 pragma Debug (New_Node_Debugging_Output (E2));
1351 and then Has_Extension (E1)
1352 and then Has_Extension (E2)
1353 and then not Nodes.Table (E1).In_List
1354 and then not Nodes.Table (E2).In_List);
1356 -- Exchange the contents of the two entities
1358 for J in 0 .. Num_Extension_Nodes loop
1359 Temp_Ent := Nodes.Table (E1 + J);
1360 Nodes.Table (E1 + J) := Nodes.Table (E2 + J);
1361 Nodes.Table (E2 + J) := Temp_Ent;
1364 -- Exchange flag bytes for first component. No need to do the exchange
1365 -- for the other components, since the flag bytes are always zero.
1367 Temp_Flg := Flags.Table (E1);
1368 Flags.Table (E1) := Flags.Table (E2);
1369 Flags.Table (E2) := Temp_Flg;
1371 -- That exchange exchanged the parent pointers as well, which is what
1372 -- we want, but we need to patch up the defining identifier pointers
1373 -- in the parent nodes (the child pointers) to match this switch
1374 -- unless for Implicit types entities which have no parent, in which
1375 -- case we don't do anything otherwise we won't be able to revert back
1376 -- to the original situation.
1378 -- Shouldn't this use Is_Itype instead of the Parent test
1380 if Present (Parent (E1)) and then Present (Parent (E2)) then
1381 Set_Defining_Identifier (Parent (E1), E1);
1382 Set_Defining_Identifier (Parent (E2), E2);
1384 end Exchange_Entities;
1390 function Extend_Node (Node : Node_Id) return Entity_Id is
1393 procedure Debug_Extend_Node;
1394 pragma Inline (Debug_Extend_Node);
1395 -- Debug routine for debug flag N
1397 -----------------------
1398 -- Debug_Extend_Node --
1399 -----------------------
1401 procedure Debug_Extend_Node is
1403 if Debug_Flag_N then
1404 Write_Str ("Extend node ");
1405 Write_Int (Int (Node));
1407 if Result = Node then
1408 Write_Str (" in place");
1410 Write_Str (" copied to ");
1411 Write_Int (Int (Result));
1416 end Debug_Extend_Node;
1418 -- Start of processing for Extend_Node
1421 pragma Assert (not (Has_Extension (Node)));
1423 Result := Allocate_Initialize_Node (Node, With_Extension => True);
1424 pragma Debug (Debug_Extend_Node);
1433 procedure Fix_Parents (Ref_Node, Fix_Node : Node_Id) is
1434 procedure Fix_Parent (Field : Union_Id);
1435 -- Fix up one parent pointer. Field is checked to see if it points to
1436 -- a node, list, or element list that has a parent that points to
1437 -- Ref_Node. If so, the parent is reset to point to Fix_Node.
1443 procedure Fix_Parent (Field : Union_Id) is
1445 -- Fix parent of node that is referenced by Field. Note that we must
1446 -- exclude the case where the node is a member of a list, because in
1447 -- this case the parent is the parent of the list.
1449 if Field in Node_Range
1450 and then Present (Node_Id (Field))
1451 and then not Nodes.Table (Node_Id (Field)).In_List
1452 and then Parent (Node_Id (Field)) = Ref_Node
1454 Set_Parent (Node_Id (Field), Fix_Node);
1456 -- Fix parent of list that is referenced by Field
1458 elsif Field in List_Range
1459 and then Present (List_Id (Field))
1460 and then Parent (List_Id (Field)) = Ref_Node
1462 Set_Parent (List_Id (Field), Fix_Node);
1466 -- Start of processing for Fix_Parents
1469 Fix_Parent (Field1 (Fix_Node));
1470 Fix_Parent (Field2 (Fix_Node));
1471 Fix_Parent (Field3 (Fix_Node));
1472 Fix_Parent (Field4 (Fix_Node));
1473 Fix_Parent (Field5 (Fix_Node));
1480 function Flags_Address return System.Address is
1482 return Flags.Table (First_Node_Id)'Address;
1485 -----------------------------------
1486 -- Get_Comes_From_Source_Default --
1487 -----------------------------------
1489 function Get_Comes_From_Source_Default return Boolean is
1491 return Default_Node.Comes_From_Source;
1492 end Get_Comes_From_Source_Default;
1498 function Has_Aspects (N : Node_Id) return Boolean is
1500 pragma Assert (N <= Nodes.Last);
1501 return Nodes.Table (N).Has_Aspects;
1508 function Has_Extension (N : Node_Id) return Boolean is
1510 return N < Nodes.Last and then Nodes.Table (N + 1).Is_Extension;
1517 procedure Initialize is
1519 pragma Warnings (Off, Dummy);
1523 Atree_Private_Part.Nodes.Init;
1524 Atree_Private_Part.Flags.Init;
1528 -- Allocate Empty node
1530 Dummy := New_Node (N_Empty, No_Location);
1531 Set_Name1 (Empty, No_Name);
1533 -- Allocate Error node, and set Error_Posted, since we certainly
1534 -- only generate an Error node if we do post some kind of error.
1536 Dummy := New_Node (N_Error, No_Location);
1537 Set_Name1 (Error, Error_Name);
1538 Set_Error_Posted (Error, True);
1541 ---------------------------
1542 -- Is_Ignored_Ghost_Node --
1543 ---------------------------
1545 function Is_Ignored_Ghost_Node (N : Node_Id) return Boolean is
1547 return Flags.Table (N).Is_Ignored_Ghost_Node;
1548 end Is_Ignored_Ghost_Node;
1550 --------------------------
1551 -- Is_Rewrite_Insertion --
1552 --------------------------
1554 function Is_Rewrite_Insertion (Node : Node_Id) return Boolean is
1556 return Nodes.Table (Node).Rewrite_Ins;
1557 end Is_Rewrite_Insertion;
1559 -----------------------------
1560 -- Is_Rewrite_Substitution --
1561 -----------------------------
1563 function Is_Rewrite_Substitution (Node : Node_Id) return Boolean is
1565 return Orig_Nodes.Table (Node) /= Node;
1566 end Is_Rewrite_Substitution;
1572 function Last_Node_Id return Node_Id is
1583 -- We used to Release the tables, as in the comments below, but that is
1584 -- a waste of time. We're only wasting virtual memory here, and the
1585 -- release calls copy large amounts of data.
1588 Nodes.Locked := True;
1590 Flags.Locked := True;
1591 -- Orig_Nodes.Release;
1592 Orig_Nodes.Locked := True;
1599 procedure Lock_Nodes is
1601 pragma Assert (not Locked);
1605 -------------------------
1606 -- Mark_New_Ghost_Node --
1607 -------------------------
1609 procedure Mark_New_Ghost_Node (N : Node_Or_Entity_Id) is
1611 -- The Ghost node is created within a Ghost region
1613 if Ghost_Mode = Check then
1614 if Nkind (N) in N_Entity then
1615 Set_Is_Checked_Ghost_Entity (N);
1618 elsif Ghost_Mode = Ignore then
1619 if Nkind (N) in N_Entity then
1620 Set_Is_Ignored_Ghost_Entity (N);
1623 Set_Is_Ignored_Ghost_Node (N);
1625 -- Record the ignored Ghost node or entity in order to eliminate it
1626 -- from the tree later.
1628 if Ignored_Ghost_Recording_Proc /= null then
1629 Ignored_Ghost_Recording_Proc.all (N);
1632 end Mark_New_Ghost_Node;
1634 ----------------------------
1635 -- Mark_Rewrite_Insertion --
1636 ----------------------------
1638 procedure Mark_Rewrite_Insertion (New_Node : Node_Id) is
1640 Nodes.Table (New_Node).Rewrite_Ins := True;
1641 end Mark_Rewrite_Insertion;
1647 function New_Copy (Source : Node_Id) return Node_Id is
1648 New_Id : Node_Id := Source;
1651 if Source > Empty_Or_Error then
1652 New_Id := Allocate_Initialize_Node (Source, Has_Extension (Source));
1654 Nodes.Table (New_Id).In_List := False;
1655 Nodes.Table (New_Id).Link := Empty_List_Or_Node;
1657 -- If the original is marked as a rewrite insertion, then unmark the
1658 -- copy, since we inserted the original, not the copy.
1660 Nodes.Table (New_Id).Rewrite_Ins := False;
1661 pragma Debug (New_Node_Debugging_Output (New_Id));
1663 -- Clear Is_Overloaded since we cannot have semantic interpretations
1664 -- of this new node.
1666 if Nkind (Source) in N_Subexpr then
1667 Set_Is_Overloaded (New_Id, False);
1670 -- Always clear Has_Aspects, the caller must take care of copying
1671 -- aspects if this is required for the particular situation.
1673 Set_Has_Aspects (New_Id, False);
1675 -- Mark the copy as Ghost depending on the current Ghost region
1677 Mark_New_Ghost_Node (New_Id);
1688 (New_Node_Kind : Node_Kind;
1689 New_Sloc : Source_Ptr) return Entity_Id
1694 pragma Assert (New_Node_Kind in N_Entity);
1696 Ent := Allocate_Initialize_Node (Empty, With_Extension => True);
1698 -- If this is a node with a real location and we are generating
1699 -- source nodes, then reset Current_Error_Node. This is useful
1700 -- if we bomb during parsing to get a error location for the bomb.
1702 if Default_Node.Comes_From_Source and then New_Sloc > No_Location then
1703 Current_Error_Node := Ent;
1706 Nodes.Table (Ent).Nkind := New_Node_Kind;
1707 Nodes.Table (Ent).Sloc := New_Sloc;
1708 pragma Debug (New_Node_Debugging_Output (Ent));
1710 -- Mark the new entity as Ghost depending on the current Ghost region
1712 Mark_New_Ghost_Node (Ent);
1722 (New_Node_Kind : Node_Kind;
1723 New_Sloc : Source_Ptr) return Node_Id
1728 pragma Assert (New_Node_Kind not in N_Entity);
1730 Nod := Allocate_Initialize_Node (Empty, With_Extension => False);
1731 Nodes.Table (Nod).Nkind := New_Node_Kind;
1732 Nodes.Table (Nod).Sloc := New_Sloc;
1733 pragma Debug (New_Node_Debugging_Output (Nod));
1735 -- If this is a node with a real location and we are generating source
1736 -- nodes, then reset Current_Error_Node. This is useful if we bomb
1737 -- during parsing to get an error location for the bomb.
1739 if Default_Node.Comes_From_Source and then New_Sloc > No_Location then
1740 Current_Error_Node := Nod;
1743 -- Mark the new node as Ghost depending on the current Ghost region
1745 Mark_New_Ghost_Node (Nod);
1750 -------------------------
1751 -- New_Node_Breakpoint --
1752 -------------------------
1756 Write_Str ("Watched node ");
1757 Write_Int (Int (Watch_Node));
1761 -------------------------------
1762 -- New_Node_Debugging_Output --
1763 -------------------------------
1765 procedure nnd (N : Node_Id) is
1766 Node_Is_Watched : constant Boolean := N = Watch_Node;
1769 if Debug_Flag_N or else Node_Is_Watched then
1770 Node_Debug_Output ("Node", N);
1772 if Node_Is_Watched then
1773 New_Node_Breakpoint;
1782 function Nkind (N : Node_Id) return Node_Kind is
1784 return Nodes.Table (N).Nkind;
1794 V2 : Node_Kind) return Boolean
1797 return Nkind_In (Nkind (N), V1, V2);
1804 V3 : Node_Kind) return Boolean
1807 return Nkind_In (Nkind (N), V1, V2, V3);
1815 V4 : Node_Kind) return Boolean
1818 return Nkind_In (Nkind (N), V1, V2, V3, V4);
1827 V5 : Node_Kind) return Boolean
1830 return Nkind_In (Nkind (N), V1, V2, V3, V4, V5);
1840 V6 : Node_Kind) return Boolean
1843 return Nkind_In (Nkind (N), V1, V2, V3, V4, V5, V6);
1854 V7 : Node_Kind) return Boolean
1857 return Nkind_In (Nkind (N), V1, V2, V3, V4, V5, V6, V7);
1869 V8 : Node_Kind) return Boolean
1872 return Nkind_In (Nkind (N), V1, V2, V3, V4, V5, V6, V7, V8);
1885 V9 : Node_Kind) return Boolean
1888 return Nkind_In (Nkind (N), V1, V2, V3, V4, V5, V6, V7, V8, V9);
1902 V10 : Node_Kind) return Boolean
1905 return Nkind_In (Nkind (N), V1, V2, V3, V4, V5, V6, V7, V8, V9, V10);
1920 V11 : Node_Kind) return Boolean
1923 return Nkind_In (Nkind (N), V1, V2, V3, V4, V5, V6, V7, V8, V9, V10,
1931 function No (N : Node_Id) return Boolean is
1936 -----------------------
1937 -- Node_Debug_Output --
1938 -----------------------
1940 procedure Node_Debug_Output (Op : String; N : Node_Id) is
1944 if Nkind (N) in N_Entity then
1945 Write_Str (" entity");
1947 Write_Str (" node");
1950 Write_Str (" Id = ");
1951 Write_Int (Int (N));
1953 Write_Location (Sloc (N));
1955 Write_Str (Node_Kind'Image (Nkind (N)));
1957 end Node_Debug_Output;
1963 function Nodes_Address return System.Address is
1965 return Nodes.Table (First_Node_Id)'Address;
1972 function Num_Nodes return Nat is
1981 function Original_Node (Node : Node_Id) return Node_Id is
1983 return Orig_Nodes.Table (Node);
1990 function Paren_Count (N : Node_Id) return Nat is
1994 pragma Assert (N <= Nodes.Last);
1996 if Nodes.Table (N).Pflag1 then
2000 if Nodes.Table (N).Pflag2 then
2004 -- Value of 0,1,2 returned as is
2009 -- Value of 3 means we search the table, and we must find an entry
2012 for J in Paren_Counts.First .. Paren_Counts.Last loop
2013 if N = Paren_Counts.Table (J).Nod then
2014 return Paren_Counts.Table (J).Count;
2018 raise Program_Error;
2026 function Parent (N : Node_Id) return Node_Id is
2028 if Is_List_Member (N) then
2029 return Parent (List_Containing (N));
2031 return Node_Id (Nodes.Table (N).Link);
2039 function Present (N : Node_Id) return Boolean is
2044 --------------------------------
2045 -- Preserve_Comes_From_Source --
2046 --------------------------------
2048 procedure Preserve_Comes_From_Source (NewN, OldN : Node_Id) is
2050 Nodes.Table (NewN).Comes_From_Source :=
2051 Nodes.Table (OldN).Comes_From_Source;
2052 end Preserve_Comes_From_Source;
2054 ----------------------
2055 -- Print_Statistics --
2056 ----------------------
2058 procedure Print_Statistics is
2059 N_Count : constant Natural := Natural (Nodes.Last - First_Node_Id + 1);
2060 E_Count : Natural := 0;
2063 Write_Str ("Number of entities: ");
2067 function CP_Lt (Op1, Op2 : Natural) return Boolean;
2068 -- Compare routine for Sort
2070 procedure CP_Move (From : Natural; To : Natural);
2071 -- Move routine for Sort
2073 Kind_Count : array (Node_Kind) of Natural := (others => 0);
2074 -- Array of occurrence count per node kind
2076 Kind_Max : constant Natural := Node_Kind'Pos (N_Unused_At_End) - 1;
2077 -- The index of the largest (interesting) node kind
2079 Ranking : array (0 .. Kind_Max) of Node_Kind;
2080 -- Ranking array for node kinds (index 0 is used for the temporary)
2082 package Sorting is new GNAT.Heap_Sort_G (CP_Move, CP_Lt);
2084 function CP_Lt (Op1, Op2 : Natural) return Boolean is
2086 return Kind_Count (Ranking (Op2)) < Kind_Count (Ranking (Op1));
2089 procedure CP_Move (From : Natural; To : Natural) is
2091 Ranking (To) := Ranking (From);
2095 -- Count the number of occurrences of each node kind
2097 for I in First_Node_Id .. Nodes.Last loop
2099 Nkind : constant Node_Kind := Nodes.Table (I).Nkind;
2101 if not Nodes.Table (I).Is_Extension then
2102 Kind_Count (Nkind) := Kind_Count (Nkind) + 1;
2107 -- Sort the node kinds by number of occurrences
2109 for N in 1 .. Kind_Max loop
2110 Ranking (N) := Node_Kind'Val (N);
2113 Sorting.Sort (Kind_Max);
2115 -- Print the list in descending order
2117 for N in 1 .. Kind_Max loop
2119 Count : constant Natural := Kind_Count (Ranking (N));
2123 Write_Str (Node_Kind'Image (Ranking (N)));
2125 Write_Int (Int (Count));
2128 E_Count := E_Count + Count;
2134 Write_Str ("Total number of entities: ");
2135 Write_Int (Int (E_Count));
2138 Write_Str ("Maximum number of nodes per entity: ");
2139 Write_Int (Int (Num_Extension_Nodes + 1));
2142 Write_Str ("Number of allocated nodes: ");
2143 Write_Int (Int (N_Count));
2146 Write_Str ("Ratio allocated nodes/entities: ");
2147 Write_Int (Int (Long_Long_Integer (N_Count) * 100 /
2148 Long_Long_Integer (E_Count)));
2152 Write_Str ("Size of a node in bytes: ");
2153 Write_Int (Int (Node_Record'Size) / Storage_Unit);
2156 Write_Str ("Memory consumption in bytes: ");
2157 Write_Int (Int (Long_Long_Integer (N_Count) *
2158 (Node_Record'Size / Storage_Unit)));
2160 end Print_Statistics;
2166 function Relocate_Node (Source : Node_Id) return Node_Id is
2174 New_Node := New_Copy (Source);
2175 Fix_Parents (Ref_Node => Source, Fix_Node => New_Node);
2177 -- We now set the parent of the new node to be the same as the parent of
2178 -- the source. Almost always this parent will be replaced by a new value
2179 -- when the relocated node is reattached to the tree, but by doing it
2180 -- now, we ensure that this node is not even temporarily disconnected
2181 -- from the tree. Note that this does not happen free, because in the
2182 -- list case, the parent does not get set.
2184 Set_Parent (New_Node, Parent (Source));
2186 -- If the node being relocated was a rewriting of some original node,
2187 -- then the relocated node has the same original node.
2189 if Is_Rewrite_Substitution (Source) then
2190 Orig_Nodes.Table (New_Node) := Orig_Nodes.Table (Source);
2200 procedure Replace (Old_Node, New_Node : Node_Id) is
2201 Old_Post : constant Boolean := Nodes.Table (Old_Node).Error_Posted;
2202 Old_HasA : constant Boolean := Nodes.Table (Old_Node).Has_Aspects;
2203 Old_CFS : constant Boolean := Nodes.Table (Old_Node).Comes_From_Source;
2207 (not Has_Extension (Old_Node)
2208 and not Has_Extension (New_Node)
2209 and not Nodes.Table (New_Node).In_List);
2211 pragma Debug (New_Node_Debugging_Output (Old_Node));
2212 pragma Debug (New_Node_Debugging_Output (New_Node));
2214 -- Do copy, preserving link and in list status and required flags
2216 Copy_Node (Source => New_Node, Destination => Old_Node);
2217 Nodes.Table (Old_Node).Comes_From_Source := Old_CFS;
2218 Nodes.Table (Old_Node).Error_Posted := Old_Post;
2219 Nodes.Table (Old_Node).Has_Aspects := Old_HasA;
2221 -- Fix parents of substituted node, since it has changed identity
2223 Fix_Parents (Ref_Node => New_Node, Fix_Node => Old_Node);
2225 -- Since we are doing a replace, we assume that the original node
2226 -- is intended to become the new replaced node. The call would be
2227 -- to Rewrite if there were an intention to save the original node.
2229 Orig_Nodes.Table (Old_Node) := Old_Node;
2231 -- Invoke the reporting procedure (if available)
2233 if Reporting_Proc /= null then
2234 Reporting_Proc.all (Target => Old_Node, Source => New_Node);
2242 procedure Rewrite (Old_Node, New_Node : Node_Id) is
2244 -- Flags table attributes
2246 Old_CA : constant Boolean := Flags.Table (Old_Node).Check_Actuals;
2247 Old_Is_IGN : constant Boolean :=
2248 Flags.Table (Old_Node).Is_Ignored_Ghost_Node;
2250 -- Nodes table attributes
2252 Old_Error_Posted : constant Boolean :=
2253 Nodes.Table (Old_Node).Error_Posted;
2254 Old_Has_Aspects : constant Boolean :=
2255 Nodes.Table (Old_Node).Has_Aspects;
2257 Old_Must_Not_Freeze : Boolean;
2258 Old_Paren_Count : Nat;
2259 -- These fields are preserved in the new node only if the new node and
2260 -- the old node are both subexpression nodes.
2262 -- Note: it is a violation of abstraction levels for Must_Not_Freeze
2263 -- to be referenced like this. ???
2269 (not Has_Extension (Old_Node)
2270 and not Has_Extension (New_Node)
2271 and not Nodes.Table (New_Node).In_List);
2273 pragma Debug (New_Node_Debugging_Output (Old_Node));
2274 pragma Debug (New_Node_Debugging_Output (New_Node));
2276 if Nkind (Old_Node) in N_Subexpr then
2277 Old_Must_Not_Freeze := Must_Not_Freeze (Old_Node);
2278 Old_Paren_Count := Paren_Count (Old_Node);
2280 Old_Must_Not_Freeze := False;
2281 Old_Paren_Count := 0;
2284 -- Allocate a new node, to be used to preserve the original contents
2285 -- of the Old_Node, for possible later retrival by Original_Node and
2286 -- make an entry in the Orig_Nodes table. This is only done if we have
2287 -- not already rewritten the node, as indicated by an Orig_Nodes entry
2288 -- that does not reference the Old_Node.
2290 if Orig_Nodes.Table (Old_Node) = Old_Node then
2291 Sav_Node := New_Copy (Old_Node);
2292 Orig_Nodes.Table (Sav_Node) := Sav_Node;
2293 Orig_Nodes.Table (Old_Node) := Sav_Node;
2295 -- Both the old and new copies of the node will share the same list
2296 -- of aspect specifications if aspect specifications are present.
2298 if Old_Has_Aspects then
2299 Set_Aspect_Specifications
2300 (Sav_Node, Aspect_Specifications (Old_Node));
2304 -- Copy substitute node into place, preserving old fields as required
2306 Copy_Node (Source => New_Node, Destination => Old_Node);
2307 Nodes.Table (Old_Node).Error_Posted := Old_Error_Posted;
2308 Nodes.Table (Old_Node).Has_Aspects := Old_Has_Aspects;
2310 Flags.Table (Old_Node).Check_Actuals := Old_CA;
2311 Flags.Table (Old_Node).Is_Ignored_Ghost_Node := Old_Is_IGN;
2313 if Nkind (New_Node) in N_Subexpr then
2314 Set_Paren_Count (Old_Node, Old_Paren_Count);
2315 Set_Must_Not_Freeze (Old_Node, Old_Must_Not_Freeze);
2318 Fix_Parents (Ref_Node => New_Node, Fix_Node => Old_Node);
2320 -- Invoke the reporting procedure (if available)
2322 if Reporting_Proc /= null then
2323 Reporting_Proc.all (Target => Old_Node, Source => New_Node);
2326 -- Invoke the rewriting procedure (if available)
2328 if Rewriting_Proc /= null then
2329 Rewriting_Proc.all (Target => Old_Node, Source => New_Node);
2337 procedure Set_Analyzed (N : Node_Id; Val : Boolean := True) is
2339 pragma Assert (not Locked);
2340 Nodes.Table (N).Analyzed := Val;
2343 -----------------------
2344 -- Set_Check_Actuals --
2345 -----------------------
2347 procedure Set_Check_Actuals (N : Node_Id; Val : Boolean := True) is
2349 pragma Assert (not Locked);
2350 Flags.Table (N).Check_Actuals := Val;
2351 end Set_Check_Actuals;
2353 ---------------------------
2354 -- Set_Comes_From_Source --
2355 ---------------------------
2357 procedure Set_Comes_From_Source (N : Node_Id; Val : Boolean) is
2359 pragma Assert (not Locked);
2360 pragma Assert (N <= Nodes.Last);
2361 Nodes.Table (N).Comes_From_Source := Val;
2362 end Set_Comes_From_Source;
2364 -----------------------------------
2365 -- Set_Comes_From_Source_Default --
2366 -----------------------------------
2368 procedure Set_Comes_From_Source_Default (Default : Boolean) is
2370 Default_Node.Comes_From_Source := Default;
2371 end Set_Comes_From_Source_Default;
2377 procedure Set_Ekind (E : Entity_Id; Val : Entity_Kind) is
2379 pragma Assert (not Locked);
2380 pragma Assert (Nkind (E) in N_Entity);
2381 Nodes.Table (E + 1).Nkind := E_To_N (Val);
2384 ----------------------
2385 -- Set_Error_Posted --
2386 ----------------------
2388 procedure Set_Error_Posted (N : Node_Id; Val : Boolean := True) is
2390 pragma Assert (not Locked);
2391 Nodes.Table (N).Error_Posted := Val;
2392 end Set_Error_Posted;
2394 ---------------------
2395 -- Set_Has_Aspects --
2396 ---------------------
2398 procedure Set_Has_Aspects (N : Node_Id; Val : Boolean := True) is
2400 pragma Assert (not Locked);
2401 pragma Assert (N <= Nodes.Last);
2402 Nodes.Table (N).Has_Aspects := Val;
2403 end Set_Has_Aspects;
2405 --------------------------------------
2406 -- Set_Ignored_Ghost_Recording_Proc --
2407 --------------------------------------
2409 procedure Set_Ignored_Ghost_Recording_Proc
2410 (Proc : Ignored_Ghost_Record_Proc)
2413 pragma Assert (Ignored_Ghost_Recording_Proc = null);
2414 Ignored_Ghost_Recording_Proc := Proc;
2415 end Set_Ignored_Ghost_Recording_Proc;
2417 -------------------------------
2418 -- Set_Is_Ignored_Ghost_Node --
2419 -------------------------------
2421 procedure Set_Is_Ignored_Ghost_Node (N : Node_Id; Val : Boolean := True) is
2423 pragma Assert (not Locked);
2424 Flags.Table (N).Is_Ignored_Ghost_Node := Val;
2425 end Set_Is_Ignored_Ghost_Node;
2427 -----------------------
2428 -- Set_Original_Node --
2429 -----------------------
2431 procedure Set_Original_Node (N : Node_Id; Val : Node_Id) is
2433 pragma Assert (not Locked);
2434 Orig_Nodes.Table (N) := Val;
2435 end Set_Original_Node;
2437 ---------------------
2438 -- Set_Paren_Count --
2439 ---------------------
2441 procedure Set_Paren_Count (N : Node_Id; Val : Nat) is
2443 pragma Assert (not Locked);
2444 pragma Assert (Nkind (N) in N_Subexpr);
2446 -- Value of 0,1,2 stored as is
2449 Nodes.Table (N).Pflag1 := (Val mod 2 /= 0);
2450 Nodes.Table (N).Pflag2 := (Val = 2);
2452 -- Value of 3 or greater stores 3 in node and makes table entry
2455 Nodes.Table (N).Pflag1 := True;
2456 Nodes.Table (N).Pflag2 := True;
2458 for J in Paren_Counts.First .. Paren_Counts.Last loop
2459 if N = Paren_Counts.Table (J).Nod then
2460 Paren_Counts.Table (J).Count := Val;
2465 Paren_Counts.Append ((Nod => N, Count => Val));
2467 end Set_Paren_Count;
2473 procedure Set_Parent (N : Node_Id; Val : Node_Id) is
2475 pragma Assert (not Locked);
2476 pragma Assert (not Nodes.Table (N).In_List);
2477 Nodes.Table (N).Link := Union_Id (Val);
2480 ------------------------
2481 -- Set_Reporting_Proc --
2482 ------------------------
2484 procedure Set_Reporting_Proc (Proc : Report_Proc) is
2486 pragma Assert (Reporting_Proc = null);
2487 Reporting_Proc := Proc;
2488 end Set_Reporting_Proc;
2494 procedure Set_Sloc (N : Node_Id; Val : Source_Ptr) is
2496 pragma Assert (not Locked);
2497 Nodes.Table (N).Sloc := Val;
2500 ------------------------
2501 -- Set_Rewriting_Proc --
2502 ------------------------
2504 procedure Set_Rewriting_Proc (Proc : Rewrite_Proc) is
2506 pragma Assert (Rewriting_Proc = null);
2507 Rewriting_Proc := Proc;
2508 end Set_Rewriting_Proc;
2514 function Sloc (N : Node_Id) return Source_Ptr is
2516 return Nodes.Table (N).Sloc;
2523 function Traverse_Func (Node : Node_Id) return Traverse_Final_Result is
2525 function Traverse_Field
2528 FN : Field_Num) return Traverse_Final_Result;
2529 -- Fld is one of the fields of Nod. If the field points to syntactic
2530 -- node or list, then this node or list is traversed, and the result is
2531 -- the result of this traversal. Otherwise a value of True is returned
2532 -- with no processing. FN is the number of the field (1 .. 5).
2534 --------------------
2535 -- Traverse_Field --
2536 --------------------
2538 function Traverse_Field
2541 FN : Field_Num) return Traverse_Final_Result
2544 if Fld = Union_Id (Empty) then
2547 -- Descendant is a node
2549 elsif Fld in Node_Range then
2551 -- Traverse descendant that is syntactic subtree node
2553 if Is_Syntactic_Field (Nkind (Nod), FN) then
2554 return Traverse_Func (Node_Id (Fld));
2556 -- Node that is not a syntactic subtree
2562 -- Descendant is a list
2564 elsif Fld in List_Range then
2566 -- Traverse descendant that is a syntactic subtree list
2568 if Is_Syntactic_Field (Nkind (Nod), FN) then
2570 Elmt : Node_Id := First (List_Id (Fld));
2573 while Present (Elmt) loop
2574 if Traverse_Func (Elmt) = Abandon then
2584 -- List that is not a syntactic subtree
2590 -- Field was not a node or a list
2597 Cur_Node : Node_Id := Node;
2599 -- Start of processing for Traverse_Func
2602 -- We walk Field2 last, and if it is a node, we eliminate the tail
2603 -- recursion by jumping back to this label. This is because Field2 is
2604 -- where the Left_Opnd field of N_Op_Concat is stored, and in practice
2605 -- concatenations are sometimes deeply nested, as in X1&X2&...&XN. This
2606 -- trick prevents us from running out of memory in that case. We don't
2607 -- bother eliminating the tail recursion if Field2 is a list.
2611 case Process (Cur_Node) is
2622 Cur_Node := Original_Node (Cur_Node);
2625 if Traverse_Field (Cur_Node, Field1 (Cur_Node), 1) = Abandon
2626 or else -- skip Field2 here
2627 Traverse_Field (Cur_Node, Field3 (Cur_Node), 3) = Abandon
2629 Traverse_Field (Cur_Node, Field4 (Cur_Node), 4) = Abandon
2631 Traverse_Field (Cur_Node, Field5 (Cur_Node), 5) = Abandon
2636 if Field2 (Cur_Node) not in Node_Range then
2637 return Traverse_Field (Cur_Node, Field2 (Cur_Node), 2);
2639 elsif Is_Syntactic_Field (Nkind (Cur_Node), 2)
2640 and then Field2 (Cur_Node) /= Empty_List_Or_Node
2642 -- Here is the tail recursion step, we reset Cur_Node and jump back
2643 -- to the start of the procedure, which has the same semantic effect
2646 Cur_Node := Node_Id (Field2 (Cur_Node));
2657 procedure Traverse_Proc (Node : Node_Id) is
2658 function Traverse is new Traverse_Func (Process);
2659 Discard : Traverse_Final_Result;
2660 pragma Warnings (Off, Discard);
2662 Discard := Traverse (Node);
2669 procedure Tree_Read is
2671 Tree_Read_Int (Node_Count);
2674 Orig_Nodes.Tree_Read;
2675 Paren_Counts.Tree_Read;
2682 procedure Tree_Write is
2684 Tree_Write_Int (Node_Count);
2687 Orig_Nodes.Tree_Write;
2688 Paren_Counts.Tree_Write;
2691 ------------------------------
2692 -- Unchecked Access Package --
2693 ------------------------------
2695 package body Unchecked_Access is
2697 function Field1 (N : Node_Id) return Union_Id is
2699 pragma Assert (N <= Nodes.Last);
2700 return Nodes.Table (N).Field1;
2703 function Field2 (N : Node_Id) return Union_Id is
2705 pragma Assert (N <= Nodes.Last);
2706 return Nodes.Table (N).Field2;
2709 function Field3 (N : Node_Id) return Union_Id is
2711 pragma Assert (N <= Nodes.Last);
2712 return Nodes.Table (N).Field3;
2715 function Field4 (N : Node_Id) return Union_Id is
2717 pragma Assert (N <= Nodes.Last);
2718 return Nodes.Table (N).Field4;
2721 function Field5 (N : Node_Id) return Union_Id is
2723 pragma Assert (N <= Nodes.Last);
2724 return Nodes.Table (N).Field5;
2727 function Field6 (N : Node_Id) return Union_Id is
2729 pragma Assert (Nkind (N) in N_Entity);
2730 return Nodes.Table (N + 1).Field6;
2733 function Field7 (N : Node_Id) return Union_Id is
2735 pragma Assert (Nkind (N) in N_Entity);
2736 return Nodes.Table (N + 1).Field7;
2739 function Field8 (N : Node_Id) return Union_Id is
2741 pragma Assert (Nkind (N) in N_Entity);
2742 return Nodes.Table (N + 1).Field8;
2745 function Field9 (N : Node_Id) return Union_Id is
2747 pragma Assert (Nkind (N) in N_Entity);
2748 return Nodes.Table (N + 1).Field9;
2751 function Field10 (N : Node_Id) return Union_Id is
2753 pragma Assert (Nkind (N) in N_Entity);
2754 return Nodes.Table (N + 1).Field10;
2757 function Field11 (N : Node_Id) return Union_Id is
2759 pragma Assert (Nkind (N) in N_Entity);
2760 return Nodes.Table (N + 1).Field11;
2763 function Field12 (N : Node_Id) return Union_Id is
2765 pragma Assert (Nkind (N) in N_Entity);
2766 return Nodes.Table (N + 1).Field12;
2769 function Field13 (N : Node_Id) return Union_Id is
2771 pragma Assert (Nkind (N) in N_Entity);
2772 return Nodes.Table (N + 2).Field6;
2775 function Field14 (N : Node_Id) return Union_Id is
2777 pragma Assert (Nkind (N) in N_Entity);
2778 return Nodes.Table (N + 2).Field7;
2781 function Field15 (N : Node_Id) return Union_Id is
2783 pragma Assert (Nkind (N) in N_Entity);
2784 return Nodes.Table (N + 2).Field8;
2787 function Field16 (N : Node_Id) return Union_Id is
2789 pragma Assert (Nkind (N) in N_Entity);
2790 return Nodes.Table (N + 2).Field9;
2793 function Field17 (N : Node_Id) return Union_Id is
2795 pragma Assert (Nkind (N) in N_Entity);
2796 return Nodes.Table (N + 2).Field10;
2799 function Field18 (N : Node_Id) return Union_Id is
2801 pragma Assert (Nkind (N) in N_Entity);
2802 return Nodes.Table (N + 2).Field11;
2805 function Field19 (N : Node_Id) return Union_Id is
2807 pragma Assert (Nkind (N) in N_Entity);
2808 return Nodes.Table (N + 3).Field6;
2811 function Field20 (N : Node_Id) return Union_Id is
2813 pragma Assert (Nkind (N) in N_Entity);
2814 return Nodes.Table (N + 3).Field7;
2817 function Field21 (N : Node_Id) return Union_Id is
2819 pragma Assert (Nkind (N) in N_Entity);
2820 return Nodes.Table (N + 3).Field8;
2823 function Field22 (N : Node_Id) return Union_Id is
2825 pragma Assert (Nkind (N) in N_Entity);
2826 return Nodes.Table (N + 3).Field9;
2829 function Field23 (N : Node_Id) return Union_Id is
2831 pragma Assert (Nkind (N) in N_Entity);
2832 return Nodes.Table (N + 3).Field10;
2835 function Field24 (N : Node_Id) return Union_Id is
2837 pragma Assert (Nkind (N) in N_Entity);
2838 return Nodes.Table (N + 4).Field6;
2841 function Field25 (N : Node_Id) return Union_Id is
2843 pragma Assert (Nkind (N) in N_Entity);
2844 return Nodes.Table (N + 4).Field7;
2847 function Field26 (N : Node_Id) return Union_Id is
2849 pragma Assert (Nkind (N) in N_Entity);
2850 return Nodes.Table (N + 4).Field8;
2853 function Field27 (N : Node_Id) return Union_Id is
2855 pragma Assert (Nkind (N) in N_Entity);
2856 return Nodes.Table (N + 4).Field9;
2859 function Field28 (N : Node_Id) return Union_Id is
2861 pragma Assert (Nkind (N) in N_Entity);
2862 return Nodes.Table (N + 4).Field10;
2865 function Field29 (N : Node_Id) return Union_Id is
2867 pragma Assert (Nkind (N) in N_Entity);
2868 return Nodes.Table (N + 4).Field11;
2871 function Field30 (N : Node_Id) return Union_Id is
2873 pragma Assert (Nkind (N) in N_Entity);
2874 return Nodes.Table (N + 5).Field6;
2877 function Field31 (N : Node_Id) return Union_Id is
2879 pragma Assert (Nkind (N) in N_Entity);
2880 return Nodes.Table (N + 5).Field7;
2883 function Field32 (N : Node_Id) return Union_Id is
2885 pragma Assert (Nkind (N) in N_Entity);
2886 return Nodes.Table (N + 5).Field8;
2889 function Field33 (N : Node_Id) return Union_Id is
2891 pragma Assert (Nkind (N) in N_Entity);
2892 return Nodes.Table (N + 5).Field9;
2895 function Field34 (N : Node_Id) return Union_Id is
2897 pragma Assert (Nkind (N) in N_Entity);
2898 return Nodes.Table (N + 5).Field10;
2901 function Field35 (N : Node_Id) return Union_Id is
2903 pragma Assert (Nkind (N) in N_Entity);
2904 return Nodes.Table (N + 5).Field11;
2907 function Field36 (N : Node_Id) return Union_Id is
2909 pragma Assert (Nkind (N) in N_Entity);
2910 return Nodes.Table (N + 6).Field6;
2913 function Field37 (N : Node_Id) return Union_Id is
2915 pragma Assert (Nkind (N) in N_Entity);
2916 return Nodes.Table (N + 6).Field7;
2919 function Field38 (N : Node_Id) return Union_Id is
2921 pragma Assert (Nkind (N) in N_Entity);
2922 return Nodes.Table (N + 6).Field8;
2925 function Field39 (N : Node_Id) return Union_Id is
2927 pragma Assert (Nkind (N) in N_Entity);
2928 return Nodes.Table (N + 6).Field9;
2931 function Field40 (N : Node_Id) return Union_Id is
2933 pragma Assert (Nkind (N) in N_Entity);
2934 return Nodes.Table (N + 6).Field10;
2937 function Field41 (N : Node_Id) return Union_Id is
2939 pragma Assert (Nkind (N) in N_Entity);
2940 return Nodes.Table (N + 6).Field11;
2943 function Node1 (N : Node_Id) return Node_Id is
2945 pragma Assert (N <= Nodes.Last);
2946 return Node_Id (Nodes.Table (N).Field1);
2949 function Node2 (N : Node_Id) return Node_Id is
2951 pragma Assert (N <= Nodes.Last);
2952 return Node_Id (Nodes.Table (N).Field2);
2955 function Node3 (N : Node_Id) return Node_Id is
2957 pragma Assert (N <= Nodes.Last);
2958 return Node_Id (Nodes.Table (N).Field3);
2961 function Node4 (N : Node_Id) return Node_Id is
2963 pragma Assert (N <= Nodes.Last);
2964 return Node_Id (Nodes.Table (N).Field4);
2967 function Node5 (N : Node_Id) return Node_Id is
2969 pragma Assert (N <= Nodes.Last);
2970 return Node_Id (Nodes.Table (N).Field5);
2973 function Node6 (N : Node_Id) return Node_Id is
2975 pragma Assert (Nkind (N) in N_Entity);
2976 return Node_Id (Nodes.Table (N + 1).Field6);
2979 function Node7 (N : Node_Id) return Node_Id is
2981 pragma Assert (Nkind (N) in N_Entity);
2982 return Node_Id (Nodes.Table (N + 1).Field7);
2985 function Node8 (N : Node_Id) return Node_Id is
2987 pragma Assert (Nkind (N) in N_Entity);
2988 return Node_Id (Nodes.Table (N + 1).Field8);
2991 function Node9 (N : Node_Id) return Node_Id is
2993 pragma Assert (Nkind (N) in N_Entity);
2994 return Node_Id (Nodes.Table (N + 1).Field9);
2997 function Node10 (N : Node_Id) return Node_Id is
2999 pragma Assert (Nkind (N) in N_Entity);
3000 return Node_Id (Nodes.Table (N + 1).Field10);
3003 function Node11 (N : Node_Id) return Node_Id is
3005 pragma Assert (Nkind (N) in N_Entity);
3006 return Node_Id (Nodes.Table (N + 1).Field11);
3009 function Node12 (N : Node_Id) return Node_Id is
3011 pragma Assert (Nkind (N) in N_Entity);
3012 return Node_Id (Nodes.Table (N + 1).Field12);
3015 function Node13 (N : Node_Id) return Node_Id is
3017 pragma Assert (Nkind (N) in N_Entity);
3018 return Node_Id (Nodes.Table (N + 2).Field6);
3021 function Node14 (N : Node_Id) return Node_Id is
3023 pragma Assert (Nkind (N) in N_Entity);
3024 return Node_Id (Nodes.Table (N + 2).Field7);
3027 function Node15 (N : Node_Id) return Node_Id is
3029 pragma Assert (Nkind (N) in N_Entity);
3030 return Node_Id (Nodes.Table (N + 2).Field8);
3033 function Node16 (N : Node_Id) return Node_Id is
3035 pragma Assert (Nkind (N) in N_Entity);
3036 return Node_Id (Nodes.Table (N + 2).Field9);
3039 function Node17 (N : Node_Id) return Node_Id is
3041 pragma Assert (Nkind (N) in N_Entity);
3042 return Node_Id (Nodes.Table (N + 2).Field10);
3045 function Node18 (N : Node_Id) return Node_Id is
3047 pragma Assert (Nkind (N) in N_Entity);
3048 return Node_Id (Nodes.Table (N + 2).Field11);
3051 function Node19 (N : Node_Id) return Node_Id is
3053 pragma Assert (Nkind (N) in N_Entity);
3054 return Node_Id (Nodes.Table (N + 3).Field6);
3057 function Node20 (N : Node_Id) return Node_Id is
3059 pragma Assert (Nkind (N) in N_Entity);
3060 return Node_Id (Nodes.Table (N + 3).Field7);
3063 function Node21 (N : Node_Id) return Node_Id is
3065 pragma Assert (Nkind (N) in N_Entity);
3066 return Node_Id (Nodes.Table (N + 3).Field8);
3069 function Node22 (N : Node_Id) return Node_Id is
3071 pragma Assert (Nkind (N) in N_Entity);
3072 return Node_Id (Nodes.Table (N + 3).Field9);
3075 function Node23 (N : Node_Id) return Node_Id is
3077 pragma Assert (Nkind (N) in N_Entity);
3078 return Node_Id (Nodes.Table (N + 3).Field10);
3081 function Node24 (N : Node_Id) return Node_Id is
3083 pragma Assert (Nkind (N) in N_Entity);
3084 return Node_Id (Nodes.Table (N + 4).Field6);
3087 function Node25 (N : Node_Id) return Node_Id is
3089 pragma Assert (Nkind (N) in N_Entity);
3090 return Node_Id (Nodes.Table (N + 4).Field7);
3093 function Node26 (N : Node_Id) return Node_Id is
3095 pragma Assert (Nkind (N) in N_Entity);
3096 return Node_Id (Nodes.Table (N + 4).Field8);
3099 function Node27 (N : Node_Id) return Node_Id is
3101 pragma Assert (Nkind (N) in N_Entity);
3102 return Node_Id (Nodes.Table (N + 4).Field9);
3105 function Node28 (N : Node_Id) return Node_Id is
3107 pragma Assert (Nkind (N) in N_Entity);
3108 return Node_Id (Nodes.Table (N + 4).Field10);
3111 function Node29 (N : Node_Id) return Node_Id is
3113 pragma Assert (Nkind (N) in N_Entity);
3114 return Node_Id (Nodes.Table (N + 4).Field11);
3117 function Node30 (N : Node_Id) return Node_Id is
3119 pragma Assert (Nkind (N) in N_Entity);
3120 return Node_Id (Nodes.Table (N + 5).Field6);
3123 function Node31 (N : Node_Id) return Node_Id is
3125 pragma Assert (Nkind (N) in N_Entity);
3126 return Node_Id (Nodes.Table (N + 5).Field7);
3129 function Node32 (N : Node_Id) return Node_Id is
3131 pragma Assert (Nkind (N) in N_Entity);
3132 return Node_Id (Nodes.Table (N + 5).Field8);
3135 function Node33 (N : Node_Id) return Node_Id is
3137 pragma Assert (Nkind (N) in N_Entity);
3138 return Node_Id (Nodes.Table (N + 5).Field9);
3141 function Node34 (N : Node_Id) return Node_Id is
3143 pragma Assert (Nkind (N) in N_Entity);
3144 return Node_Id (Nodes.Table (N + 5).Field10);
3147 function Node35 (N : Node_Id) return Node_Id is
3149 pragma Assert (Nkind (N) in N_Entity);
3150 return Node_Id (Nodes.Table (N + 5).Field11);
3153 function Node36 (N : Node_Id) return Node_Id is
3155 pragma Assert (Nkind (N) in N_Entity);
3156 return Node_Id (Nodes.Table (N + 6).Field6);
3159 function Node37 (N : Node_Id) return Node_Id is
3161 pragma Assert (Nkind (N) in N_Entity);
3162 return Node_Id (Nodes.Table (N + 6).Field7);
3165 function Node38 (N : Node_Id) return Node_Id is
3167 pragma Assert (Nkind (N) in N_Entity);
3168 return Node_Id (Nodes.Table (N + 6).Field8);
3171 function Node39 (N : Node_Id) return Node_Id is
3173 pragma Assert (Nkind (N) in N_Entity);
3174 return Node_Id (Nodes.Table (N + 6).Field9);
3177 function Node40 (N : Node_Id) return Node_Id is
3179 pragma Assert (Nkind (N) in N_Entity);
3180 return Node_Id (Nodes.Table (N + 6).Field10);
3183 function Node41 (N : Node_Id) return Node_Id is
3185 pragma Assert (Nkind (N) in N_Entity);
3186 return Node_Id (Nodes.Table (N + 6).Field11);
3189 function List1 (N : Node_Id) return List_Id is
3191 pragma Assert (N <= Nodes.Last);
3192 return List_Id (Nodes.Table (N).Field1);
3195 function List2 (N : Node_Id) return List_Id is
3197 pragma Assert (N <= Nodes.Last);
3198 return List_Id (Nodes.Table (N).Field2);
3201 function List3 (N : Node_Id) return List_Id is
3203 pragma Assert (N <= Nodes.Last);
3204 return List_Id (Nodes.Table (N).Field3);
3207 function List4 (N : Node_Id) return List_Id is
3209 pragma Assert (N <= Nodes.Last);
3210 return List_Id (Nodes.Table (N).Field4);
3213 function List5 (N : Node_Id) return List_Id is
3215 pragma Assert (N <= Nodes.Last);
3216 return List_Id (Nodes.Table (N).Field5);
3219 function List10 (N : Node_Id) return List_Id is
3221 pragma Assert (Nkind (N) in N_Entity);
3222 return List_Id (Nodes.Table (N + 1).Field10);
3225 function List14 (N : Node_Id) return List_Id is
3227 pragma Assert (Nkind (N) in N_Entity);
3228 return List_Id (Nodes.Table (N + 2).Field7);
3231 function List25 (N : Node_Id) return List_Id is
3233 pragma Assert (Nkind (N) in N_Entity);
3234 return List_Id (Nodes.Table (N + 4).Field7);
3237 function List38 (N : Node_Id) return List_Id is
3239 return List_Id (Nodes.Table (N + 6).Field8);
3242 function List39 (N : Node_Id) return List_Id is
3244 return List_Id (Nodes.Table (N + 6).Field9);
3247 function Elist1 (N : Node_Id) return Elist_Id is
3248 pragma Assert (N <= Nodes.Last);
3249 Value : constant Union_Id := Nodes.Table (N).Field1;
3254 return Elist_Id (Value);
3258 function Elist2 (N : Node_Id) return Elist_Id is
3259 pragma Assert (N <= Nodes.Last);
3260 Value : constant Union_Id := Nodes.Table (N).Field2;
3265 return Elist_Id (Value);
3269 function Elist3 (N : Node_Id) return Elist_Id is
3270 pragma Assert (N <= Nodes.Last);
3271 Value : constant Union_Id := Nodes.Table (N).Field3;
3276 return Elist_Id (Value);
3280 function Elist4 (N : Node_Id) return Elist_Id is
3281 pragma Assert (N <= Nodes.Last);
3282 Value : constant Union_Id := Nodes.Table (N).Field4;
3287 return Elist_Id (Value);
3291 function Elist5 (N : Node_Id) return Elist_Id is
3292 pragma Assert (N <= Nodes.Last);
3293 Value : constant Union_Id := Nodes.Table (N).Field5;
3298 return Elist_Id (Value);
3302 function Elist8 (N : Node_Id) return Elist_Id is
3303 pragma Assert (Nkind (N) in N_Entity);
3304 Value : constant Union_Id := Nodes.Table (N + 1).Field8;
3309 return Elist_Id (Value);
3313 function Elist9 (N : Node_Id) return Elist_Id is
3314 pragma Assert (Nkind (N) in N_Entity);
3315 Value : constant Union_Id := Nodes.Table (N + 1).Field9;
3320 return Elist_Id (Value);
3324 function Elist10 (N : Node_Id) return Elist_Id is
3325 pragma Assert (Nkind (N) in N_Entity);
3326 Value : constant Union_Id := Nodes.Table (N + 1).Field10;
3331 return Elist_Id (Value);
3335 function Elist11 (N : Node_Id) return Elist_Id is
3336 pragma Assert (Nkind (N) in N_Entity);
3337 Value : constant Union_Id := Nodes.Table (N + 1).Field11;
3342 return Elist_Id (Value);
3346 function Elist13 (N : Node_Id) return Elist_Id is
3347 pragma Assert (Nkind (N) in N_Entity);
3348 Value : constant Union_Id := Nodes.Table (N + 2).Field6;
3353 return Elist_Id (Value);
3357 function Elist15 (N : Node_Id) return Elist_Id is
3358 pragma Assert (Nkind (N) in N_Entity);
3359 Value : constant Union_Id := Nodes.Table (N + 2).Field8;
3364 return Elist_Id (Value);
3368 function Elist16 (N : Node_Id) return Elist_Id is
3369 pragma Assert (Nkind (N) in N_Entity);
3370 Value : constant Union_Id := Nodes.Table (N + 2).Field9;
3375 return Elist_Id (Value);
3379 function Elist18 (N : Node_Id) return Elist_Id is
3380 pragma Assert (Nkind (N) in N_Entity);
3381 Value : constant Union_Id := Nodes.Table (N + 2).Field11;
3386 return Elist_Id (Value);
3390 function Elist21 (N : Node_Id) return Elist_Id is
3391 pragma Assert (Nkind (N) in N_Entity);
3392 Value : constant Union_Id := Nodes.Table (N + 3).Field8;
3397 return Elist_Id (Value);
3401 function Elist23 (N : Node_Id) return Elist_Id is
3402 pragma Assert (Nkind (N) in N_Entity);
3403 Value : constant Union_Id := Nodes.Table (N + 3).Field10;
3408 return Elist_Id (Value);
3412 function Elist24 (N : Node_Id) return Elist_Id is
3413 pragma Assert (Nkind (N) in N_Entity);
3414 Value : constant Union_Id := Nodes.Table (N + 4).Field6;
3419 return Elist_Id (Value);
3423 function Elist25 (N : Node_Id) return Elist_Id is
3424 pragma Assert (Nkind (N) in N_Entity);
3425 Value : constant Union_Id := Nodes.Table (N + 4).Field7;
3430 return Elist_Id (Value);
3434 function Elist26 (N : Node_Id) return Elist_Id is
3435 pragma Assert (Nkind (N) in N_Entity);
3436 Value : constant Union_Id := Nodes.Table (N + 4).Field8;
3441 return Elist_Id (Value);
3445 function Elist29 (N : Node_Id) return Elist_Id is
3446 pragma Assert (Nkind (N) in N_Entity);
3447 Value : constant Union_Id := Nodes.Table (N + 4).Field11;
3452 return Elist_Id (Value);
3456 function Elist30 (N : Node_Id) return Elist_Id is
3457 pragma Assert (Nkind (N) in N_Entity);
3458 Value : constant Union_Id := Nodes.Table (N + 5).Field6;
3463 return Elist_Id (Value);
3467 function Elist36 (N : Node_Id) return Elist_Id is
3468 pragma Assert (Nkind (N) in N_Entity);
3469 Value : constant Union_Id := Nodes.Table (N + 6).Field6;
3474 return Elist_Id (Value);
3478 function Name1 (N : Node_Id) return Name_Id is
3480 pragma Assert (N <= Nodes.Last);
3481 return Name_Id (Nodes.Table (N).Field1);
3484 function Name2 (N : Node_Id) return Name_Id is
3486 pragma Assert (N <= Nodes.Last);
3487 return Name_Id (Nodes.Table (N).Field2);
3490 function Str3 (N : Node_Id) return String_Id is
3492 pragma Assert (N <= Nodes.Last);
3493 return String_Id (Nodes.Table (N).Field3);
3496 function Uint2 (N : Node_Id) return Uint is
3497 pragma Assert (N <= Nodes.Last);
3498 U : constant Union_Id := Nodes.Table (N).Field2;
3503 return From_Union (U);
3507 function Uint3 (N : Node_Id) return Uint is
3508 pragma Assert (N <= Nodes.Last);
3509 U : constant Union_Id := Nodes.Table (N).Field3;
3514 return From_Union (U);
3518 function Uint4 (N : Node_Id) return Uint is
3519 pragma Assert (N <= Nodes.Last);
3520 U : constant Union_Id := Nodes.Table (N).Field4;
3525 return From_Union (U);
3529 function Uint5 (N : Node_Id) return Uint is
3530 pragma Assert (N <= Nodes.Last);
3531 U : constant Union_Id := Nodes.Table (N).Field5;
3536 return From_Union (U);
3540 function Uint8 (N : Node_Id) return Uint is
3541 pragma Assert (Nkind (N) in N_Entity);
3542 U : constant Union_Id := Nodes.Table (N + 1).Field8;
3547 return From_Union (U);
3551 function Uint9 (N : Node_Id) return Uint is
3552 pragma Assert (Nkind (N) in N_Entity);
3553 U : constant Union_Id := Nodes.Table (N + 1).Field9;
3558 return From_Union (U);
3562 function Uint10 (N : Node_Id) return Uint is
3563 pragma Assert (Nkind (N) in N_Entity);
3564 U : constant Union_Id := Nodes.Table (N + 1).Field10;
3569 return From_Union (U);
3573 function Uint11 (N : Node_Id) return Uint is
3574 pragma Assert (Nkind (N) in N_Entity);
3575 U : constant Union_Id := Nodes.Table (N + 1).Field11;
3580 return From_Union (U);
3584 function Uint12 (N : Node_Id) return Uint is
3585 pragma Assert (Nkind (N) in N_Entity);
3586 U : constant Union_Id := Nodes.Table (N + 1).Field12;
3591 return From_Union (U);
3595 function Uint13 (N : Node_Id) return Uint is
3596 pragma Assert (Nkind (N) in N_Entity);
3597 U : constant Union_Id := Nodes.Table (N + 2).Field6;
3602 return From_Union (U);
3606 function Uint14 (N : Node_Id) return Uint is
3607 pragma Assert (Nkind (N) in N_Entity);
3608 U : constant Union_Id := Nodes.Table (N + 2).Field7;
3613 return From_Union (U);
3617 function Uint15 (N : Node_Id) return Uint is
3618 pragma Assert (Nkind (N) in N_Entity);
3619 U : constant Union_Id := Nodes.Table (N + 2).Field8;
3624 return From_Union (U);
3628 function Uint16 (N : Node_Id) return Uint is
3629 pragma Assert (Nkind (N) in N_Entity);
3630 U : constant Union_Id := Nodes.Table (N + 2).Field9;
3635 return From_Union (U);
3639 function Uint17 (N : Node_Id) return Uint is
3640 pragma Assert (Nkind (N) in N_Entity);
3641 U : constant Union_Id := Nodes.Table (N + 2).Field10;
3646 return From_Union (U);
3650 function Uint22 (N : Node_Id) return Uint is
3651 pragma Assert (Nkind (N) in N_Entity);
3652 U : constant Union_Id := Nodes.Table (N + 3).Field9;
3657 return From_Union (U);
3661 function Uint24 (N : Node_Id) return Uint is
3662 pragma Assert (Nkind (N) in N_Entity);
3663 U : constant Union_Id := Nodes.Table (N + 4).Field6;
3668 return From_Union (U);
3672 function Ureal3 (N : Node_Id) return Ureal is
3674 pragma Assert (N <= Nodes.Last);
3675 return From_Union (Nodes.Table (N).Field3);
3678 function Ureal18 (N : Node_Id) return Ureal is
3680 pragma Assert (Nkind (N) in N_Entity);
3681 return From_Union (Nodes.Table (N + 2).Field11);
3684 function Ureal21 (N : Node_Id) return Ureal is
3686 pragma Assert (Nkind (N) in N_Entity);
3687 return From_Union (Nodes.Table (N + 3).Field8);
3690 function Flag0 (N : Node_Id) return Boolean is
3692 pragma Assert (N <= Nodes.Last);
3693 return Flags.Table (N).Flag0;
3696 function Flag1 (N : Node_Id) return Boolean is
3698 pragma Assert (N <= Nodes.Last);
3699 return Flags.Table (N).Flag1;
3702 function Flag2 (N : Node_Id) return Boolean is
3704 pragma Assert (N <= Nodes.Last);
3705 return Flags.Table (N).Flag2;
3708 function Flag3 (N : Node_Id) return Boolean is
3710 pragma Assert (N <= Nodes.Last);
3711 return Flags.Table (N).Flag3;
3714 function Flag4 (N : Node_Id) return Boolean is
3716 pragma Assert (N <= Nodes.Last);
3717 return Nodes.Table (N).Flag4;
3720 function Flag5 (N : Node_Id) return Boolean is
3722 pragma Assert (N <= Nodes.Last);
3723 return Nodes.Table (N).Flag5;
3726 function Flag6 (N : Node_Id) return Boolean is
3728 pragma Assert (N <= Nodes.Last);
3729 return Nodes.Table (N).Flag6;
3732 function Flag7 (N : Node_Id) return Boolean is
3734 pragma Assert (N <= Nodes.Last);
3735 return Nodes.Table (N).Flag7;
3738 function Flag8 (N : Node_Id) return Boolean is
3740 pragma Assert (N <= Nodes.Last);
3741 return Nodes.Table (N).Flag8;
3744 function Flag9 (N : Node_Id) return Boolean is
3746 pragma Assert (N <= Nodes.Last);
3747 return Nodes.Table (N).Flag9;
3750 function Flag10 (N : Node_Id) return Boolean is
3752 pragma Assert (N <= Nodes.Last);
3753 return Nodes.Table (N).Flag10;
3756 function Flag11 (N : Node_Id) return Boolean is
3758 pragma Assert (N <= Nodes.Last);
3759 return Nodes.Table (N).Flag11;
3762 function Flag12 (N : Node_Id) return Boolean is
3764 pragma Assert (N <= Nodes.Last);
3765 return Nodes.Table (N).Flag12;
3768 function Flag13 (N : Node_Id) return Boolean is
3770 pragma Assert (N <= Nodes.Last);
3771 return Nodes.Table (N).Flag13;
3774 function Flag14 (N : Node_Id) return Boolean is
3776 pragma Assert (N <= Nodes.Last);
3777 return Nodes.Table (N).Flag14;
3780 function Flag15 (N : Node_Id) return Boolean is
3782 pragma Assert (N <= Nodes.Last);
3783 return Nodes.Table (N).Flag15;
3786 function Flag16 (N : Node_Id) return Boolean is
3788 pragma Assert (N <= Nodes.Last);
3789 return Nodes.Table (N).Flag16;
3792 function Flag17 (N : Node_Id) return Boolean is
3794 pragma Assert (N <= Nodes.Last);
3795 return Nodes.Table (N).Flag17;
3798 function Flag18 (N : Node_Id) return Boolean is
3800 pragma Assert (N <= Nodes.Last);
3801 return Nodes.Table (N).Flag18;
3804 function Flag19 (N : Node_Id) return Boolean is
3806 pragma Assert (Nkind (N) in N_Entity);
3807 return Nodes.Table (N + 1).In_List;
3810 function Flag20 (N : Node_Id) return Boolean is
3812 pragma Assert (Nkind (N) in N_Entity);
3813 return Nodes.Table (N + 1).Has_Aspects;
3816 function Flag21 (N : Node_Id) return Boolean is
3818 pragma Assert (Nkind (N) in N_Entity);
3819 return Nodes.Table (N + 1).Rewrite_Ins;
3822 function Flag22 (N : Node_Id) return Boolean is
3824 pragma Assert (Nkind (N) in N_Entity);
3825 return Nodes.Table (N + 1).Analyzed;
3828 function Flag23 (N : Node_Id) return Boolean is
3830 pragma Assert (Nkind (N) in N_Entity);
3831 return Nodes.Table (N + 1).Comes_From_Source;
3834 function Flag24 (N : Node_Id) return Boolean is
3836 pragma Assert (Nkind (N) in N_Entity);
3837 return Nodes.Table (N + 1).Error_Posted;
3840 function Flag25 (N : Node_Id) return Boolean is
3842 pragma Assert (Nkind (N) in N_Entity);
3843 return Nodes.Table (N + 1).Flag4;
3846 function Flag26 (N : Node_Id) return Boolean is
3848 pragma Assert (Nkind (N) in N_Entity);
3849 return Nodes.Table (N + 1).Flag5;
3852 function Flag27 (N : Node_Id) return Boolean is
3854 pragma Assert (Nkind (N) in N_Entity);
3855 return Nodes.Table (N + 1).Flag6;
3858 function Flag28 (N : Node_Id) return Boolean is
3860 pragma Assert (Nkind (N) in N_Entity);
3861 return Nodes.Table (N + 1).Flag7;
3864 function Flag29 (N : Node_Id) return Boolean is
3866 pragma Assert (Nkind (N) in N_Entity);
3867 return Nodes.Table (N + 1).Flag8;
3870 function Flag30 (N : Node_Id) return Boolean is
3872 pragma Assert (Nkind (N) in N_Entity);
3873 return Nodes.Table (N + 1).Flag9;
3876 function Flag31 (N : Node_Id) return Boolean is
3878 pragma Assert (Nkind (N) in N_Entity);
3879 return Nodes.Table (N + 1).Flag10;
3882 function Flag32 (N : Node_Id) return Boolean is
3884 pragma Assert (Nkind (N) in N_Entity);
3885 return Nodes.Table (N + 1).Flag11;
3888 function Flag33 (N : Node_Id) return Boolean is
3890 pragma Assert (Nkind (N) in N_Entity);
3891 return Nodes.Table (N + 1).Flag12;
3894 function Flag34 (N : Node_Id) return Boolean is
3896 pragma Assert (Nkind (N) in N_Entity);
3897 return Nodes.Table (N + 1).Flag13;
3900 function Flag35 (N : Node_Id) return Boolean is
3902 pragma Assert (Nkind (N) in N_Entity);
3903 return Nodes.Table (N + 1).Flag14;
3906 function Flag36 (N : Node_Id) return Boolean is
3908 pragma Assert (Nkind (N) in N_Entity);
3909 return Nodes.Table (N + 1).Flag15;
3912 function Flag37 (N : Node_Id) return Boolean is
3914 pragma Assert (Nkind (N) in N_Entity);
3915 return Nodes.Table (N + 1).Flag16;
3918 function Flag38 (N : Node_Id) return Boolean is
3920 pragma Assert (Nkind (N) in N_Entity);
3921 return Nodes.Table (N + 1).Flag17;
3924 function Flag39 (N : Node_Id) return Boolean is
3926 pragma Assert (Nkind (N) in N_Entity);
3927 return Nodes.Table (N + 1).Flag18;
3930 function Flag40 (N : Node_Id) return Boolean is
3932 pragma Assert (Nkind (N) in N_Entity);
3933 return Nodes.Table (N + 2).In_List;
3936 function Flag41 (N : Node_Id) return Boolean is
3938 pragma Assert (Nkind (N) in N_Entity);
3939 return Nodes.Table (N + 2).Has_Aspects;
3942 function Flag42 (N : Node_Id) return Boolean is
3944 pragma Assert (Nkind (N) in N_Entity);
3945 return Nodes.Table (N + 2).Rewrite_Ins;
3948 function Flag43 (N : Node_Id) return Boolean is
3950 pragma Assert (Nkind (N) in N_Entity);
3951 return Nodes.Table (N + 2).Analyzed;
3954 function Flag44 (N : Node_Id) return Boolean is
3956 pragma Assert (Nkind (N) in N_Entity);
3957 return Nodes.Table (N + 2).Comes_From_Source;
3960 function Flag45 (N : Node_Id) return Boolean is
3962 pragma Assert (Nkind (N) in N_Entity);
3963 return Nodes.Table (N + 2).Error_Posted;
3966 function Flag46 (N : Node_Id) return Boolean is
3968 pragma Assert (Nkind (N) in N_Entity);
3969 return Nodes.Table (N + 2).Flag4;
3972 function Flag47 (N : Node_Id) return Boolean is
3974 pragma Assert (Nkind (N) in N_Entity);
3975 return Nodes.Table (N + 2).Flag5;
3978 function Flag48 (N : Node_Id) return Boolean is
3980 pragma Assert (Nkind (N) in N_Entity);
3981 return Nodes.Table (N + 2).Flag6;
3984 function Flag49 (N : Node_Id) return Boolean is
3986 pragma Assert (Nkind (N) in N_Entity);
3987 return Nodes.Table (N + 2).Flag7;
3990 function Flag50 (N : Node_Id) return Boolean is
3992 pragma Assert (Nkind (N) in N_Entity);
3993 return Nodes.Table (N + 2).Flag8;
3996 function Flag51 (N : Node_Id) return Boolean is
3998 pragma Assert (Nkind (N) in N_Entity);
3999 return Nodes.Table (N + 2).Flag9;
4002 function Flag52 (N : Node_Id) return Boolean is
4004 pragma Assert (Nkind (N) in N_Entity);
4005 return Nodes.Table (N + 2).Flag10;
4008 function Flag53 (N : Node_Id) return Boolean is
4010 pragma Assert (Nkind (N) in N_Entity);
4011 return Nodes.Table (N + 2).Flag11;
4014 function Flag54 (N : Node_Id) return Boolean is
4016 pragma Assert (Nkind (N) in N_Entity);
4017 return Nodes.Table (N + 2).Flag12;
4020 function Flag55 (N : Node_Id) return Boolean is
4022 pragma Assert (Nkind (N) in N_Entity);
4023 return Nodes.Table (N + 2).Flag13;
4026 function Flag56 (N : Node_Id) return Boolean is
4028 pragma Assert (Nkind (N) in N_Entity);
4029 return Nodes.Table (N + 2).Flag14;
4032 function Flag57 (N : Node_Id) return Boolean is
4034 pragma Assert (Nkind (N) in N_Entity);
4035 return Nodes.Table (N + 2).Flag15;
4038 function Flag58 (N : Node_Id) return Boolean is
4040 pragma Assert (Nkind (N) in N_Entity);
4041 return Nodes.Table (N + 2).Flag16;
4044 function Flag59 (N : Node_Id) return Boolean is
4046 pragma Assert (Nkind (N) in N_Entity);
4047 return Nodes.Table (N + 2).Flag17;
4050 function Flag60 (N : Node_Id) return Boolean is
4052 pragma Assert (Nkind (N) in N_Entity);
4053 return Nodes.Table (N + 2).Flag18;
4056 function Flag61 (N : Node_Id) return Boolean is
4058 pragma Assert (Nkind (N) in N_Entity);
4059 return Nodes.Table (N + 1).Pflag1;
4062 function Flag62 (N : Node_Id) return Boolean is
4064 pragma Assert (Nkind (N) in N_Entity);
4065 return Nodes.Table (N + 1).Pflag2;
4068 function Flag63 (N : Node_Id) return Boolean is
4070 pragma Assert (Nkind (N) in N_Entity);
4071 return Nodes.Table (N + 2).Pflag1;
4074 function Flag64 (N : Node_Id) return Boolean is
4076 pragma Assert (Nkind (N) in N_Entity);
4077 return Nodes.Table (N + 2).Pflag2;
4080 function Flag65 (N : Node_Id) return Boolean is
4082 pragma Assert (Nkind (N) in N_Entity);
4083 return To_Flag_Byte (Nodes.Table (N + 2).Nkind).Flag65;
4086 function Flag66 (N : Node_Id) return Boolean is
4088 pragma Assert (Nkind (N) in N_Entity);
4089 return To_Flag_Byte (Nodes.Table (N + 2).Nkind).Flag66;
4092 function Flag67 (N : Node_Id) return Boolean is
4094 pragma Assert (Nkind (N) in N_Entity);
4095 return To_Flag_Byte (Nodes.Table (N + 2).Nkind).Flag67;
4098 function Flag68 (N : Node_Id) return Boolean is
4100 pragma Assert (Nkind (N) in N_Entity);
4101 return To_Flag_Byte (Nodes.Table (N + 2).Nkind).Flag68;
4104 function Flag69 (N : Node_Id) return Boolean is
4106 pragma Assert (Nkind (N) in N_Entity);
4107 return To_Flag_Byte (Nodes.Table (N + 2).Nkind).Flag69;
4110 function Flag70 (N : Node_Id) return Boolean is
4112 pragma Assert (Nkind (N) in N_Entity);
4113 return To_Flag_Byte (Nodes.Table (N + 2).Nkind).Flag70;
4116 function Flag71 (N : Node_Id) return Boolean is
4118 pragma Assert (Nkind (N) in N_Entity);
4119 return To_Flag_Byte (Nodes.Table (N + 2).Nkind).Flag71;
4122 function Flag72 (N : Node_Id) return Boolean is
4124 pragma Assert (Nkind (N) in N_Entity);
4125 return To_Flag_Byte (Nodes.Table (N + 2).Nkind).Flag72;
4128 function Flag73 (N : Node_Id) return Boolean is
4130 pragma Assert (Nkind (N) in N_Entity);
4131 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag73;
4134 function Flag74 (N : Node_Id) return Boolean is
4136 pragma Assert (Nkind (N) in N_Entity);
4137 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag74;
4140 function Flag75 (N : Node_Id) return Boolean is
4142 pragma Assert (Nkind (N) in N_Entity);
4143 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag75;
4146 function Flag76 (N : Node_Id) return Boolean is
4148 pragma Assert (Nkind (N) in N_Entity);
4149 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag76;
4152 function Flag77 (N : Node_Id) return Boolean is
4154 pragma Assert (Nkind (N) in N_Entity);
4155 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag77;
4158 function Flag78 (N : Node_Id) return Boolean is
4160 pragma Assert (Nkind (N) in N_Entity);
4161 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag78;
4164 function Flag79 (N : Node_Id) return Boolean is
4166 pragma Assert (Nkind (N) in N_Entity);
4167 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag79;
4170 function Flag80 (N : Node_Id) return Boolean is
4172 pragma Assert (Nkind (N) in N_Entity);
4173 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag80;
4176 function Flag81 (N : Node_Id) return Boolean is
4178 pragma Assert (Nkind (N) in N_Entity);
4179 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag81;
4182 function Flag82 (N : Node_Id) return Boolean is
4184 pragma Assert (Nkind (N) in N_Entity);
4185 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag82;
4188 function Flag83 (N : Node_Id) return Boolean is
4190 pragma Assert (Nkind (N) in N_Entity);
4191 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag83;
4194 function Flag84 (N : Node_Id) return Boolean is
4196 pragma Assert (Nkind (N) in N_Entity);
4197 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag84;
4200 function Flag85 (N : Node_Id) return Boolean is
4202 pragma Assert (Nkind (N) in N_Entity);
4203 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag85;
4206 function Flag86 (N : Node_Id) return Boolean is
4208 pragma Assert (Nkind (N) in N_Entity);
4209 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag86;
4212 function Flag87 (N : Node_Id) return Boolean is
4214 pragma Assert (Nkind (N) in N_Entity);
4215 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag87;
4218 function Flag88 (N : Node_Id) return Boolean is
4220 pragma Assert (Nkind (N) in N_Entity);
4221 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag88;
4224 function Flag89 (N : Node_Id) return Boolean is
4226 pragma Assert (Nkind (N) in N_Entity);
4227 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag89;
4230 function Flag90 (N : Node_Id) return Boolean is
4232 pragma Assert (Nkind (N) in N_Entity);
4233 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag90;
4236 function Flag91 (N : Node_Id) return Boolean is
4238 pragma Assert (Nkind (N) in N_Entity);
4239 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag91;
4242 function Flag92 (N : Node_Id) return Boolean is
4244 pragma Assert (Nkind (N) in N_Entity);
4245 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag92;
4248 function Flag93 (N : Node_Id) return Boolean is
4250 pragma Assert (Nkind (N) in N_Entity);
4251 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag93;
4254 function Flag94 (N : Node_Id) return Boolean is
4256 pragma Assert (Nkind (N) in N_Entity);
4257 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag94;
4260 function Flag95 (N : Node_Id) return Boolean is
4262 pragma Assert (Nkind (N) in N_Entity);
4263 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag95;
4266 function Flag96 (N : Node_Id) return Boolean is
4268 pragma Assert (Nkind (N) in N_Entity);
4269 return To_Flag_Word (Nodes.Table (N + 2).Field12).Flag96;
4272 function Flag97 (N : Node_Id) return Boolean is
4274 pragma Assert (Nkind (N) in N_Entity);
4275 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag97;
4278 function Flag98 (N : Node_Id) return Boolean is
4280 pragma Assert (Nkind (N) in N_Entity);
4281 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag98;
4284 function Flag99 (N : Node_Id) return Boolean is
4286 pragma Assert (Nkind (N) in N_Entity);
4287 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag99;
4290 function Flag100 (N : Node_Id) return Boolean is
4292 pragma Assert (Nkind (N) in N_Entity);
4293 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag100;
4296 function Flag101 (N : Node_Id) return Boolean is
4298 pragma Assert (Nkind (N) in N_Entity);
4299 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag101;
4302 function Flag102 (N : Node_Id) return Boolean is
4304 pragma Assert (Nkind (N) in N_Entity);
4305 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag102;
4308 function Flag103 (N : Node_Id) return Boolean is
4310 pragma Assert (Nkind (N) in N_Entity);
4311 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag103;
4314 function Flag104 (N : Node_Id) return Boolean is
4316 pragma Assert (Nkind (N) in N_Entity);
4317 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag104;
4320 function Flag105 (N : Node_Id) return Boolean is
4322 pragma Assert (Nkind (N) in N_Entity);
4323 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag105;
4326 function Flag106 (N : Node_Id) return Boolean is
4328 pragma Assert (Nkind (N) in N_Entity);
4329 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag106;
4332 function Flag107 (N : Node_Id) return Boolean is
4334 pragma Assert (Nkind (N) in N_Entity);
4335 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag107;
4338 function Flag108 (N : Node_Id) return Boolean is
4340 pragma Assert (Nkind (N) in N_Entity);
4341 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag108;
4344 function Flag109 (N : Node_Id) return Boolean is
4346 pragma Assert (Nkind (N) in N_Entity);
4347 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag109;
4350 function Flag110 (N : Node_Id) return Boolean is
4352 pragma Assert (Nkind (N) in N_Entity);
4353 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag110;
4356 function Flag111 (N : Node_Id) return Boolean is
4358 pragma Assert (Nkind (N) in N_Entity);
4359 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag111;
4362 function Flag112 (N : Node_Id) return Boolean is
4364 pragma Assert (Nkind (N) in N_Entity);
4365 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag112;
4368 function Flag113 (N : Node_Id) return Boolean is
4370 pragma Assert (Nkind (N) in N_Entity);
4371 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag113;
4374 function Flag114 (N : Node_Id) return Boolean is
4376 pragma Assert (Nkind (N) in N_Entity);
4377 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag114;
4380 function Flag115 (N : Node_Id) return Boolean is
4382 pragma Assert (Nkind (N) in N_Entity);
4383 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag115;
4386 function Flag116 (N : Node_Id) return Boolean is
4388 pragma Assert (Nkind (N) in N_Entity);
4389 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag116;
4392 function Flag117 (N : Node_Id) return Boolean is
4394 pragma Assert (Nkind (N) in N_Entity);
4395 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag117;
4398 function Flag118 (N : Node_Id) return Boolean is
4400 pragma Assert (Nkind (N) in N_Entity);
4401 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag118;
4404 function Flag119 (N : Node_Id) return Boolean is
4406 pragma Assert (Nkind (N) in N_Entity);
4407 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag119;
4410 function Flag120 (N : Node_Id) return Boolean is
4412 pragma Assert (Nkind (N) in N_Entity);
4413 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag120;
4416 function Flag121 (N : Node_Id) return Boolean is
4418 pragma Assert (Nkind (N) in N_Entity);
4419 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag121;
4422 function Flag122 (N : Node_Id) return Boolean is
4424 pragma Assert (Nkind (N) in N_Entity);
4425 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag122;
4428 function Flag123 (N : Node_Id) return Boolean is
4430 pragma Assert (Nkind (N) in N_Entity);
4431 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag123;
4434 function Flag124 (N : Node_Id) return Boolean is
4436 pragma Assert (Nkind (N) in N_Entity);
4437 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag124;
4440 function Flag125 (N : Node_Id) return Boolean is
4442 pragma Assert (Nkind (N) in N_Entity);
4443 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag125;
4446 function Flag126 (N : Node_Id) return Boolean is
4448 pragma Assert (Nkind (N) in N_Entity);
4449 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag126;
4452 function Flag127 (N : Node_Id) return Boolean is
4454 pragma Assert (Nkind (N) in N_Entity);
4455 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag127;
4458 function Flag128 (N : Node_Id) return Boolean is
4460 pragma Assert (Nkind (N) in N_Entity);
4461 return To_Flag_Word2 (Nodes.Table (N + 3).Field12).Flag128;
4464 function Flag129 (N : Node_Id) return Boolean is
4466 pragma Assert (Nkind (N) in N_Entity);
4467 return Nodes.Table (N + 3).In_List;
4470 function Flag130 (N : Node_Id) return Boolean is
4472 pragma Assert (Nkind (N) in N_Entity);
4473 return Nodes.Table (N + 3).Has_Aspects;
4476 function Flag131 (N : Node_Id) return Boolean is
4478 pragma Assert (Nkind (N) in N_Entity);
4479 return Nodes.Table (N + 3).Rewrite_Ins;
4482 function Flag132 (N : Node_Id) return Boolean is
4484 pragma Assert (Nkind (N) in N_Entity);
4485 return Nodes.Table (N + 3).Analyzed;
4488 function Flag133 (N : Node_Id) return Boolean is
4490 pragma Assert (Nkind (N) in N_Entity);
4491 return Nodes.Table (N + 3).Comes_From_Source;
4494 function Flag134 (N : Node_Id) return Boolean is
4496 pragma Assert (Nkind (N) in N_Entity);
4497 return Nodes.Table (N + 3).Error_Posted;
4500 function Flag135 (N : Node_Id) return Boolean is
4502 pragma Assert (Nkind (N) in N_Entity);
4503 return Nodes.Table (N + 3).Flag4;
4506 function Flag136 (N : Node_Id) return Boolean is
4508 pragma Assert (Nkind (N) in N_Entity);
4509 return Nodes.Table (N + 3).Flag5;
4512 function Flag137 (N : Node_Id) return Boolean is
4514 pragma Assert (Nkind (N) in N_Entity);
4515 return Nodes.Table (N + 3).Flag6;
4518 function Flag138 (N : Node_Id) return Boolean is
4520 pragma Assert (Nkind (N) in N_Entity);
4521 return Nodes.Table (N + 3).Flag7;
4524 function Flag139 (N : Node_Id) return Boolean is
4526 pragma Assert (Nkind (N) in N_Entity);
4527 return Nodes.Table (N + 3).Flag8;
4530 function Flag140 (N : Node_Id) return Boolean is
4532 pragma Assert (Nkind (N) in N_Entity);
4533 return Nodes.Table (N + 3).Flag9;
4536 function Flag141 (N : Node_Id) return Boolean is
4538 pragma Assert (Nkind (N) in N_Entity);
4539 return Nodes.Table (N + 3).Flag10;
4542 function Flag142 (N : Node_Id) return Boolean is
4544 pragma Assert (Nkind (N) in N_Entity);
4545 return Nodes.Table (N + 3).Flag11;
4548 function Flag143 (N : Node_Id) return Boolean is
4550 pragma Assert (Nkind (N) in N_Entity);
4551 return Nodes.Table (N + 3).Flag12;
4554 function Flag144 (N : Node_Id) return Boolean is
4556 pragma Assert (Nkind (N) in N_Entity);
4557 return Nodes.Table (N + 3).Flag13;
4560 function Flag145 (N : Node_Id) return Boolean is
4562 pragma Assert (Nkind (N) in N_Entity);
4563 return Nodes.Table (N + 3).Flag14;
4566 function Flag146 (N : Node_Id) return Boolean is
4568 pragma Assert (Nkind (N) in N_Entity);
4569 return Nodes.Table (N + 3).Flag15;
4572 function Flag147 (N : Node_Id) return Boolean is
4574 pragma Assert (Nkind (N) in N_Entity);
4575 return Nodes.Table (N + 3).Flag16;
4578 function Flag148 (N : Node_Id) return Boolean is
4580 pragma Assert (Nkind (N) in N_Entity);
4581 return Nodes.Table (N + 3).Flag17;
4584 function Flag149 (N : Node_Id) return Boolean is
4586 pragma Assert (Nkind (N) in N_Entity);
4587 return Nodes.Table (N + 3).Flag18;
4590 function Flag150 (N : Node_Id) return Boolean is
4592 pragma Assert (Nkind (N) in N_Entity);
4593 return Nodes.Table (N + 3).Pflag1;
4596 function Flag151 (N : Node_Id) return Boolean is
4598 pragma Assert (Nkind (N) in N_Entity);
4599 return Nodes.Table (N + 3).Pflag2;
4602 function Flag152 (N : Node_Id) return Boolean is
4604 pragma Assert (Nkind (N) in N_Entity);
4605 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag152;
4608 function Flag153 (N : Node_Id) return Boolean is
4610 pragma Assert (Nkind (N) in N_Entity);
4611 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag153;
4614 function Flag154 (N : Node_Id) return Boolean is
4616 pragma Assert (Nkind (N) in N_Entity);
4617 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag154;
4620 function Flag155 (N : Node_Id) return Boolean is
4622 pragma Assert (Nkind (N) in N_Entity);
4623 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag155;
4626 function Flag156 (N : Node_Id) return Boolean is
4628 pragma Assert (Nkind (N) in N_Entity);
4629 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag156;
4632 function Flag157 (N : Node_Id) return Boolean is
4634 pragma Assert (Nkind (N) in N_Entity);
4635 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag157;
4638 function Flag158 (N : Node_Id) return Boolean is
4640 pragma Assert (Nkind (N) in N_Entity);
4641 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag158;
4644 function Flag159 (N : Node_Id) return Boolean is
4646 pragma Assert (Nkind (N) in N_Entity);
4647 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag159;
4650 function Flag160 (N : Node_Id) return Boolean is
4652 pragma Assert (Nkind (N) in N_Entity);
4653 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag160;
4656 function Flag161 (N : Node_Id) return Boolean is
4658 pragma Assert (Nkind (N) in N_Entity);
4659 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag161;
4662 function Flag162 (N : Node_Id) return Boolean is
4664 pragma Assert (Nkind (N) in N_Entity);
4665 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag162;
4668 function Flag163 (N : Node_Id) return Boolean is
4670 pragma Assert (Nkind (N) in N_Entity);
4671 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag163;
4674 function Flag164 (N : Node_Id) return Boolean is
4676 pragma Assert (Nkind (N) in N_Entity);
4677 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag164;
4680 function Flag165 (N : Node_Id) return Boolean is
4682 pragma Assert (Nkind (N) in N_Entity);
4683 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag165;
4686 function Flag166 (N : Node_Id) return Boolean is
4688 pragma Assert (Nkind (N) in N_Entity);
4689 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag166;
4692 function Flag167 (N : Node_Id) return Boolean is
4694 pragma Assert (Nkind (N) in N_Entity);
4695 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag167;
4698 function Flag168 (N : Node_Id) return Boolean is
4700 pragma Assert (Nkind (N) in N_Entity);
4701 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag168;
4704 function Flag169 (N : Node_Id) return Boolean is
4706 pragma Assert (Nkind (N) in N_Entity);
4707 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag169;
4710 function Flag170 (N : Node_Id) return Boolean is
4712 pragma Assert (Nkind (N) in N_Entity);
4713 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag170;
4716 function Flag171 (N : Node_Id) return Boolean is
4718 pragma Assert (Nkind (N) in N_Entity);
4719 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag171;
4722 function Flag172 (N : Node_Id) return Boolean is
4724 pragma Assert (Nkind (N) in N_Entity);
4725 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag172;
4728 function Flag173 (N : Node_Id) return Boolean is
4730 pragma Assert (Nkind (N) in N_Entity);
4731 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag173;
4734 function Flag174 (N : Node_Id) return Boolean is
4736 pragma Assert (Nkind (N) in N_Entity);
4737 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag174;
4740 function Flag175 (N : Node_Id) return Boolean is
4742 pragma Assert (Nkind (N) in N_Entity);
4743 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag175;
4746 function Flag176 (N : Node_Id) return Boolean is
4748 pragma Assert (Nkind (N) in N_Entity);
4749 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag176;
4752 function Flag177 (N : Node_Id) return Boolean is
4754 pragma Assert (Nkind (N) in N_Entity);
4755 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag177;
4758 function Flag178 (N : Node_Id) return Boolean is
4760 pragma Assert (Nkind (N) in N_Entity);
4761 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag178;
4764 function Flag179 (N : Node_Id) return Boolean is
4766 pragma Assert (Nkind (N) in N_Entity);
4767 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag179;
4770 function Flag180 (N : Node_Id) return Boolean is
4772 pragma Assert (Nkind (N) in N_Entity);
4773 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag180;
4776 function Flag181 (N : Node_Id) return Boolean is
4778 pragma Assert (Nkind (N) in N_Entity);
4779 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag181;
4782 function Flag182 (N : Node_Id) return Boolean is
4784 pragma Assert (Nkind (N) in N_Entity);
4785 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag182;
4788 function Flag183 (N : Node_Id) return Boolean is
4790 pragma Assert (Nkind (N) in N_Entity);
4791 return To_Flag_Word3 (Nodes.Table (N + 3).Field11).Flag183;
4794 function Flag184 (N : Node_Id) return Boolean is
4796 pragma Assert (Nkind (N) in N_Entity);
4797 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag184;
4800 function Flag185 (N : Node_Id) return Boolean is
4802 pragma Assert (Nkind (N) in N_Entity);
4803 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag185;
4806 function Flag186 (N : Node_Id) return Boolean is
4808 pragma Assert (Nkind (N) in N_Entity);
4809 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag186;
4812 function Flag187 (N : Node_Id) return Boolean is
4814 pragma Assert (Nkind (N) in N_Entity);
4815 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag187;
4818 function Flag188 (N : Node_Id) return Boolean is
4820 pragma Assert (Nkind (N) in N_Entity);
4821 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag188;
4824 function Flag189 (N : Node_Id) return Boolean is
4826 pragma Assert (Nkind (N) in N_Entity);
4827 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag189;
4830 function Flag190 (N : Node_Id) return Boolean is
4832 pragma Assert (Nkind (N) in N_Entity);
4833 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag190;
4836 function Flag191 (N : Node_Id) return Boolean is
4838 pragma Assert (Nkind (N) in N_Entity);
4839 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag191;
4842 function Flag192 (N : Node_Id) return Boolean is
4844 pragma Assert (Nkind (N) in N_Entity);
4845 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag192;
4848 function Flag193 (N : Node_Id) return Boolean is
4850 pragma Assert (Nkind (N) in N_Entity);
4851 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag193;
4854 function Flag194 (N : Node_Id) return Boolean is
4856 pragma Assert (Nkind (N) in N_Entity);
4857 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag194;
4860 function Flag195 (N : Node_Id) return Boolean is
4862 pragma Assert (Nkind (N) in N_Entity);
4863 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag195;
4866 function Flag196 (N : Node_Id) return Boolean is
4868 pragma Assert (Nkind (N) in N_Entity);
4869 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag196;
4872 function Flag197 (N : Node_Id) return Boolean is
4874 pragma Assert (Nkind (N) in N_Entity);
4875 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag197;
4878 function Flag198 (N : Node_Id) return Boolean is
4880 pragma Assert (Nkind (N) in N_Entity);
4881 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag198;
4884 function Flag199 (N : Node_Id) return Boolean is
4886 pragma Assert (Nkind (N) in N_Entity);
4887 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag199;
4890 function Flag200 (N : Node_Id) return Boolean is
4892 pragma Assert (Nkind (N) in N_Entity);
4893 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag200;
4896 function Flag201 (N : Node_Id) return Boolean is
4898 pragma Assert (Nkind (N) in N_Entity);
4899 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag201;
4902 function Flag202 (N : Node_Id) return Boolean is
4904 pragma Assert (Nkind (N) in N_Entity);
4905 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag202;
4908 function Flag203 (N : Node_Id) return Boolean is
4910 pragma Assert (Nkind (N) in N_Entity);
4911 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag203;
4914 function Flag204 (N : Node_Id) return Boolean is
4916 pragma Assert (Nkind (N) in N_Entity);
4917 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag204;
4920 function Flag205 (N : Node_Id) return Boolean is
4922 pragma Assert (Nkind (N) in N_Entity);
4923 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag205;
4926 function Flag206 (N : Node_Id) return Boolean is
4928 pragma Assert (Nkind (N) in N_Entity);
4929 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag206;
4932 function Flag207 (N : Node_Id) return Boolean is
4934 pragma Assert (Nkind (N) in N_Entity);
4935 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag207;
4938 function Flag208 (N : Node_Id) return Boolean is
4940 pragma Assert (Nkind (N) in N_Entity);
4941 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag208;
4944 function Flag209 (N : Node_Id) return Boolean is
4946 pragma Assert (Nkind (N) in N_Entity);
4947 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag209;
4950 function Flag210 (N : Node_Id) return Boolean is
4952 pragma Assert (Nkind (N) in N_Entity);
4953 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag210;
4956 function Flag211 (N : Node_Id) return Boolean is
4958 pragma Assert (Nkind (N) in N_Entity);
4959 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag211;
4962 function Flag212 (N : Node_Id) return Boolean is
4964 pragma Assert (Nkind (N) in N_Entity);
4965 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag212;
4968 function Flag213 (N : Node_Id) return Boolean is
4970 pragma Assert (Nkind (N) in N_Entity);
4971 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag213;
4974 function Flag214 (N : Node_Id) return Boolean is
4976 pragma Assert (Nkind (N) in N_Entity);
4977 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag214;
4980 function Flag215 (N : Node_Id) return Boolean is
4982 pragma Assert (Nkind (N) in N_Entity);
4983 return To_Flag_Word4 (Nodes.Table (N + 4).Field12).Flag215;
4986 function Flag216 (N : Node_Id) return Boolean is
4988 pragma Assert (Nkind (N) in N_Entity);
4989 return Nodes.Table (N + 4).In_List;
4992 function Flag217 (N : Node_Id) return Boolean is
4994 pragma Assert (Nkind (N) in N_Entity);
4995 return Nodes.Table (N + 4).Has_Aspects;
4998 function Flag218 (N : Node_Id) return Boolean is
5000 pragma Assert (Nkind (N) in N_Entity);
5001 return Nodes.Table (N + 4).Rewrite_Ins;
5004 function Flag219 (N : Node_Id) return Boolean is
5006 pragma Assert (Nkind (N) in N_Entity);
5007 return Nodes.Table (N + 4).Analyzed;
5010 function Flag220 (N : Node_Id) return Boolean is
5012 pragma Assert (Nkind (N) in N_Entity);
5013 return Nodes.Table (N + 4).Comes_From_Source;
5016 function Flag221 (N : Node_Id) return Boolean is
5018 pragma Assert (Nkind (N) in N_Entity);
5019 return Nodes.Table (N + 4).Error_Posted;
5022 function Flag222 (N : Node_Id) return Boolean is
5024 pragma Assert (Nkind (N) in N_Entity);
5025 return Nodes.Table (N + 4).Flag4;
5028 function Flag223 (N : Node_Id) return Boolean is
5030 pragma Assert (Nkind (N) in N_Entity);
5031 return Nodes.Table (N + 4).Flag5;
5034 function Flag224 (N : Node_Id) return Boolean is
5036 pragma Assert (Nkind (N) in N_Entity);
5037 return Nodes.Table (N + 4).Flag6;
5040 function Flag225 (N : Node_Id) return Boolean is
5042 pragma Assert (Nkind (N) in N_Entity);
5043 return Nodes.Table (N + 4).Flag7;
5046 function Flag226 (N : Node_Id) return Boolean is
5048 pragma Assert (Nkind (N) in N_Entity);
5049 return Nodes.Table (N + 4).Flag8;
5052 function Flag227 (N : Node_Id) return Boolean is
5054 pragma Assert (Nkind (N) in N_Entity);
5055 return Nodes.Table (N + 4).Flag9;
5058 function Flag228 (N : Node_Id) return Boolean is
5060 pragma Assert (Nkind (N) in N_Entity);
5061 return Nodes.Table (N + 4).Flag10;
5064 function Flag229 (N : Node_Id) return Boolean is
5066 pragma Assert (Nkind (N) in N_Entity);
5067 return Nodes.Table (N + 4).Flag11;
5070 function Flag230 (N : Node_Id) return Boolean is
5072 pragma Assert (Nkind (N) in N_Entity);
5073 return Nodes.Table (N + 4).Flag12;
5076 function Flag231 (N : Node_Id) return Boolean is
5078 pragma Assert (Nkind (N) in N_Entity);
5079 return Nodes.Table (N + 4).Flag13;
5082 function Flag232 (N : Node_Id) return Boolean is
5084 pragma Assert (Nkind (N) in N_Entity);
5085 return Nodes.Table (N + 4).Flag14;
5088 function Flag233 (N : Node_Id) return Boolean is
5090 pragma Assert (Nkind (N) in N_Entity);
5091 return Nodes.Table (N + 4).Flag15;
5094 function Flag234 (N : Node_Id) return Boolean is
5096 pragma Assert (Nkind (N) in N_Entity);
5097 return Nodes.Table (N + 4).Flag16;
5100 function Flag235 (N : Node_Id) return Boolean is
5102 pragma Assert (Nkind (N) in N_Entity);
5103 return Nodes.Table (N + 4).Flag17;
5106 function Flag236 (N : Node_Id) return Boolean is
5108 pragma Assert (Nkind (N) in N_Entity);
5109 return Nodes.Table (N + 4).Flag18;
5112 function Flag237 (N : Node_Id) return Boolean is
5114 pragma Assert (Nkind (N) in N_Entity);
5115 return Nodes.Table (N + 4).Pflag1;
5118 function Flag238 (N : Node_Id) return Boolean is
5120 pragma Assert (Nkind (N) in N_Entity);
5121 return Nodes.Table (N + 4).Pflag2;
5124 function Flag239 (N : Node_Id) return Boolean is
5126 pragma Assert (Nkind (N) in N_Entity);
5127 return To_Flag_Byte2 (Nodes.Table (N + 3).Nkind).Flag239;
5130 function Flag240 (N : Node_Id) return Boolean is
5132 pragma Assert (Nkind (N) in N_Entity);
5133 return To_Flag_Byte2 (Nodes.Table (N + 3).Nkind).Flag240;
5136 function Flag241 (N : Node_Id) return Boolean is
5138 pragma Assert (Nkind (N) in N_Entity);
5139 return To_Flag_Byte2 (Nodes.Table (N + 3).Nkind).Flag241;
5142 function Flag242 (N : Node_Id) return Boolean is
5144 pragma Assert (Nkind (N) in N_Entity);
5145 return To_Flag_Byte2 (Nodes.Table (N + 3).Nkind).Flag242;
5148 function Flag243 (N : Node_Id) return Boolean is
5150 pragma Assert (Nkind (N) in N_Entity);
5151 return To_Flag_Byte2 (Nodes.Table (N + 3).Nkind).Flag243;
5154 function Flag244 (N : Node_Id) return Boolean is
5156 pragma Assert (Nkind (N) in N_Entity);
5157 return To_Flag_Byte2 (Nodes.Table (N + 3).Nkind).Flag244;
5160 function Flag245 (N : Node_Id) return Boolean is
5162 pragma Assert (Nkind (N) in N_Entity);
5163 return To_Flag_Byte2 (Nodes.Table (N + 3).Nkind).Flag245;
5166 function Flag246 (N : Node_Id) return Boolean is
5168 pragma Assert (Nkind (N) in N_Entity);
5169 return To_Flag_Byte2 (Nodes.Table (N + 3).Nkind).Flag246;
5172 function Flag247 (N : Node_Id) return Boolean is
5174 pragma Assert (Nkind (N) in N_Entity);
5175 return To_Flag_Byte3 (Nodes.Table (N + 4).Nkind).Flag247;
5178 function Flag248 (N : Node_Id) return Boolean is
5180 pragma Assert (Nkind (N) in N_Entity);
5181 return To_Flag_Byte3 (Nodes.Table (N + 4).Nkind).Flag248;
5184 function Flag249 (N : Node_Id) return Boolean is
5186 pragma Assert (Nkind (N) in N_Entity);
5187 return To_Flag_Byte3 (Nodes.Table (N + 4).Nkind).Flag249;
5190 function Flag250 (N : Node_Id) return Boolean is
5192 pragma Assert (Nkind (N) in N_Entity);
5193 return To_Flag_Byte3 (Nodes.Table (N + 4).Nkind).Flag250;
5196 function Flag251 (N : Node_Id) return Boolean is
5198 pragma Assert (Nkind (N) in N_Entity);
5199 return To_Flag_Byte3 (Nodes.Table (N + 4).Nkind).Flag251;
5202 function Flag252 (N : Node_Id) return Boolean is
5204 pragma Assert (Nkind (N) in N_Entity);
5205 return To_Flag_Byte3 (Nodes.Table (N + 4).Nkind).Flag252;
5208 function Flag253 (N : Node_Id) return Boolean is
5210 pragma Assert (Nkind (N) in N_Entity);
5211 return To_Flag_Byte3 (Nodes.Table (N + 4).Nkind).Flag253;
5214 function Flag254 (N : Node_Id) return Boolean is
5216 pragma Assert (Nkind (N) in N_Entity);
5217 return To_Flag_Byte3 (Nodes.Table (N + 4).Nkind).Flag254;
5220 function Flag255 (N : Node_Id) return Boolean is
5222 pragma Assert (Nkind (N) in N_Entity);
5223 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag255;
5226 function Flag256 (N : Node_Id) return Boolean is
5228 pragma Assert (Nkind (N) in N_Entity);
5229 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag256;
5232 function Flag257 (N : Node_Id) return Boolean is
5234 pragma Assert (Nkind (N) in N_Entity);
5235 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag257;
5238 function Flag258 (N : Node_Id) return Boolean is
5240 pragma Assert (Nkind (N) in N_Entity);
5241 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag258;
5244 function Flag259 (N : Node_Id) return Boolean is
5246 pragma Assert (Nkind (N) in N_Entity);
5247 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag259;
5250 function Flag260 (N : Node_Id) return Boolean is
5252 pragma Assert (Nkind (N) in N_Entity);
5253 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag260;
5256 function Flag261 (N : Node_Id) return Boolean is
5258 pragma Assert (Nkind (N) in N_Entity);
5259 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag261;
5262 function Flag262 (N : Node_Id) return Boolean is
5264 pragma Assert (Nkind (N) in N_Entity);
5265 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag262;
5268 function Flag263 (N : Node_Id) return Boolean is
5270 pragma Assert (Nkind (N) in N_Entity);
5271 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag263;
5274 function Flag264 (N : Node_Id) return Boolean is
5276 pragma Assert (Nkind (N) in N_Entity);
5277 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag264;
5280 function Flag265 (N : Node_Id) return Boolean is
5282 pragma Assert (Nkind (N) in N_Entity);
5283 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag265;
5286 function Flag266 (N : Node_Id) return Boolean is
5288 pragma Assert (Nkind (N) in N_Entity);
5289 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag266;
5292 function Flag267 (N : Node_Id) return Boolean is
5294 pragma Assert (Nkind (N) in N_Entity);
5295 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag267;
5298 function Flag268 (N : Node_Id) return Boolean is
5300 pragma Assert (Nkind (N) in N_Entity);
5301 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag268;
5304 function Flag269 (N : Node_Id) return Boolean is
5306 pragma Assert (Nkind (N) in N_Entity);
5307 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag269;
5310 function Flag270 (N : Node_Id) return Boolean is
5312 pragma Assert (Nkind (N) in N_Entity);
5313 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag270;
5316 function Flag271 (N : Node_Id) return Boolean is
5318 pragma Assert (Nkind (N) in N_Entity);
5319 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag271;
5322 function Flag272 (N : Node_Id) return Boolean is
5324 pragma Assert (Nkind (N) in N_Entity);
5325 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag272;
5328 function Flag273 (N : Node_Id) return Boolean is
5330 pragma Assert (Nkind (N) in N_Entity);
5331 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag273;
5334 function Flag274 (N : Node_Id) return Boolean is
5336 pragma Assert (Nkind (N) in N_Entity);
5337 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag274;
5340 function Flag275 (N : Node_Id) return Boolean is
5342 pragma Assert (Nkind (N) in N_Entity);
5343 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag275;
5346 function Flag276 (N : Node_Id) return Boolean is
5348 pragma Assert (Nkind (N) in N_Entity);
5349 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag276;
5352 function Flag277 (N : Node_Id) return Boolean is
5354 pragma Assert (Nkind (N) in N_Entity);
5355 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag277;
5358 function Flag278 (N : Node_Id) return Boolean is
5360 pragma Assert (Nkind (N) in N_Entity);
5361 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag278;
5364 function Flag279 (N : Node_Id) return Boolean is
5366 pragma Assert (Nkind (N) in N_Entity);
5367 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag279;
5370 function Flag280 (N : Node_Id) return Boolean is
5372 pragma Assert (Nkind (N) in N_Entity);
5373 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag280;
5376 function Flag281 (N : Node_Id) return Boolean is
5378 pragma Assert (Nkind (N) in N_Entity);
5379 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag281;
5382 function Flag282 (N : Node_Id) return Boolean is
5384 pragma Assert (Nkind (N) in N_Entity);
5385 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag282;
5388 function Flag283 (N : Node_Id) return Boolean is
5390 pragma Assert (Nkind (N) in N_Entity);
5391 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag283;
5394 function Flag284 (N : Node_Id) return Boolean is
5396 pragma Assert (Nkind (N) in N_Entity);
5397 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag284;
5400 function Flag285 (N : Node_Id) return Boolean is
5402 pragma Assert (Nkind (N) in N_Entity);
5403 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag285;
5406 function Flag286 (N : Node_Id) return Boolean is
5408 pragma Assert (Nkind (N) in N_Entity);
5409 return To_Flag_Word5 (Nodes.Table (N + 5).Field12).Flag286;
5412 function Flag287 (N : Node_Id) return Boolean is
5414 pragma Assert (Nkind (N) in N_Entity);
5415 return Nodes.Table (N + 5).In_List;
5418 function Flag288 (N : Node_Id) return Boolean is
5420 pragma Assert (Nkind (N) in N_Entity);
5421 return Nodes.Table (N + 5).Has_Aspects;
5424 function Flag289 (N : Node_Id) return Boolean is
5426 pragma Assert (Nkind (N) in N_Entity);
5427 return Nodes.Table (N + 5).Rewrite_Ins;
5430 function Flag290 (N : Node_Id) return Boolean is
5432 pragma Assert (Nkind (N) in N_Entity);
5433 return Nodes.Table (N + 5).Analyzed;
5436 function Flag291 (N : Node_Id) return Boolean is
5438 pragma Assert (Nkind (N) in N_Entity);
5439 return Nodes.Table (N + 5).Comes_From_Source;
5442 function Flag292 (N : Node_Id) return Boolean is
5444 pragma Assert (Nkind (N) in N_Entity);
5445 return Nodes.Table (N + 5).Error_Posted;
5448 function Flag293 (N : Node_Id) return Boolean is
5450 pragma Assert (Nkind (N) in N_Entity);
5451 return Nodes.Table (N + 5).Flag4;
5454 function Flag294 (N : Node_Id) return Boolean is
5456 pragma Assert (Nkind (N) in N_Entity);
5457 return Nodes.Table (N + 5).Flag5;
5460 function Flag295 (N : Node_Id) return Boolean is
5462 pragma Assert (Nkind (N) in N_Entity);
5463 return Nodes.Table (N + 5).Flag6;
5466 function Flag296 (N : Node_Id) return Boolean is
5468 pragma Assert (Nkind (N) in N_Entity);
5469 return Nodes.Table (N + 5).Flag7;
5472 function Flag297 (N : Node_Id) return Boolean is
5474 pragma Assert (Nkind (N) in N_Entity);
5475 return Nodes.Table (N + 5).Flag8;
5478 function Flag298 (N : Node_Id) return Boolean is
5480 pragma Assert (Nkind (N) in N_Entity);
5481 return Nodes.Table (N + 5).Flag9;
5484 function Flag299 (N : Node_Id) return Boolean is
5486 pragma Assert (Nkind (N) in N_Entity);
5487 return Nodes.Table (N + 5).Flag10;
5490 function Flag300 (N : Node_Id) return Boolean is
5492 pragma Assert (Nkind (N) in N_Entity);
5493 return Nodes.Table (N + 5).Flag11;
5496 function Flag301 (N : Node_Id) return Boolean is
5498 pragma Assert (Nkind (N) in N_Entity);
5499 return Nodes.Table (N + 5).Flag12;
5502 function Flag302 (N : Node_Id) return Boolean is
5504 pragma Assert (Nkind (N) in N_Entity);
5505 return Nodes.Table (N + 5).Flag13;
5508 function Flag303 (N : Node_Id) return Boolean is
5510 pragma Assert (Nkind (N) in N_Entity);
5511 return Nodes.Table (N + 5).Flag14;
5514 function Flag304 (N : Node_Id) return Boolean is
5516 pragma Assert (Nkind (N) in N_Entity);
5517 return Nodes.Table (N + 5).Flag15;
5520 function Flag305 (N : Node_Id) return Boolean is
5522 pragma Assert (Nkind (N) in N_Entity);
5523 return Nodes.Table (N + 5).Flag16;
5526 function Flag306 (N : Node_Id) return Boolean is
5528 pragma Assert (Nkind (N) in N_Entity);
5529 return Nodes.Table (N + 5).Flag17;
5532 function Flag307 (N : Node_Id) return Boolean is
5534 pragma Assert (Nkind (N) in N_Entity);
5535 return Nodes.Table (N + 5).Flag18;
5538 function Flag308 (N : Node_Id) return Boolean is
5540 pragma Assert (Nkind (N) in N_Entity);
5541 return Nodes.Table (N + 5).Pflag1;
5544 function Flag309 (N : Node_Id) return Boolean is
5546 pragma Assert (Nkind (N) in N_Entity);
5547 return Nodes.Table (N + 5).Pflag2;
5550 function Flag310 (N : Node_Id) return Boolean is
5552 pragma Assert (Nkind (N) in N_Entity);
5553 return To_Flag_Byte4 (Nodes.Table (N + 5).Nkind).Flag310;
5556 function Flag311 (N : Node_Id) return Boolean is
5558 pragma Assert (Nkind (N) in N_Entity);
5559 return To_Flag_Byte4 (Nodes.Table (N + 5).Nkind).Flag311;
5562 function Flag312 (N : Node_Id) return Boolean is
5564 pragma Assert (Nkind (N) in N_Entity);
5565 return To_Flag_Byte4 (Nodes.Table (N + 5).Nkind).Flag312;
5568 function Flag313 (N : Node_Id) return Boolean is
5570 pragma Assert (Nkind (N) in N_Entity);
5571 return To_Flag_Byte4 (Nodes.Table (N + 5).Nkind).Flag313;
5574 function Flag314 (N : Node_Id) return Boolean is
5576 pragma Assert (Nkind (N) in N_Entity);
5577 return To_Flag_Byte4 (Nodes.Table (N + 5).Nkind).Flag314;
5580 function Flag315 (N : Node_Id) return Boolean is
5582 pragma Assert (Nkind (N) in N_Entity);
5583 return To_Flag_Byte4 (Nodes.Table (N + 5).Nkind).Flag315;
5586 function Flag316 (N : Node_Id) return Boolean is
5588 pragma Assert (Nkind (N) in N_Entity);
5589 return To_Flag_Byte4 (Nodes.Table (N + 5).Nkind).Flag316;
5592 function Flag317 (N : Node_Id) return Boolean is
5594 pragma Assert (Nkind (N) in N_Entity);
5595 return To_Flag_Byte4 (Nodes.Table (N + 5).Nkind).Flag317;
5598 procedure Set_Nkind (N : Node_Id; Val : Node_Kind) is
5600 pragma Assert (not Locked);
5601 pragma Assert (N <= Nodes.Last);
5602 Nodes.Table (N).Nkind := Val;
5605 procedure Set_Field1 (N : Node_Id; Val : Union_Id) is
5607 pragma Assert (not Locked);
5608 pragma Assert (N <= Nodes.Last);
5609 Nodes.Table (N).Field1 := Val;
5612 procedure Set_Field2 (N : Node_Id; Val : Union_Id) is
5614 pragma Assert (not Locked);
5615 pragma Assert (N <= Nodes.Last);
5616 Nodes.Table (N).Field2 := Val;
5619 procedure Set_Field3 (N : Node_Id; Val : Union_Id) is
5621 pragma Assert (not Locked);
5622 pragma Assert (N <= Nodes.Last);
5623 Nodes.Table (N).Field3 := Val;
5626 procedure Set_Field4 (N : Node_Id; Val : Union_Id) is
5628 pragma Assert (not Locked);
5629 pragma Assert (N <= Nodes.Last);
5630 Nodes.Table (N).Field4 := Val;
5633 procedure Set_Field5 (N : Node_Id; Val : Union_Id) is
5635 pragma Assert (not Locked);
5636 pragma Assert (N <= Nodes.Last);
5637 Nodes.Table (N).Field5 := Val;
5640 procedure Set_Field6 (N : Node_Id; Val : Union_Id) is
5642 pragma Assert (not Locked);
5643 pragma Assert (Nkind (N) in N_Entity);
5644 Nodes.Table (N + 1).Field6 := Val;
5647 procedure Set_Field7 (N : Node_Id; Val : Union_Id) is
5649 pragma Assert (not Locked);
5650 pragma Assert (Nkind (N) in N_Entity);
5651 Nodes.Table (N + 1).Field7 := Val;
5654 procedure Set_Field8 (N : Node_Id; Val : Union_Id) is
5656 pragma Assert (not Locked);
5657 pragma Assert (Nkind (N) in N_Entity);
5658 Nodes.Table (N + 1).Field8 := Val;
5661 procedure Set_Field9 (N : Node_Id; Val : Union_Id) is
5663 pragma Assert (not Locked);
5664 pragma Assert (Nkind (N) in N_Entity);
5665 Nodes.Table (N + 1).Field9 := Val;
5668 procedure Set_Field10 (N : Node_Id; Val : Union_Id) is
5670 pragma Assert (not Locked);
5671 pragma Assert (Nkind (N) in N_Entity);
5672 Nodes.Table (N + 1).Field10 := Val;
5675 procedure Set_Field11 (N : Node_Id; Val : Union_Id) is
5677 pragma Assert (not Locked);
5678 pragma Assert (Nkind (N) in N_Entity);
5679 Nodes.Table (N + 1).Field11 := Val;
5682 procedure Set_Field12 (N : Node_Id; Val : Union_Id) is
5684 pragma Assert (not Locked);
5685 pragma Assert (Nkind (N) in N_Entity);
5686 Nodes.Table (N + 1).Field12 := Val;
5689 procedure Set_Field13 (N : Node_Id; Val : Union_Id) is
5691 pragma Assert (not Locked);
5692 pragma Assert (Nkind (N) in N_Entity);
5693 Nodes.Table (N + 2).Field6 := Val;
5696 procedure Set_Field14 (N : Node_Id; Val : Union_Id) is
5698 pragma Assert (not Locked);
5699 pragma Assert (Nkind (N) in N_Entity);
5700 Nodes.Table (N + 2).Field7 := Val;
5703 procedure Set_Field15 (N : Node_Id; Val : Union_Id) is
5705 pragma Assert (not Locked);
5706 pragma Assert (Nkind (N) in N_Entity);
5707 Nodes.Table (N + 2).Field8 := Val;
5710 procedure Set_Field16 (N : Node_Id; Val : Union_Id) is
5712 pragma Assert (not Locked);
5713 pragma Assert (Nkind (N) in N_Entity);
5714 Nodes.Table (N + 2).Field9 := Val;
5717 procedure Set_Field17 (N : Node_Id; Val : Union_Id) is
5719 pragma Assert (not Locked);
5720 pragma Assert (Nkind (N) in N_Entity);
5721 Nodes.Table (N + 2).Field10 := Val;
5724 procedure Set_Field18 (N : Node_Id; Val : Union_Id) is
5726 pragma Assert (not Locked);
5727 pragma Assert (Nkind (N) in N_Entity);
5728 Nodes.Table (N + 2).Field11 := Val;
5731 procedure Set_Field19 (N : Node_Id; Val : Union_Id) is
5733 pragma Assert (not Locked);
5734 pragma Assert (Nkind (N) in N_Entity);
5735 Nodes.Table (N + 3).Field6 := Val;
5738 procedure Set_Field20 (N : Node_Id; Val : Union_Id) is
5740 pragma Assert (not Locked);
5741 pragma Assert (Nkind (N) in N_Entity);
5742 Nodes.Table (N + 3).Field7 := Val;
5745 procedure Set_Field21 (N : Node_Id; Val : Union_Id) is
5747 pragma Assert (not Locked);
5748 pragma Assert (Nkind (N) in N_Entity);
5749 Nodes.Table (N + 3).Field8 := Val;
5752 procedure Set_Field22 (N : Node_Id; Val : Union_Id) is
5754 pragma Assert (not Locked);
5755 pragma Assert (Nkind (N) in N_Entity);
5756 Nodes.Table (N + 3).Field9 := Val;
5759 procedure Set_Field23 (N : Node_Id; Val : Union_Id) is
5761 pragma Assert (not Locked);
5762 pragma Assert (Nkind (N) in N_Entity);
5763 Nodes.Table (N + 3).Field10 := Val;
5766 procedure Set_Field24 (N : Node_Id; Val : Union_Id) is
5768 pragma Assert (not Locked);
5769 pragma Assert (Nkind (N) in N_Entity);
5770 Nodes.Table (N + 4).Field6 := Val;
5773 procedure Set_Field25 (N : Node_Id; Val : Union_Id) is
5775 pragma Assert (not Locked);
5776 pragma Assert (Nkind (N) in N_Entity);
5777 Nodes.Table (N + 4).Field7 := Val;
5780 procedure Set_Field26 (N : Node_Id; Val : Union_Id) is
5782 pragma Assert (not Locked);
5783 pragma Assert (Nkind (N) in N_Entity);
5784 Nodes.Table (N + 4).Field8 := Val;
5787 procedure Set_Field27 (N : Node_Id; Val : Union_Id) is
5789 pragma Assert (not Locked);
5790 pragma Assert (Nkind (N) in N_Entity);
5791 Nodes.Table (N + 4).Field9 := Val;
5794 procedure Set_Field28 (N : Node_Id; Val : Union_Id) is
5796 pragma Assert (not Locked);
5797 pragma Assert (Nkind (N) in N_Entity);
5798 Nodes.Table (N + 4).Field10 := Val;
5801 procedure Set_Field29 (N : Node_Id; Val : Union_Id) is
5803 pragma Assert (not Locked);
5804 pragma Assert (Nkind (N) in N_Entity);
5805 Nodes.Table (N + 4).Field11 := Val;
5808 procedure Set_Field30 (N : Node_Id; Val : Union_Id) is
5810 pragma Assert (not Locked);
5811 pragma Assert (Nkind (N) in N_Entity);
5812 Nodes.Table (N + 5).Field6 := Val;
5815 procedure Set_Field31 (N : Node_Id; Val : Union_Id) is
5817 pragma Assert (not Locked);
5818 pragma Assert (Nkind (N) in N_Entity);
5819 Nodes.Table (N + 5).Field7 := Val;
5822 procedure Set_Field32 (N : Node_Id; Val : Union_Id) is
5824 pragma Assert (not Locked);
5825 pragma Assert (Nkind (N) in N_Entity);
5826 Nodes.Table (N + 5).Field8 := Val;
5829 procedure Set_Field33 (N : Node_Id; Val : Union_Id) is
5831 pragma Assert (not Locked);
5832 pragma Assert (Nkind (N) in N_Entity);
5833 Nodes.Table (N + 5).Field9 := Val;
5836 procedure Set_Field34 (N : Node_Id; Val : Union_Id) is
5838 pragma Assert (not Locked);
5839 pragma Assert (Nkind (N) in N_Entity);
5840 Nodes.Table (N + 5).Field10 := Val;
5843 procedure Set_Field35 (N : Node_Id; Val : Union_Id) is
5845 pragma Assert (not Locked);
5846 pragma Assert (Nkind (N) in N_Entity);
5847 Nodes.Table (N + 5).Field11 := Val;
5850 procedure Set_Field36 (N : Node_Id; Val : Union_Id) is
5852 pragma Assert (not Locked);
5853 pragma Assert (Nkind (N) in N_Entity);
5854 Nodes.Table (N + 6).Field6 := Val;
5857 procedure Set_Field37 (N : Node_Id; Val : Union_Id) is
5859 pragma Assert (not Locked);
5860 pragma Assert (Nkind (N) in N_Entity);
5861 Nodes.Table (N + 6).Field7 := Val;
5864 procedure Set_Field38 (N : Node_Id; Val : Union_Id) is
5866 pragma Assert (not Locked);
5867 pragma Assert (Nkind (N) in N_Entity);
5868 Nodes.Table (N + 6).Field8 := Val;
5871 procedure Set_Field39 (N : Node_Id; Val : Union_Id) is
5873 pragma Assert (not Locked);
5874 pragma Assert (Nkind (N) in N_Entity);
5875 Nodes.Table (N + 6).Field9 := Val;
5878 procedure Set_Field40 (N : Node_Id; Val : Union_Id) is
5880 pragma Assert (not Locked);
5881 pragma Assert (Nkind (N) in N_Entity);
5882 Nodes.Table (N + 6).Field10 := Val;
5885 procedure Set_Field41 (N : Node_Id; Val : Union_Id) is
5887 pragma Assert (not Locked);
5888 pragma Assert (Nkind (N) in N_Entity);
5889 Nodes.Table (N + 6).Field11 := Val;
5892 procedure Set_Node1 (N : Node_Id; Val : Node_Id) is
5894 pragma Assert (not Locked);
5895 pragma Assert (N <= Nodes.Last);
5896 Nodes.Table (N).Field1 := Union_Id (Val);
5899 procedure Set_Node2 (N : Node_Id; Val : Node_Id) is
5901 pragma Assert (not Locked);
5902 pragma Assert (N <= Nodes.Last);
5903 Nodes.Table (N).Field2 := Union_Id (Val);
5906 procedure Set_Node3 (N : Node_Id; Val : Node_Id) is
5908 pragma Assert (not Locked);
5909 pragma Assert (N <= Nodes.Last);
5910 Nodes.Table (N).Field3 := Union_Id (Val);
5913 procedure Set_Node4 (N : Node_Id; Val : Node_Id) is
5915 pragma Assert (not Locked);
5916 pragma Assert (N <= Nodes.Last);
5917 Nodes.Table (N).Field4 := Union_Id (Val);
5920 procedure Set_Node5 (N : Node_Id; Val : Node_Id) is
5922 pragma Assert (not Locked);
5923 pragma Assert (N <= Nodes.Last);
5924 Nodes.Table (N).Field5 := Union_Id (Val);
5927 procedure Set_Node6 (N : Node_Id; Val : Node_Id) is
5929 pragma Assert (not Locked);
5930 pragma Assert (Nkind (N) in N_Entity);
5931 Nodes.Table (N + 1).Field6 := Union_Id (Val);
5934 procedure Set_Node7 (N : Node_Id; Val : Node_Id) is
5936 pragma Assert (not Locked);
5937 pragma Assert (Nkind (N) in N_Entity);
5938 Nodes.Table (N + 1).Field7 := Union_Id (Val);
5941 procedure Set_Node8 (N : Node_Id; Val : Node_Id) is
5943 pragma Assert (not Locked);
5944 pragma Assert (Nkind (N) in N_Entity);
5945 Nodes.Table (N + 1).Field8 := Union_Id (Val);
5948 procedure Set_Node9 (N : Node_Id; Val : Node_Id) is
5950 pragma Assert (not Locked);
5951 pragma Assert (Nkind (N) in N_Entity);
5952 Nodes.Table (N + 1).Field9 := Union_Id (Val);
5955 procedure Set_Node10 (N : Node_Id; Val : Node_Id) is
5957 pragma Assert (not Locked);
5958 pragma Assert (Nkind (N) in N_Entity);
5959 Nodes.Table (N + 1).Field10 := Union_Id (Val);
5962 procedure Set_Node11 (N : Node_Id; Val : Node_Id) is
5964 pragma Assert (not Locked);
5965 pragma Assert (Nkind (N) in N_Entity);
5966 Nodes.Table (N + 1).Field11 := Union_Id (Val);
5969 procedure Set_Node12 (N : Node_Id; Val : Node_Id) is
5971 pragma Assert (not Locked);
5972 pragma Assert (Nkind (N) in N_Entity);
5973 Nodes.Table (N + 1).Field12 := Union_Id (Val);
5976 procedure Set_Node13 (N : Node_Id; Val : Node_Id) is
5978 pragma Assert (not Locked);
5979 pragma Assert (Nkind (N) in N_Entity);
5980 Nodes.Table (N + 2).Field6 := Union_Id (Val);
5983 procedure Set_Node14 (N : Node_Id; Val : Node_Id) is
5985 pragma Assert (not Locked);
5986 pragma Assert (Nkind (N) in N_Entity);
5987 Nodes.Table (N + 2).Field7 := Union_Id (Val);
5990 procedure Set_Node15 (N : Node_Id; Val : Node_Id) is
5992 pragma Assert (not Locked);
5993 pragma Assert (Nkind (N) in N_Entity);
5994 Nodes.Table (N + 2).Field8 := Union_Id (Val);
5997 procedure Set_Node16 (N : Node_Id; Val : Node_Id) is
5999 pragma Assert (not Locked);
6000 pragma Assert (Nkind (N) in N_Entity);
6001 Nodes.Table (N + 2).Field9 := Union_Id (Val);
6004 procedure Set_Node17 (N : Node_Id; Val : Node_Id) is
6006 pragma Assert (not Locked);
6007 pragma Assert (Nkind (N) in N_Entity);
6008 Nodes.Table (N + 2).Field10 := Union_Id (Val);
6011 procedure Set_Node18 (N : Node_Id; Val : Node_Id) is
6013 pragma Assert (not Locked);
6014 pragma Assert (Nkind (N) in N_Entity);
6015 Nodes.Table (N + 2).Field11 := Union_Id (Val);
6018 procedure Set_Node19 (N : Node_Id; Val : Node_Id) is
6020 pragma Assert (not Locked);
6021 pragma Assert (Nkind (N) in N_Entity);
6022 Nodes.Table (N + 3).Field6 := Union_Id (Val);
6025 procedure Set_Node20 (N : Node_Id; Val : Node_Id) is
6027 pragma Assert (not Locked);
6028 pragma Assert (Nkind (N) in N_Entity);
6029 Nodes.Table (N + 3).Field7 := Union_Id (Val);
6032 procedure Set_Node21 (N : Node_Id; Val : Node_Id) is
6034 pragma Assert (not Locked);
6035 pragma Assert (Nkind (N) in N_Entity);
6036 Nodes.Table (N + 3).Field8 := Union_Id (Val);
6039 procedure Set_Node22 (N : Node_Id; Val : Node_Id) is
6041 pragma Assert (not Locked);
6042 pragma Assert (Nkind (N) in N_Entity);
6043 Nodes.Table (N + 3).Field9 := Union_Id (Val);
6046 procedure Set_Node23 (N : Node_Id; Val : Node_Id) is
6048 pragma Assert (not Locked);
6049 pragma Assert (Nkind (N) in N_Entity);
6050 Nodes.Table (N + 3).Field10 := Union_Id (Val);
6053 procedure Set_Node24 (N : Node_Id; Val : Node_Id) is
6055 pragma Assert (not Locked);
6056 pragma Assert (Nkind (N) in N_Entity);
6057 Nodes.Table (N + 4).Field6 := Union_Id (Val);
6060 procedure Set_Node25 (N : Node_Id; Val : Node_Id) is
6062 pragma Assert (not Locked);
6063 pragma Assert (Nkind (N) in N_Entity);
6064 Nodes.Table (N + 4).Field7 := Union_Id (Val);
6067 procedure Set_Node26 (N : Node_Id; Val : Node_Id) is
6069 pragma Assert (not Locked);
6070 pragma Assert (Nkind (N) in N_Entity);
6071 Nodes.Table (N + 4).Field8 := Union_Id (Val);
6074 procedure Set_Node27 (N : Node_Id; Val : Node_Id) is
6076 pragma Assert (not Locked);
6077 pragma Assert (Nkind (N) in N_Entity);
6078 Nodes.Table (N + 4).Field9 := Union_Id (Val);
6081 procedure Set_Node28 (N : Node_Id; Val : Node_Id) is
6083 pragma Assert (not Locked);
6084 pragma Assert (Nkind (N) in N_Entity);
6085 Nodes.Table (N + 4).Field10 := Union_Id (Val);
6088 procedure Set_Node29 (N : Node_Id; Val : Node_Id) is
6090 pragma Assert (not Locked);
6091 pragma Assert (Nkind (N) in N_Entity);
6092 Nodes.Table (N + 4).Field11 := Union_Id (Val);
6095 procedure Set_Node30 (N : Node_Id; Val : Node_Id) is
6097 pragma Assert (not Locked);
6098 pragma Assert (Nkind (N) in N_Entity);
6099 Nodes.Table (N + 5).Field6 := Union_Id (Val);
6102 procedure Set_Node31 (N : Node_Id; Val : Node_Id) is
6104 pragma Assert (not Locked);
6105 pragma Assert (Nkind (N) in N_Entity);
6106 Nodes.Table (N + 5).Field7 := Union_Id (Val);
6109 procedure Set_Node32 (N : Node_Id; Val : Node_Id) is
6111 pragma Assert (not Locked);
6112 pragma Assert (Nkind (N) in N_Entity);
6113 Nodes.Table (N + 5).Field8 := Union_Id (Val);
6116 procedure Set_Node33 (N : Node_Id; Val : Node_Id) is
6118 pragma Assert (not Locked);
6119 pragma Assert (Nkind (N) in N_Entity);
6120 Nodes.Table (N + 5).Field9 := Union_Id (Val);
6123 procedure Set_Node34 (N : Node_Id; Val : Node_Id) is
6125 pragma Assert (not Locked);
6126 pragma Assert (Nkind (N) in N_Entity);
6127 Nodes.Table (N + 5).Field10 := Union_Id (Val);
6130 procedure Set_Node35 (N : Node_Id; Val : Node_Id) is
6132 pragma Assert (not Locked);
6133 pragma Assert (Nkind (N) in N_Entity);
6134 Nodes.Table (N + 5).Field11 := Union_Id (Val);
6137 procedure Set_Node36 (N : Node_Id; Val : Node_Id) is
6139 pragma Assert (not Locked);
6140 pragma Assert (Nkind (N) in N_Entity);
6141 Nodes.Table (N + 6).Field6 := Union_Id (Val);
6144 procedure Set_Node37 (N : Node_Id; Val : Node_Id) is
6146 pragma Assert (not Locked);
6147 pragma Assert (Nkind (N) in N_Entity);
6148 Nodes.Table (N + 6).Field7 := Union_Id (Val);
6151 procedure Set_Node38 (N : Node_Id; Val : Node_Id) is
6153 pragma Assert (not Locked);
6154 pragma Assert (Nkind (N) in N_Entity);
6155 Nodes.Table (N + 6).Field8 := Union_Id (Val);
6158 procedure Set_Node39 (N : Node_Id; Val : Node_Id) is
6160 pragma Assert (not Locked);
6161 pragma Assert (Nkind (N) in N_Entity);
6162 Nodes.Table (N + 6).Field9 := Union_Id (Val);
6165 procedure Set_Node40 (N : Node_Id; Val : Node_Id) is
6167 pragma Assert (not Locked);
6168 pragma Assert (Nkind (N) in N_Entity);
6169 Nodes.Table (N + 6).Field10 := Union_Id (Val);
6172 procedure Set_Node41 (N : Node_Id; Val : Node_Id) is
6174 pragma Assert (not Locked);
6175 pragma Assert (Nkind (N) in N_Entity);
6176 Nodes.Table (N + 6).Field11 := Union_Id (Val);
6179 procedure Set_List1 (N : Node_Id; Val : List_Id) is
6181 pragma Assert (not Locked);
6182 pragma Assert (N <= Nodes.Last);
6183 Nodes.Table (N).Field1 := Union_Id (Val);
6186 procedure Set_List2 (N : Node_Id; Val : List_Id) is
6188 pragma Assert (not Locked);
6189 pragma Assert (N <= Nodes.Last);
6190 Nodes.Table (N).Field2 := Union_Id (Val);
6193 procedure Set_List3 (N : Node_Id; Val : List_Id) is
6195 pragma Assert (not Locked);
6196 pragma Assert (N <= Nodes.Last);
6197 Nodes.Table (N).Field3 := Union_Id (Val);
6200 procedure Set_List4 (N : Node_Id; Val : List_Id) is
6202 pragma Assert (not Locked);
6203 pragma Assert (N <= Nodes.Last);
6204 Nodes.Table (N).Field4 := Union_Id (Val);
6207 procedure Set_List5 (N : Node_Id; Val : List_Id) is
6209 pragma Assert (not Locked);
6210 pragma Assert (N <= Nodes.Last);
6211 Nodes.Table (N).Field5 := Union_Id (Val);
6214 procedure Set_List10 (N : Node_Id; Val : List_Id) is
6216 pragma Assert (not Locked);
6217 pragma Assert (Nkind (N) in N_Entity);
6218 Nodes.Table (N + 1).Field10 := Union_Id (Val);
6221 procedure Set_List14 (N : Node_Id; Val : List_Id) is
6223 pragma Assert (not Locked);
6224 pragma Assert (Nkind (N) in N_Entity);
6225 Nodes.Table (N + 2).Field7 := Union_Id (Val);
6228 procedure Set_List25 (N : Node_Id; Val : List_Id) is
6230 pragma Assert (not Locked);
6231 pragma Assert (Nkind (N) in N_Entity);
6232 Nodes.Table (N + 4).Field7 := Union_Id (Val);
6235 procedure Set_List38 (N : Node_Id; Val : List_Id) is
6237 pragma Assert (not Locked);
6238 pragma Assert (Nkind (N) in N_Entity);
6239 Nodes.Table (N + 6).Field8 := Union_Id (Val);
6242 procedure Set_List39 (N : Node_Id; Val : List_Id) is
6244 pragma Assert (not Locked);
6245 pragma Assert (Nkind (N) in N_Entity);
6246 Nodes.Table (N + 6).Field9 := Union_Id (Val);
6249 procedure Set_Elist1 (N : Node_Id; Val : Elist_Id) is
6251 pragma Assert (not Locked);
6252 Nodes.Table (N).Field1 := Union_Id (Val);
6255 procedure Set_Elist2 (N : Node_Id; Val : Elist_Id) is
6257 pragma Assert (not Locked);
6258 Nodes.Table (N).Field2 := Union_Id (Val);
6261 procedure Set_Elist3 (N : Node_Id; Val : Elist_Id) is
6263 pragma Assert (not Locked);
6264 Nodes.Table (N).Field3 := Union_Id (Val);
6267 procedure Set_Elist4 (N : Node_Id; Val : Elist_Id) is
6269 pragma Assert (not Locked);
6270 Nodes.Table (N).Field4 := Union_Id (Val);
6273 procedure Set_Elist5 (N : Node_Id; Val : Elist_Id) is
6275 pragma Assert (not Locked);
6276 Nodes.Table (N).Field5 := Union_Id (Val);
6279 procedure Set_Elist8 (N : Node_Id; Val : Elist_Id) is
6281 pragma Assert (not Locked);
6282 pragma Assert (Nkind (N) in N_Entity);
6283 Nodes.Table (N + 1).Field8 := Union_Id (Val);
6286 procedure Set_Elist9 (N : Node_Id; Val : Elist_Id) is
6288 pragma Assert (not Locked);
6289 pragma Assert (Nkind (N) in N_Entity);
6290 Nodes.Table (N + 1).Field9 := Union_Id (Val);
6293 procedure Set_Elist10 (N : Node_Id; Val : Elist_Id) is
6295 pragma Assert (not Locked);
6296 pragma Assert (Nkind (N) in N_Entity);
6297 Nodes.Table (N + 1).Field10 := Union_Id (Val);
6300 procedure Set_Elist11 (N : Node_Id; Val : Elist_Id) is
6302 pragma Assert (not Locked);
6303 pragma Assert (Nkind (N) in N_Entity);
6304 Nodes.Table (N + 1).Field11 := Union_Id (Val);
6307 procedure Set_Elist13 (N : Node_Id; Val : Elist_Id) is
6309 pragma Assert (not Locked);
6310 pragma Assert (Nkind (N) in N_Entity);
6311 Nodes.Table (N + 2).Field6 := Union_Id (Val);
6314 procedure Set_Elist15 (N : Node_Id; Val : Elist_Id) is
6316 pragma Assert (not Locked);
6317 pragma Assert (Nkind (N) in N_Entity);
6318 Nodes.Table (N + 2).Field8 := Union_Id (Val);
6321 procedure Set_Elist16 (N : Node_Id; Val : Elist_Id) is
6323 pragma Assert (not Locked);
6324 pragma Assert (Nkind (N) in N_Entity);
6325 Nodes.Table (N + 2).Field9 := Union_Id (Val);
6328 procedure Set_Elist18 (N : Node_Id; Val : Elist_Id) is
6330 pragma Assert (not Locked);
6331 pragma Assert (Nkind (N) in N_Entity);
6332 Nodes.Table (N + 2).Field11 := Union_Id (Val);
6335 procedure Set_Elist21 (N : Node_Id; Val : Elist_Id) is
6337 pragma Assert (not Locked);
6338 pragma Assert (Nkind (N) in N_Entity);
6339 Nodes.Table (N + 3).Field8 := Union_Id (Val);
6342 procedure Set_Elist23 (N : Node_Id; Val : Elist_Id) is
6344 pragma Assert (not Locked);
6345 pragma Assert (Nkind (N) in N_Entity);
6346 Nodes.Table (N + 3).Field10 := Union_Id (Val);
6349 procedure Set_Elist24 (N : Node_Id; Val : Elist_Id) is
6351 pragma Assert (not Locked);
6352 pragma Assert (Nkind (N) in N_Entity);
6353 Nodes.Table (N + 4).Field6 := Union_Id (Val);
6356 procedure Set_Elist25 (N : Node_Id; Val : Elist_Id) is
6358 pragma Assert (not Locked);
6359 pragma Assert (Nkind (N) in N_Entity);
6360 Nodes.Table (N + 4).Field7 := Union_Id (Val);
6363 procedure Set_Elist26 (N : Node_Id; Val : Elist_Id) is
6365 pragma Assert (not Locked);
6366 pragma Assert (Nkind (N) in N_Entity);
6367 Nodes.Table (N + 4).Field8 := Union_Id (Val);
6370 procedure Set_Elist29 (N : Node_Id; Val : Elist_Id) is
6372 pragma Assert (not Locked);
6373 pragma Assert (Nkind (N) in N_Entity);
6374 Nodes.Table (N + 4).Field11 := Union_Id (Val);
6377 procedure Set_Elist30 (N : Node_Id; Val : Elist_Id) is
6379 pragma Assert (not Locked);
6380 pragma Assert (Nkind (N) in N_Entity);
6381 Nodes.Table (N + 5).Field6 := Union_Id (Val);
6384 procedure Set_Elist36 (N : Node_Id; Val : Elist_Id) is
6386 pragma Assert (not Locked);
6387 pragma Assert (Nkind (N) in N_Entity);
6388 Nodes.Table (N + 6).Field6 := Union_Id (Val);
6391 procedure Set_Name1 (N : Node_Id; Val : Name_Id) is
6393 pragma Assert (not Locked);
6394 pragma Assert (N <= Nodes.Last);
6395 Nodes.Table (N).Field1 := Union_Id (Val);
6398 procedure Set_Name2 (N : Node_Id; Val : Name_Id) is
6400 pragma Assert (not Locked);
6401 pragma Assert (N <= Nodes.Last);
6402 Nodes.Table (N).Field2 := Union_Id (Val);
6405 procedure Set_Str3 (N : Node_Id; Val : String_Id) is
6407 pragma Assert (not Locked);
6408 pragma Assert (N <= Nodes.Last);
6409 Nodes.Table (N).Field3 := Union_Id (Val);
6412 procedure Set_Uint2 (N : Node_Id; Val : Uint) is
6414 pragma Assert (not Locked);
6415 pragma Assert (N <= Nodes.Last);
6416 Nodes.Table (N).Field2 := To_Union (Val);
6419 procedure Set_Uint3 (N : Node_Id; Val : Uint) is
6421 pragma Assert (not Locked);
6422 pragma Assert (N <= Nodes.Last);
6423 Nodes.Table (N).Field3 := To_Union (Val);
6426 procedure Set_Uint4 (N : Node_Id; Val : Uint) is
6428 pragma Assert (not Locked);
6429 pragma Assert (N <= Nodes.Last);
6430 Nodes.Table (N).Field4 := To_Union (Val);
6433 procedure Set_Uint5 (N : Node_Id; Val : Uint) is
6435 pragma Assert (not Locked);
6436 pragma Assert (N <= Nodes.Last);
6437 Nodes.Table (N).Field5 := To_Union (Val);
6440 procedure Set_Uint8 (N : Node_Id; Val : Uint) is
6442 pragma Assert (not Locked);
6443 pragma Assert (Nkind (N) in N_Entity);
6444 Nodes.Table (N + 1).Field8 := To_Union (Val);
6447 procedure Set_Uint9 (N : Node_Id; Val : Uint) is
6449 pragma Assert (not Locked);
6450 pragma Assert (Nkind (N) in N_Entity);
6451 Nodes.Table (N + 1).Field9 := To_Union (Val);
6454 procedure Set_Uint10 (N : Node_Id; Val : Uint) is
6456 pragma Assert (not Locked);
6457 pragma Assert (Nkind (N) in N_Entity);
6458 Nodes.Table (N + 1).Field10 := To_Union (Val);
6461 procedure Set_Uint11 (N : Node_Id; Val : Uint) is
6463 pragma Assert (not Locked);
6464 pragma Assert (Nkind (N) in N_Entity);
6465 Nodes.Table (N + 1).Field11 := To_Union (Val);
6468 procedure Set_Uint12 (N : Node_Id; Val : Uint) is
6470 pragma Assert (not Locked);
6471 pragma Assert (Nkind (N) in N_Entity);
6472 Nodes.Table (N + 1).Field12 := To_Union (Val);
6475 procedure Set_Uint13 (N : Node_Id; Val : Uint) is
6477 pragma Assert (not Locked);
6478 pragma Assert (Nkind (N) in N_Entity);
6479 Nodes.Table (N + 2).Field6 := To_Union (Val);
6482 procedure Set_Uint14 (N : Node_Id; Val : Uint) is
6484 pragma Assert (not Locked);
6485 pragma Assert (Nkind (N) in N_Entity);
6486 Nodes.Table (N + 2).Field7 := To_Union (Val);
6489 procedure Set_Uint15 (N : Node_Id; Val : Uint) is
6491 pragma Assert (not Locked);
6492 pragma Assert (Nkind (N) in N_Entity);
6493 Nodes.Table (N + 2).Field8 := To_Union (Val);
6496 procedure Set_Uint16 (N : Node_Id; Val : Uint) is
6498 pragma Assert (not Locked);
6499 pragma Assert (Nkind (N) in N_Entity);
6500 Nodes.Table (N + 2).Field9 := To_Union (Val);
6503 procedure Set_Uint17 (N : Node_Id; Val : Uint) is
6505 pragma Assert (not Locked);
6506 pragma Assert (Nkind (N) in N_Entity);
6507 Nodes.Table (N + 2).Field10 := To_Union (Val);
6510 procedure Set_Uint22 (N : Node_Id; Val : Uint) is
6512 pragma Assert (not Locked);
6513 pragma Assert (Nkind (N) in N_Entity);
6514 Nodes.Table (N + 3).Field9 := To_Union (Val);
6517 procedure Set_Uint24 (N : Node_Id; Val : Uint) is
6519 pragma Assert (not Locked);
6520 pragma Assert (Nkind (N) in N_Entity);
6521 Nodes.Table (N + 4).Field6 := To_Union (Val);
6524 procedure Set_Ureal3 (N : Node_Id; Val : Ureal) is
6526 pragma Assert (not Locked);
6527 pragma Assert (N <= Nodes.Last);
6528 Nodes.Table (N).Field3 := To_Union (Val);
6531 procedure Set_Ureal18 (N : Node_Id; Val : Ureal) is
6533 pragma Assert (not Locked);
6534 pragma Assert (Nkind (N) in N_Entity);
6535 Nodes.Table (N + 2).Field11 := To_Union (Val);
6538 procedure Set_Ureal21 (N : Node_Id; Val : Ureal) is
6540 pragma Assert (not Locked);
6541 pragma Assert (Nkind (N) in N_Entity);
6542 Nodes.Table (N + 3).Field8 := To_Union (Val);
6545 procedure Set_Flag0 (N : Node_Id; Val : Boolean) is
6547 pragma Assert (not Locked);
6548 pragma Assert (N <= Nodes.Last);
6549 Flags.Table (N).Flag0 := Val;
6552 procedure Set_Flag1 (N : Node_Id; Val : Boolean) is
6554 pragma Assert (not Locked);
6555 pragma Assert (N <= Nodes.Last);
6556 Flags.Table (N).Flag1 := Val;
6559 procedure Set_Flag2 (N : Node_Id; Val : Boolean) is
6561 pragma Assert (not Locked);
6562 pragma Assert (N <= Nodes.Last);
6563 Flags.Table (N).Flag2 := Val;
6566 procedure Set_Flag3 (N : Node_Id; Val : Boolean) is
6568 pragma Assert (not Locked);
6569 pragma Assert (N <= Nodes.Last);
6570 Flags.Table (N).Flag3 := Val;
6573 procedure Set_Flag4 (N : Node_Id; Val : Boolean) is
6575 pragma Assert (not Locked);
6576 pragma Assert (N <= Nodes.Last);
6577 Nodes.Table (N).Flag4 := Val;
6580 procedure Set_Flag5 (N : Node_Id; Val : Boolean) is
6582 pragma Assert (not Locked);
6583 pragma Assert (N <= Nodes.Last);
6584 Nodes.Table (N).Flag5 := Val;
6587 procedure Set_Flag6 (N : Node_Id; Val : Boolean) is
6589 pragma Assert (not Locked);
6590 pragma Assert (N <= Nodes.Last);
6591 Nodes.Table (N).Flag6 := Val;
6594 procedure Set_Flag7 (N : Node_Id; Val : Boolean) is
6596 pragma Assert (not Locked);
6597 pragma Assert (N <= Nodes.Last);
6598 Nodes.Table (N).Flag7 := Val;
6601 procedure Set_Flag8 (N : Node_Id; Val : Boolean) is
6603 pragma Assert (not Locked);
6604 pragma Assert (N <= Nodes.Last);
6605 Nodes.Table (N).Flag8 := Val;
6608 procedure Set_Flag9 (N : Node_Id; Val : Boolean) is
6610 pragma Assert (not Locked);
6611 pragma Assert (N <= Nodes.Last);
6612 Nodes.Table (N).Flag9 := Val;
6615 procedure Set_Flag10 (N : Node_Id; Val : Boolean) is
6617 pragma Assert (not Locked);
6618 pragma Assert (N <= Nodes.Last);
6619 Nodes.Table (N).Flag10 := Val;
6622 procedure Set_Flag11 (N : Node_Id; Val : Boolean) is
6624 pragma Assert (not Locked);
6625 pragma Assert (N <= Nodes.Last);
6626 Nodes.Table (N).Flag11 := Val;
6629 procedure Set_Flag12 (N : Node_Id; Val : Boolean) is
6631 pragma Assert (not Locked);
6632 pragma Assert (N <= Nodes.Last);
6633 Nodes.Table (N).Flag12 := Val;
6636 procedure Set_Flag13 (N : Node_Id; Val : Boolean) is
6638 pragma Assert (not Locked);
6639 pragma Assert (N <= Nodes.Last);
6640 Nodes.Table (N).Flag13 := Val;
6643 procedure Set_Flag14 (N : Node_Id; Val : Boolean) is
6645 pragma Assert (not Locked);
6646 pragma Assert (N <= Nodes.Last);
6647 Nodes.Table (N).Flag14 := Val;
6650 procedure Set_Flag15 (N : Node_Id; Val : Boolean) is
6652 pragma Assert (not Locked);
6653 pragma Assert (N <= Nodes.Last);
6654 Nodes.Table (N).Flag15 := Val;
6657 procedure Set_Flag16 (N : Node_Id; Val : Boolean) is
6659 pragma Assert (not Locked);
6660 pragma Assert (N <= Nodes.Last);
6661 Nodes.Table (N).Flag16 := Val;
6664 procedure Set_Flag17 (N : Node_Id; Val : Boolean) is
6666 pragma Assert (not Locked);
6667 pragma Assert (N <= Nodes.Last);
6668 Nodes.Table (N).Flag17 := Val;
6671 procedure Set_Flag18 (N : Node_Id; Val : Boolean) is
6673 pragma Assert (not Locked);
6674 pragma Assert (N <= Nodes.Last);
6675 Nodes.Table (N).Flag18 := Val;
6678 procedure Set_Flag19 (N : Node_Id; Val : Boolean) is
6680 pragma Assert (not Locked);
6681 pragma Assert (Nkind (N) in N_Entity);
6682 Nodes.Table (N + 1).In_List := Val;
6685 procedure Set_Flag20 (N : Node_Id; Val : Boolean) is
6687 pragma Assert (not Locked);
6688 pragma Assert (Nkind (N) in N_Entity);
6689 Nodes.Table (N + 1).Has_Aspects := Val;
6692 procedure Set_Flag21 (N : Node_Id; Val : Boolean) is
6694 pragma Assert (not Locked);
6695 pragma Assert (Nkind (N) in N_Entity);
6696 Nodes.Table (N + 1).Rewrite_Ins := Val;
6699 procedure Set_Flag22 (N : Node_Id; Val : Boolean) is
6701 pragma Assert (not Locked);
6702 pragma Assert (Nkind (N) in N_Entity);
6703 Nodes.Table (N + 1).Analyzed := Val;
6706 procedure Set_Flag23 (N : Node_Id; Val : Boolean) is
6708 pragma Assert (not Locked);
6709 pragma Assert (Nkind (N) in N_Entity);
6710 Nodes.Table (N + 1).Comes_From_Source := Val;
6713 procedure Set_Flag24 (N : Node_Id; Val : Boolean) is
6715 pragma Assert (not Locked);
6716 pragma Assert (Nkind (N) in N_Entity);
6717 Nodes.Table (N + 1).Error_Posted := Val;
6720 procedure Set_Flag25 (N : Node_Id; Val : Boolean) is
6722 pragma Assert (not Locked);
6723 pragma Assert (Nkind (N) in N_Entity);
6724 Nodes.Table (N + 1).Flag4 := Val;
6727 procedure Set_Flag26 (N : Node_Id; Val : Boolean) is
6729 pragma Assert (not Locked);
6730 pragma Assert (Nkind (N) in N_Entity);
6731 Nodes.Table (N + 1).Flag5 := Val;
6734 procedure Set_Flag27 (N : Node_Id; Val : Boolean) is
6736 pragma Assert (not Locked);
6737 pragma Assert (Nkind (N) in N_Entity);
6738 Nodes.Table (N + 1).Flag6 := Val;
6741 procedure Set_Flag28 (N : Node_Id; Val : Boolean) is
6743 pragma Assert (not Locked);
6744 pragma Assert (Nkind (N) in N_Entity);
6745 Nodes.Table (N + 1).Flag7 := Val;
6748 procedure Set_Flag29 (N : Node_Id; Val : Boolean) is
6750 pragma Assert (not Locked);
6751 pragma Assert (Nkind (N) in N_Entity);
6752 Nodes.Table (N + 1).Flag8 := Val;
6755 procedure Set_Flag30 (N : Node_Id; Val : Boolean) is
6757 pragma Assert (not Locked);
6758 pragma Assert (Nkind (N) in N_Entity);
6759 Nodes.Table (N + 1).Flag9 := Val;
6762 procedure Set_Flag31 (N : Node_Id; Val : Boolean) is
6764 pragma Assert (not Locked);
6765 pragma Assert (Nkind (N) in N_Entity);
6766 Nodes.Table (N + 1).Flag10 := Val;
6769 procedure Set_Flag32 (N : Node_Id; Val : Boolean) is
6771 pragma Assert (not Locked);
6772 pragma Assert (Nkind (N) in N_Entity);
6773 Nodes.Table (N + 1).Flag11 := Val;
6776 procedure Set_Flag33 (N : Node_Id; Val : Boolean) is
6778 pragma Assert (not Locked);
6779 pragma Assert (Nkind (N) in N_Entity);
6780 Nodes.Table (N + 1).Flag12 := Val;
6783 procedure Set_Flag34 (N : Node_Id; Val : Boolean) is
6785 pragma Assert (not Locked);
6786 pragma Assert (Nkind (N) in N_Entity);
6787 Nodes.Table (N + 1).Flag13 := Val;
6790 procedure Set_Flag35 (N : Node_Id; Val : Boolean) is
6792 pragma Assert (not Locked);
6793 pragma Assert (Nkind (N) in N_Entity);
6794 Nodes.Table (N + 1).Flag14 := Val;
6797 procedure Set_Flag36 (N : Node_Id; Val : Boolean) is
6799 pragma Assert (not Locked);
6800 pragma Assert (Nkind (N) in N_Entity);
6801 Nodes.Table (N + 1).Flag15 := Val;
6804 procedure Set_Flag37 (N : Node_Id; Val : Boolean) is
6806 pragma Assert (not Locked);
6807 pragma Assert (Nkind (N) in N_Entity);
6808 Nodes.Table (N + 1).Flag16 := Val;
6811 procedure Set_Flag38 (N : Node_Id; Val : Boolean) is
6813 pragma Assert (not Locked);
6814 pragma Assert (Nkind (N) in N_Entity);
6815 Nodes.Table (N + 1).Flag17 := Val;
6818 procedure Set_Flag39 (N : Node_Id; Val : Boolean) is
6820 pragma Assert (not Locked);
6821 pragma Assert (Nkind (N) in N_Entity);
6822 Nodes.Table (N + 1).Flag18 := Val;
6825 procedure Set_Flag40 (N : Node_Id; Val : Boolean) is
6827 pragma Assert (not Locked);
6828 pragma Assert (Nkind (N) in N_Entity);
6829 Nodes.Table (N + 2).In_List := Val;
6832 procedure Set_Flag41 (N : Node_Id; Val : Boolean) is
6834 pragma Assert (not Locked);
6835 pragma Assert (Nkind (N) in N_Entity);
6836 Nodes.Table (N + 2).Has_Aspects := Val;
6839 procedure Set_Flag42 (N : Node_Id; Val : Boolean) is
6841 pragma Assert (not Locked);
6842 pragma Assert (Nkind (N) in N_Entity);
6843 Nodes.Table (N + 2).Rewrite_Ins := Val;
6846 procedure Set_Flag43 (N : Node_Id; Val : Boolean) is
6848 pragma Assert (not Locked);
6849 pragma Assert (Nkind (N) in N_Entity);
6850 Nodes.Table (N + 2).Analyzed := Val;
6853 procedure Set_Flag44 (N : Node_Id; Val : Boolean) is
6855 pragma Assert (not Locked);
6856 pragma Assert (Nkind (N) in N_Entity);
6857 Nodes.Table (N + 2).Comes_From_Source := Val;
6860 procedure Set_Flag45 (N : Node_Id; Val : Boolean) is
6862 pragma Assert (not Locked);
6863 pragma Assert (Nkind (N) in N_Entity);
6864 Nodes.Table (N + 2).Error_Posted := Val;
6867 procedure Set_Flag46 (N : Node_Id; Val : Boolean) is
6869 pragma Assert (not Locked);
6870 pragma Assert (Nkind (N) in N_Entity);
6871 Nodes.Table (N + 2).Flag4 := Val;
6874 procedure Set_Flag47 (N : Node_Id; Val : Boolean) is
6876 pragma Assert (not Locked);
6877 pragma Assert (Nkind (N) in N_Entity);
6878 Nodes.Table (N + 2).Flag5 := Val;
6881 procedure Set_Flag48 (N : Node_Id; Val : Boolean) is
6883 pragma Assert (not Locked);
6884 pragma Assert (Nkind (N) in N_Entity);
6885 Nodes.Table (N + 2).Flag6 := Val;
6888 procedure Set_Flag49 (N : Node_Id; Val : Boolean) is
6890 pragma Assert (not Locked);
6891 pragma Assert (Nkind (N) in N_Entity);
6892 Nodes.Table (N + 2).Flag7 := Val;
6895 procedure Set_Flag50 (N : Node_Id; Val : Boolean) is
6897 pragma Assert (not Locked);
6898 pragma Assert (Nkind (N) in N_Entity);
6899 Nodes.Table (N + 2).Flag8 := Val;
6902 procedure Set_Flag51 (N : Node_Id; Val : Boolean) is
6904 pragma Assert (not Locked);
6905 pragma Assert (Nkind (N) in N_Entity);
6906 Nodes.Table (N + 2).Flag9 := Val;
6909 procedure Set_Flag52 (N : Node_Id; Val : Boolean) is
6911 pragma Assert (not Locked);
6912 pragma Assert (Nkind (N) in N_Entity);
6913 Nodes.Table (N + 2).Flag10 := Val;
6916 procedure Set_Flag53 (N : Node_Id; Val : Boolean) is
6918 pragma Assert (not Locked);
6919 pragma Assert (Nkind (N) in N_Entity);
6920 Nodes.Table (N + 2).Flag11 := Val;
6923 procedure Set_Flag54 (N : Node_Id; Val : Boolean) is
6925 pragma Assert (not Locked);
6926 pragma Assert (Nkind (N) in N_Entity);
6927 Nodes.Table (N + 2).Flag12 := Val;
6930 procedure Set_Flag55 (N : Node_Id; Val : Boolean) is
6932 pragma Assert (not Locked);
6933 pragma Assert (Nkind (N) in N_Entity);
6934 Nodes.Table (N + 2).Flag13 := Val;
6937 procedure Set_Flag56 (N : Node_Id; Val : Boolean) is
6939 pragma Assert (not Locked);
6940 pragma Assert (Nkind (N) in N_Entity);
6941 Nodes.Table (N + 2).Flag14 := Val;
6944 procedure Set_Flag57 (N : Node_Id; Val : Boolean) is
6946 pragma Assert (not Locked);
6947 pragma Assert (Nkind (N) in N_Entity);
6948 Nodes.Table (N + 2).Flag15 := Val;
6951 procedure Set_Flag58 (N : Node_Id; Val : Boolean) is
6953 pragma Assert (not Locked);
6954 pragma Assert (Nkind (N) in N_Entity);
6955 Nodes.Table (N + 2).Flag16 := Val;
6958 procedure Set_Flag59 (N : Node_Id; Val : Boolean) is
6960 pragma Assert (not Locked);
6961 pragma Assert (Nkind (N) in N_Entity);
6962 Nodes.Table (N + 2).Flag17 := Val;
6965 procedure Set_Flag60 (N : Node_Id; Val : Boolean) is
6967 pragma Assert (not Locked);
6968 pragma Assert (Nkind (N) in N_Entity);
6969 Nodes.Table (N + 2).Flag18 := Val;
6972 procedure Set_Flag61 (N : Node_Id; Val : Boolean) is
6974 pragma Assert (not Locked);
6975 pragma Assert (Nkind (N) in N_Entity);
6976 Nodes.Table (N + 1).Pflag1 := Val;
6979 procedure Set_Flag62 (N : Node_Id; Val : Boolean) is
6981 pragma Assert (not Locked);
6982 pragma Assert (Nkind (N) in N_Entity);
6983 Nodes.Table (N + 1).Pflag2 := Val;
6986 procedure Set_Flag63 (N : Node_Id; Val : Boolean) is
6988 pragma Assert (not Locked);
6989 pragma Assert (Nkind (N) in N_Entity);
6990 Nodes.Table (N + 2).Pflag1 := Val;
6993 procedure Set_Flag64 (N : Node_Id; Val : Boolean) is
6995 pragma Assert (not Locked);
6996 pragma Assert (Nkind (N) in N_Entity);
6997 Nodes.Table (N + 2).Pflag2 := Val;
7000 procedure Set_Flag65 (N : Node_Id; Val : Boolean) is
7002 pragma Assert (not Locked);
7003 pragma Assert (Nkind (N) in N_Entity);
7006 (Nodes
.Table
(N
+ 2).Nkind
'Unrestricted_Access)).Flag65
:= Val
;
7009 procedure Set_Flag66
(N
: Node_Id
; Val
: Boolean) is
7011 pragma Assert
(not Locked
);
7012 pragma Assert
(Nkind
(N
) in N_Entity
);
7015 (Nodes.Table (N + 2).Nkind'Unrestricted_Access)).Flag66 := Val;
7018 procedure Set_Flag67 (N : Node_Id; Val : Boolean) is
7020 pragma Assert (not Locked);
7021 pragma Assert (Nkind (N) in N_Entity);
7024 (Nodes
.Table
(N
+ 2).Nkind
'Unrestricted_Access)).Flag67
:= Val
;
7027 procedure Set_Flag68
(N
: Node_Id
; Val
: Boolean) is
7029 pragma Assert
(not Locked
);
7030 pragma Assert
(Nkind
(N
) in N_Entity
);
7033 (Nodes.Table (N + 2).Nkind'Unrestricted_Access)).Flag68 := Val;
7036 procedure Set_Flag69 (N : Node_Id; Val : Boolean) is
7038 pragma Assert (not Locked);
7039 pragma Assert (Nkind (N) in N_Entity);
7042 (Nodes
.Table
(N
+ 2).Nkind
'Unrestricted_Access)).Flag69
:= Val
;
7045 procedure Set_Flag70
(N
: Node_Id
; Val
: Boolean) is
7047 pragma Assert
(not Locked
);
7048 pragma Assert
(Nkind
(N
) in N_Entity
);
7051 (Nodes.Table (N + 2).Nkind'Unrestricted_Access)).Flag70 := Val;
7054 procedure Set_Flag71 (N : Node_Id; Val : Boolean) is
7056 pragma Assert (not Locked);
7057 pragma Assert (Nkind (N) in N_Entity);
7060 (Nodes
.Table
(N
+ 2).Nkind
'Unrestricted_Access)).Flag71
:= Val
;
7063 procedure Set_Flag72
(N
: Node_Id
; Val
: Boolean) is
7065 pragma Assert
(not Locked
);
7066 pragma Assert
(Nkind
(N
) in N_Entity
);
7069 (Nodes.Table (N + 2).Nkind'Unrestricted_Access)).Flag72 := Val;
7072 procedure Set_Flag73 (N : Node_Id; Val : Boolean) is
7074 pragma Assert (not Locked);
7075 pragma Assert (Nkind (N) in N_Entity);
7078 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag73
:= Val
;
7081 procedure Set_Flag74
(N
: Node_Id
; Val
: Boolean) is
7083 pragma Assert
(not Locked
);
7084 pragma Assert
(Nkind
(N
) in N_Entity
);
7087 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag74 := Val;
7090 procedure Set_Flag75 (N : Node_Id; Val : Boolean) is
7092 pragma Assert (not Locked);
7093 pragma Assert (Nkind (N) in N_Entity);
7096 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag75
:= Val
;
7099 procedure Set_Flag76
(N
: Node_Id
; Val
: Boolean) is
7101 pragma Assert
(not Locked
);
7102 pragma Assert
(Nkind
(N
) in N_Entity
);
7105 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag76 := Val;
7108 procedure Set_Flag77 (N : Node_Id; Val : Boolean) is
7110 pragma Assert (not Locked);
7111 pragma Assert (Nkind (N) in N_Entity);
7114 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag77
:= Val
;
7117 procedure Set_Flag78
(N
: Node_Id
; Val
: Boolean) is
7119 pragma Assert
(not Locked
);
7120 pragma Assert
(Nkind
(N
) in N_Entity
);
7123 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag78 := Val;
7126 procedure Set_Flag79 (N : Node_Id; Val : Boolean) is
7128 pragma Assert (not Locked);
7129 pragma Assert (Nkind (N) in N_Entity);
7132 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag79
:= Val
;
7135 procedure Set_Flag80
(N
: Node_Id
; Val
: Boolean) is
7137 pragma Assert
(not Locked
);
7138 pragma Assert
(Nkind
(N
) in N_Entity
);
7141 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag80 := Val;
7144 procedure Set_Flag81 (N : Node_Id; Val : Boolean) is
7146 pragma Assert (not Locked);
7147 pragma Assert (Nkind (N) in N_Entity);
7150 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag81
:= Val
;
7153 procedure Set_Flag82
(N
: Node_Id
; Val
: Boolean) is
7155 pragma Assert
(not Locked
);
7156 pragma Assert
(Nkind
(N
) in N_Entity
);
7159 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag82 := Val;
7162 procedure Set_Flag83 (N : Node_Id; Val : Boolean) is
7164 pragma Assert (not Locked);
7165 pragma Assert (Nkind (N) in N_Entity);
7168 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag83
:= Val
;
7171 procedure Set_Flag84
(N
: Node_Id
; Val
: Boolean) is
7173 pragma Assert
(not Locked
);
7174 pragma Assert
(Nkind
(N
) in N_Entity
);
7177 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag84 := Val;
7180 procedure Set_Flag85 (N : Node_Id; Val : Boolean) is
7182 pragma Assert (not Locked);
7183 pragma Assert (Nkind (N) in N_Entity);
7186 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag85
:= Val
;
7189 procedure Set_Flag86
(N
: Node_Id
; Val
: Boolean) is
7191 pragma Assert
(not Locked
);
7192 pragma Assert
(Nkind
(N
) in N_Entity
);
7195 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag86 := Val;
7198 procedure Set_Flag87 (N : Node_Id; Val : Boolean) is
7200 pragma Assert (not Locked);
7201 pragma Assert (Nkind (N) in N_Entity);
7204 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag87
:= Val
;
7207 procedure Set_Flag88
(N
: Node_Id
; Val
: Boolean) is
7209 pragma Assert
(not Locked
);
7210 pragma Assert
(Nkind
(N
) in N_Entity
);
7213 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag88 := Val;
7216 procedure Set_Flag89 (N : Node_Id; Val : Boolean) is
7218 pragma Assert (not Locked);
7219 pragma Assert (Nkind (N) in N_Entity);
7222 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag89
:= Val
;
7225 procedure Set_Flag90
(N
: Node_Id
; Val
: Boolean) is
7227 pragma Assert
(not Locked
);
7228 pragma Assert
(Nkind
(N
) in N_Entity
);
7231 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag90 := Val;
7234 procedure Set_Flag91 (N : Node_Id; Val : Boolean) is
7236 pragma Assert (not Locked);
7237 pragma Assert (Nkind (N) in N_Entity);
7240 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag91
:= Val
;
7243 procedure Set_Flag92
(N
: Node_Id
; Val
: Boolean) is
7245 pragma Assert
(not Locked
);
7246 pragma Assert
(Nkind
(N
) in N_Entity
);
7249 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag92 := Val;
7252 procedure Set_Flag93 (N : Node_Id; Val : Boolean) is
7254 pragma Assert (not Locked);
7255 pragma Assert (Nkind (N) in N_Entity);
7258 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag93
:= Val
;
7261 procedure Set_Flag94
(N
: Node_Id
; Val
: Boolean) is
7263 pragma Assert
(not Locked
);
7264 pragma Assert
(Nkind
(N
) in N_Entity
);
7267 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag94 := Val;
7270 procedure Set_Flag95 (N : Node_Id; Val : Boolean) is
7272 pragma Assert (not Locked);
7273 pragma Assert (Nkind (N) in N_Entity);
7276 (Nodes
.Table
(N
+ 2).Field12
'Unrestricted_Access)).Flag95
:= Val
;
7279 procedure Set_Flag96
(N
: Node_Id
; Val
: Boolean) is
7281 pragma Assert
(not Locked
);
7282 pragma Assert
(Nkind
(N
) in N_Entity
);
7285 (Nodes.Table (N + 2).Field12'Unrestricted_Access)).Flag96 := Val;
7288 procedure Set_Flag97 (N : Node_Id; Val : Boolean) is
7290 pragma Assert (not Locked);
7291 pragma Assert (Nkind (N) in N_Entity);
7294 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag97
:= Val
;
7297 procedure Set_Flag98
(N
: Node_Id
; Val
: Boolean) is
7299 pragma Assert
(not Locked
);
7300 pragma Assert
(Nkind
(N
) in N_Entity
);
7303 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag98 := Val;
7306 procedure Set_Flag99 (N : Node_Id; Val : Boolean) is
7308 pragma Assert (not Locked);
7309 pragma Assert (Nkind (N) in N_Entity);
7312 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag99
:= Val
;
7315 procedure Set_Flag100
(N
: Node_Id
; Val
: Boolean) is
7317 pragma Assert
(not Locked
);
7318 pragma Assert
(Nkind
(N
) in N_Entity
);
7321 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag100 := Val;
7324 procedure Set_Flag101 (N : Node_Id; Val : Boolean) is
7326 pragma Assert (not Locked);
7327 pragma Assert (Nkind (N) in N_Entity);
7330 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag101
:= Val
;
7333 procedure Set_Flag102
(N
: Node_Id
; Val
: Boolean) is
7335 pragma Assert
(not Locked
);
7336 pragma Assert
(Nkind
(N
) in N_Entity
);
7339 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag102 := Val;
7342 procedure Set_Flag103 (N : Node_Id; Val : Boolean) is
7344 pragma Assert (not Locked);
7345 pragma Assert (Nkind (N) in N_Entity);
7348 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag103
:= Val
;
7351 procedure Set_Flag104
(N
: Node_Id
; Val
: Boolean) is
7353 pragma Assert
(not Locked
);
7354 pragma Assert
(Nkind
(N
) in N_Entity
);
7357 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag104 := Val;
7360 procedure Set_Flag105 (N : Node_Id; Val : Boolean) is
7362 pragma Assert (not Locked);
7363 pragma Assert (Nkind (N) in N_Entity);
7366 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag105
:= Val
;
7369 procedure Set_Flag106
(N
: Node_Id
; Val
: Boolean) is
7371 pragma Assert
(not Locked
);
7372 pragma Assert
(Nkind
(N
) in N_Entity
);
7375 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag106 := Val;
7378 procedure Set_Flag107 (N : Node_Id; Val : Boolean) is
7380 pragma Assert (not Locked);
7381 pragma Assert (Nkind (N) in N_Entity);
7384 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag107
:= Val
;
7387 procedure Set_Flag108
(N
: Node_Id
; Val
: Boolean) is
7389 pragma Assert
(not Locked
);
7390 pragma Assert
(Nkind
(N
) in N_Entity
);
7393 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag108 := Val;
7396 procedure Set_Flag109 (N : Node_Id; Val : Boolean) is
7398 pragma Assert (not Locked);
7399 pragma Assert (Nkind (N) in N_Entity);
7402 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag109
:= Val
;
7405 procedure Set_Flag110
(N
: Node_Id
; Val
: Boolean) is
7407 pragma Assert
(not Locked
);
7408 pragma Assert
(Nkind
(N
) in N_Entity
);
7411 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag110 := Val;
7414 procedure Set_Flag111 (N : Node_Id; Val : Boolean) is
7416 pragma Assert (not Locked);
7417 pragma Assert (Nkind (N) in N_Entity);
7420 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag111
:= Val
;
7423 procedure Set_Flag112
(N
: Node_Id
; Val
: Boolean) is
7425 pragma Assert
(not Locked
);
7426 pragma Assert
(Nkind
(N
) in N_Entity
);
7429 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag112 := Val;
7432 procedure Set_Flag113 (N : Node_Id; Val : Boolean) is
7434 pragma Assert (not Locked);
7435 pragma Assert (Nkind (N) in N_Entity);
7438 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag113
:= Val
;
7441 procedure Set_Flag114
(N
: Node_Id
; Val
: Boolean) is
7443 pragma Assert
(not Locked
);
7444 pragma Assert
(Nkind
(N
) in N_Entity
);
7447 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag114 := Val;
7450 procedure Set_Flag115 (N : Node_Id; Val : Boolean) is
7452 pragma Assert (not Locked);
7453 pragma Assert (Nkind (N) in N_Entity);
7456 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag115
:= Val
;
7459 procedure Set_Flag116
(N
: Node_Id
; Val
: Boolean) is
7461 pragma Assert
(not Locked
);
7462 pragma Assert
(Nkind
(N
) in N_Entity
);
7465 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag116 := Val;
7468 procedure Set_Flag117 (N : Node_Id; Val : Boolean) is
7470 pragma Assert (not Locked);
7471 pragma Assert (Nkind (N) in N_Entity);
7474 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag117
:= Val
;
7477 procedure Set_Flag118
(N
: Node_Id
; Val
: Boolean) is
7479 pragma Assert
(not Locked
);
7480 pragma Assert
(Nkind
(N
) in N_Entity
);
7483 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag118 := Val;
7486 procedure Set_Flag119 (N : Node_Id; Val : Boolean) is
7488 pragma Assert (not Locked);
7489 pragma Assert (Nkind (N) in N_Entity);
7492 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag119
:= Val
;
7495 procedure Set_Flag120
(N
: Node_Id
; Val
: Boolean) is
7497 pragma Assert
(not Locked
);
7498 pragma Assert
(Nkind
(N
) in N_Entity
);
7501 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag120 := Val;
7504 procedure Set_Flag121 (N : Node_Id; Val : Boolean) is
7506 pragma Assert (not Locked);
7507 pragma Assert (Nkind (N) in N_Entity);
7510 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag121
:= Val
;
7513 procedure Set_Flag122
(N
: Node_Id
; Val
: Boolean) is
7515 pragma Assert
(not Locked
);
7516 pragma Assert
(Nkind
(N
) in N_Entity
);
7519 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag122 := Val;
7522 procedure Set_Flag123 (N : Node_Id; Val : Boolean) is
7524 pragma Assert (not Locked);
7525 pragma Assert (Nkind (N) in N_Entity);
7528 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag123
:= Val
;
7531 procedure Set_Flag124
(N
: Node_Id
; Val
: Boolean) is
7533 pragma Assert
(not Locked
);
7534 pragma Assert
(Nkind
(N
) in N_Entity
);
7537 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag124 := Val;
7540 procedure Set_Flag125 (N : Node_Id; Val : Boolean) is
7542 pragma Assert (not Locked);
7543 pragma Assert (Nkind (N) in N_Entity);
7546 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag125
:= Val
;
7549 procedure Set_Flag126
(N
: Node_Id
; Val
: Boolean) is
7551 pragma Assert
(not Locked
);
7552 pragma Assert
(Nkind
(N
) in N_Entity
);
7555 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag126 := Val;
7558 procedure Set_Flag127 (N : Node_Id; Val : Boolean) is
7560 pragma Assert (not Locked);
7561 pragma Assert (Nkind (N) in N_Entity);
7564 (Nodes
.Table
(N
+ 3).Field12
'Unrestricted_Access)).Flag127
:= Val
;
7567 procedure Set_Flag128
(N
: Node_Id
; Val
: Boolean) is
7569 pragma Assert
(not Locked
);
7570 pragma Assert
(Nkind
(N
) in N_Entity
);
7573 (Nodes.Table (N + 3).Field12'Unrestricted_Access)).Flag128 := Val;
7576 procedure Set_Flag129 (N : Node_Id; Val : Boolean) is
7578 pragma Assert (not Locked);
7579 pragma Assert (Nkind (N) in N_Entity);
7580 Nodes.Table (N + 3).In_List := Val;
7583 procedure Set_Flag130 (N : Node_Id; Val : Boolean) is
7585 pragma Assert (not Locked);
7586 pragma Assert (Nkind (N) in N_Entity);
7587 Nodes.Table (N + 3).Has_Aspects := Val;
7590 procedure Set_Flag131 (N : Node_Id; Val : Boolean) is
7592 pragma Assert (not Locked);
7593 pragma Assert (Nkind (N) in N_Entity);
7594 Nodes.Table (N + 3).Rewrite_Ins := Val;
7597 procedure Set_Flag132 (N : Node_Id; Val : Boolean) is
7599 pragma Assert (not Locked);
7600 pragma Assert (Nkind (N) in N_Entity);
7601 Nodes.Table (N + 3).Analyzed := Val;
7604 procedure Set_Flag133 (N : Node_Id; Val : Boolean) is
7606 pragma Assert (not Locked);
7607 pragma Assert (Nkind (N) in N_Entity);
7608 Nodes.Table (N + 3).Comes_From_Source := Val;
7611 procedure Set_Flag134 (N : Node_Id; Val : Boolean) is
7613 pragma Assert (not Locked);
7614 pragma Assert (Nkind (N) in N_Entity);
7615 Nodes.Table (N + 3).Error_Posted := Val;
7618 procedure Set_Flag135 (N : Node_Id; Val : Boolean) is
7620 pragma Assert (not Locked);
7621 pragma Assert (Nkind (N) in N_Entity);
7622 Nodes.Table (N + 3).Flag4 := Val;
7625 procedure Set_Flag136 (N : Node_Id; Val : Boolean) is
7627 pragma Assert (not Locked);
7628 pragma Assert (Nkind (N) in N_Entity);
7629 Nodes.Table (N + 3).Flag5 := Val;
7632 procedure Set_Flag137 (N : Node_Id; Val : Boolean) is
7634 pragma Assert (not Locked);
7635 pragma Assert (Nkind (N) in N_Entity);
7636 Nodes.Table (N + 3).Flag6 := Val;
7639 procedure Set_Flag138 (N : Node_Id; Val : Boolean) is
7641 pragma Assert (not Locked);
7642 pragma Assert (Nkind (N) in N_Entity);
7643 Nodes.Table (N + 3).Flag7 := Val;
7646 procedure Set_Flag139 (N : Node_Id; Val : Boolean) is
7648 pragma Assert (not Locked);
7649 pragma Assert (Nkind (N) in N_Entity);
7650 Nodes.Table (N + 3).Flag8 := Val;
7653 procedure Set_Flag140 (N : Node_Id; Val : Boolean) is
7655 pragma Assert (not Locked);
7656 pragma Assert (Nkind (N) in N_Entity);
7657 Nodes.Table (N + 3).Flag9 := Val;
7660 procedure Set_Flag141 (N : Node_Id; Val : Boolean) is
7662 pragma Assert (not Locked);
7663 pragma Assert (Nkind (N) in N_Entity);
7664 Nodes.Table (N + 3).Flag10 := Val;
7667 procedure Set_Flag142 (N : Node_Id; Val : Boolean) is
7669 pragma Assert (not Locked);
7670 pragma Assert (Nkind (N) in N_Entity);
7671 Nodes.Table (N + 3).Flag11 := Val;
7674 procedure Set_Flag143 (N : Node_Id; Val : Boolean) is
7676 pragma Assert (not Locked);
7677 pragma Assert (Nkind (N) in N_Entity);
7678 Nodes.Table (N + 3).Flag12 := Val;
7681 procedure Set_Flag144 (N : Node_Id; Val : Boolean) is
7683 pragma Assert (not Locked);
7684 pragma Assert (Nkind (N) in N_Entity);
7685 Nodes.Table (N + 3).Flag13 := Val;
7688 procedure Set_Flag145 (N : Node_Id; Val : Boolean) is
7690 pragma Assert (not Locked);
7691 pragma Assert (Nkind (N) in N_Entity);
7692 Nodes.Table (N + 3).Flag14 := Val;
7695 procedure Set_Flag146 (N : Node_Id; Val : Boolean) is
7697 pragma Assert (not Locked);
7698 pragma Assert (Nkind (N) in N_Entity);
7699 Nodes.Table (N + 3).Flag15 := Val;
7702 procedure Set_Flag147 (N : Node_Id; Val : Boolean) is
7704 pragma Assert (not Locked);
7705 pragma Assert (Nkind (N) in N_Entity);
7706 Nodes.Table (N + 3).Flag16 := Val;
7709 procedure Set_Flag148 (N : Node_Id; Val : Boolean) is
7711 pragma Assert (not Locked);
7712 pragma Assert (Nkind (N) in N_Entity);
7713 Nodes.Table (N + 3).Flag17 := Val;
7716 procedure Set_Flag149 (N : Node_Id; Val : Boolean) is
7718 pragma Assert (not Locked);
7719 pragma Assert (Nkind (N) in N_Entity);
7720 Nodes.Table (N + 3).Flag18 := Val;
7723 procedure Set_Flag150 (N : Node_Id; Val : Boolean) is
7725 pragma Assert (not Locked);
7726 pragma Assert (Nkind (N) in N_Entity);
7727 Nodes.Table (N + 3).Pflag1 := Val;
7730 procedure Set_Flag151 (N : Node_Id; Val : Boolean) is
7732 pragma Assert (not Locked);
7733 pragma Assert (Nkind (N) in N_Entity);
7734 Nodes.Table (N + 3).Pflag2 := Val;
7737 procedure Set_Flag152 (N : Node_Id; Val : Boolean) is
7739 pragma Assert (not Locked);
7740 pragma Assert (Nkind (N) in N_Entity);
7743 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag152
:= Val
;
7746 procedure Set_Flag153
(N
: Node_Id
; Val
: Boolean) is
7748 pragma Assert
(not Locked
);
7749 pragma Assert
(Nkind
(N
) in N_Entity
);
7752 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag153 := Val;
7755 procedure Set_Flag154 (N : Node_Id; Val : Boolean) is
7757 pragma Assert (not Locked);
7758 pragma Assert (Nkind (N) in N_Entity);
7761 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag154
:= Val
;
7764 procedure Set_Flag155
(N
: Node_Id
; Val
: Boolean) is
7766 pragma Assert
(not Locked
);
7767 pragma Assert
(Nkind
(N
) in N_Entity
);
7770 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag155 := Val;
7773 procedure Set_Flag156 (N : Node_Id; Val : Boolean) is
7775 pragma Assert (not Locked);
7776 pragma Assert (Nkind (N) in N_Entity);
7779 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag156
:= Val
;
7782 procedure Set_Flag157
(N
: Node_Id
; Val
: Boolean) is
7784 pragma Assert
(not Locked
);
7785 pragma Assert
(Nkind
(N
) in N_Entity
);
7788 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag157 := Val;
7791 procedure Set_Flag158 (N : Node_Id; Val : Boolean) is
7793 pragma Assert (not Locked);
7794 pragma Assert (Nkind (N) in N_Entity);
7797 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag158
:= Val
;
7800 procedure Set_Flag159
(N
: Node_Id
; Val
: Boolean) is
7802 pragma Assert
(not Locked
);
7803 pragma Assert
(Nkind
(N
) in N_Entity
);
7806 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag159 := Val;
7809 procedure Set_Flag160 (N : Node_Id; Val : Boolean) is
7811 pragma Assert (not Locked);
7812 pragma Assert (Nkind (N) in N_Entity);
7815 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag160
:= Val
;
7818 procedure Set_Flag161
(N
: Node_Id
; Val
: Boolean) is
7820 pragma Assert
(not Locked
);
7821 pragma Assert
(Nkind
(N
) in N_Entity
);
7824 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag161 := Val;
7827 procedure Set_Flag162 (N : Node_Id; Val : Boolean) is
7829 pragma Assert (not Locked);
7830 pragma Assert (Nkind (N) in N_Entity);
7833 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag162
:= Val
;
7836 procedure Set_Flag163
(N
: Node_Id
; Val
: Boolean) is
7838 pragma Assert
(not Locked
);
7839 pragma Assert
(Nkind
(N
) in N_Entity
);
7842 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag163 := Val;
7845 procedure Set_Flag164 (N : Node_Id; Val : Boolean) is
7847 pragma Assert (not Locked);
7848 pragma Assert (Nkind (N) in N_Entity);
7851 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag164
:= Val
;
7854 procedure Set_Flag165
(N
: Node_Id
; Val
: Boolean) is
7856 pragma Assert
(not Locked
);
7857 pragma Assert
(Nkind
(N
) in N_Entity
);
7860 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag165 := Val;
7863 procedure Set_Flag166 (N : Node_Id; Val : Boolean) is
7865 pragma Assert (not Locked);
7866 pragma Assert (Nkind (N) in N_Entity);
7869 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag166
:= Val
;
7872 procedure Set_Flag167
(N
: Node_Id
; Val
: Boolean) is
7874 pragma Assert
(not Locked
);
7875 pragma Assert
(Nkind
(N
) in N_Entity
);
7878 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag167 := Val;
7881 procedure Set_Flag168 (N : Node_Id; Val : Boolean) is
7883 pragma Assert (not Locked);
7884 pragma Assert (Nkind (N) in N_Entity);
7887 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag168
:= Val
;
7890 procedure Set_Flag169
(N
: Node_Id
; Val
: Boolean) is
7892 pragma Assert
(not Locked
);
7893 pragma Assert
(Nkind
(N
) in N_Entity
);
7896 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag169 := Val;
7899 procedure Set_Flag170 (N : Node_Id; Val : Boolean) is
7901 pragma Assert (not Locked);
7902 pragma Assert (Nkind (N) in N_Entity);
7905 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag170
:= Val
;
7908 procedure Set_Flag171
(N
: Node_Id
; Val
: Boolean) is
7910 pragma Assert
(not Locked
);
7911 pragma Assert
(Nkind
(N
) in N_Entity
);
7914 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag171 := Val;
7917 procedure Set_Flag172 (N : Node_Id; Val : Boolean) is
7919 pragma Assert (not Locked);
7920 pragma Assert (Nkind (N) in N_Entity);
7923 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag172
:= Val
;
7926 procedure Set_Flag173
(N
: Node_Id
; Val
: Boolean) is
7928 pragma Assert
(not Locked
);
7929 pragma Assert
(Nkind
(N
) in N_Entity
);
7932 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag173 := Val;
7935 procedure Set_Flag174 (N : Node_Id; Val : Boolean) is
7937 pragma Assert (not Locked);
7938 pragma Assert (Nkind (N) in N_Entity);
7941 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag174
:= Val
;
7944 procedure Set_Flag175
(N
: Node_Id
; Val
: Boolean) is
7946 pragma Assert
(not Locked
);
7947 pragma Assert
(Nkind
(N
) in N_Entity
);
7950 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag175 := Val;
7953 procedure Set_Flag176 (N : Node_Id; Val : Boolean) is
7955 pragma Assert (not Locked);
7956 pragma Assert (Nkind (N) in N_Entity);
7959 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag176
:= Val
;
7962 procedure Set_Flag177
(N
: Node_Id
; Val
: Boolean) is
7964 pragma Assert
(not Locked
);
7965 pragma Assert
(Nkind
(N
) in N_Entity
);
7968 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag177 := Val;
7971 procedure Set_Flag178 (N : Node_Id; Val : Boolean) is
7973 pragma Assert (not Locked);
7974 pragma Assert (Nkind (N) in N_Entity);
7977 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag178
:= Val
;
7980 procedure Set_Flag179
(N
: Node_Id
; Val
: Boolean) is
7982 pragma Assert
(not Locked
);
7983 pragma Assert
(Nkind
(N
) in N_Entity
);
7986 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag179 := Val;
7989 procedure Set_Flag180 (N : Node_Id; Val : Boolean) is
7991 pragma Assert (not Locked);
7992 pragma Assert (Nkind (N) in N_Entity);
7995 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag180
:= Val
;
7998 procedure Set_Flag181
(N
: Node_Id
; Val
: Boolean) is
8000 pragma Assert
(not Locked
);
8001 pragma Assert
(Nkind
(N
) in N_Entity
);
8004 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag181 := Val;
8007 procedure Set_Flag182 (N : Node_Id; Val : Boolean) is
8009 pragma Assert (not Locked);
8010 pragma Assert (Nkind (N) in N_Entity);
8013 (Nodes
.Table
(N
+ 3).Field11
'Unrestricted_Access)).Flag182
:= Val
;
8016 procedure Set_Flag183
(N
: Node_Id
; Val
: Boolean) is
8018 pragma Assert
(not Locked
);
8019 pragma Assert
(Nkind
(N
) in N_Entity
);
8022 (Nodes.Table (N + 3).Field11'Unrestricted_Access)).Flag183 := Val;
8025 procedure Set_Flag184 (N : Node_Id; Val : Boolean) is
8027 pragma Assert (not Locked);
8028 pragma Assert (Nkind (N) in N_Entity);
8031 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag184
:= Val
;
8034 procedure Set_Flag185
(N
: Node_Id
; Val
: Boolean) is
8036 pragma Assert
(not Locked
);
8037 pragma Assert
(Nkind
(N
) in N_Entity
);
8040 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag185 := Val;
8043 procedure Set_Flag186 (N : Node_Id; Val : Boolean) is
8045 pragma Assert (not Locked);
8046 pragma Assert (Nkind (N) in N_Entity);
8049 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag186
:= Val
;
8052 procedure Set_Flag187
(N
: Node_Id
; Val
: Boolean) is
8054 pragma Assert
(not Locked
);
8055 pragma Assert
(Nkind
(N
) in N_Entity
);
8058 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag187 := Val;
8061 procedure Set_Flag188 (N : Node_Id; Val : Boolean) is
8063 pragma Assert (not Locked);
8064 pragma Assert (Nkind (N) in N_Entity);
8067 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag188
:= Val
;
8070 procedure Set_Flag189
(N
: Node_Id
; Val
: Boolean) is
8072 pragma Assert
(not Locked
);
8073 pragma Assert
(Nkind
(N
) in N_Entity
);
8076 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag189 := Val;
8079 procedure Set_Flag190 (N : Node_Id; Val : Boolean) is
8081 pragma Assert (not Locked);
8082 pragma Assert (Nkind (N) in N_Entity);
8085 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag190
:= Val
;
8088 procedure Set_Flag191
(N
: Node_Id
; Val
: Boolean) is
8090 pragma Assert
(not Locked
);
8091 pragma Assert
(Nkind
(N
) in N_Entity
);
8094 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag191 := Val;
8097 procedure Set_Flag192 (N : Node_Id; Val : Boolean) is
8099 pragma Assert (not Locked);
8100 pragma Assert (Nkind (N) in N_Entity);
8103 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag192
:= Val
;
8106 procedure Set_Flag193
(N
: Node_Id
; Val
: Boolean) is
8108 pragma Assert
(not Locked
);
8109 pragma Assert
(Nkind
(N
) in N_Entity
);
8112 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag193 := Val;
8115 procedure Set_Flag194 (N : Node_Id; Val : Boolean) is
8117 pragma Assert (not Locked);
8118 pragma Assert (Nkind (N) in N_Entity);
8121 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag194
:= Val
;
8124 procedure Set_Flag195
(N
: Node_Id
; Val
: Boolean) is
8126 pragma Assert
(not Locked
);
8127 pragma Assert
(Nkind
(N
) in N_Entity
);
8130 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag195 := Val;
8133 procedure Set_Flag196 (N : Node_Id; Val : Boolean) is
8135 pragma Assert (not Locked);
8136 pragma Assert (Nkind (N) in N_Entity);
8139 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag196
:= Val
;
8142 procedure Set_Flag197
(N
: Node_Id
; Val
: Boolean) is
8144 pragma Assert
(not Locked
);
8145 pragma Assert
(Nkind
(N
) in N_Entity
);
8148 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag197 := Val;
8151 procedure Set_Flag198 (N : Node_Id; Val : Boolean) is
8153 pragma Assert (not Locked);
8154 pragma Assert (Nkind (N) in N_Entity);
8157 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag198
:= Val
;
8160 procedure Set_Flag199
(N
: Node_Id
; Val
: Boolean) is
8162 pragma Assert
(not Locked
);
8163 pragma Assert
(Nkind
(N
) in N_Entity
);
8166 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag199 := Val;
8169 procedure Set_Flag200 (N : Node_Id; Val : Boolean) is
8171 pragma Assert (not Locked);
8172 pragma Assert (Nkind (N) in N_Entity);
8175 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag200
:= Val
;
8178 procedure Set_Flag201
(N
: Node_Id
; Val
: Boolean) is
8180 pragma Assert
(not Locked
);
8181 pragma Assert
(Nkind
(N
) in N_Entity
);
8184 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag201 := Val;
8187 procedure Set_Flag202 (N : Node_Id; Val : Boolean) is
8189 pragma Assert (not Locked);
8190 pragma Assert (Nkind (N) in N_Entity);
8193 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag202
:= Val
;
8196 procedure Set_Flag203
(N
: Node_Id
; Val
: Boolean) is
8198 pragma Assert
(not Locked
);
8199 pragma Assert
(Nkind
(N
) in N_Entity
);
8202 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag203 := Val;
8205 procedure Set_Flag204 (N : Node_Id; Val : Boolean) is
8207 pragma Assert (not Locked);
8208 pragma Assert (Nkind (N) in N_Entity);
8211 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag204
:= Val
;
8214 procedure Set_Flag205
(N
: Node_Id
; Val
: Boolean) is
8216 pragma Assert
(not Locked
);
8217 pragma Assert
(Nkind
(N
) in N_Entity
);
8220 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag205 := Val;
8223 procedure Set_Flag206 (N : Node_Id; Val : Boolean) is
8225 pragma Assert (not Locked);
8226 pragma Assert (Nkind (N) in N_Entity);
8229 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag206
:= Val
;
8232 procedure Set_Flag207
(N
: Node_Id
; Val
: Boolean) is
8234 pragma Assert
(not Locked
);
8235 pragma Assert
(Nkind
(N
) in N_Entity
);
8238 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag207 := Val;
8241 procedure Set_Flag208 (N : Node_Id; Val : Boolean) is
8243 pragma Assert (not Locked);
8244 pragma Assert (Nkind (N) in N_Entity);
8247 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag208
:= Val
;
8250 procedure Set_Flag209
(N
: Node_Id
; Val
: Boolean) is
8252 pragma Assert
(not Locked
);
8253 pragma Assert
(Nkind
(N
) in N_Entity
);
8256 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag209 := Val;
8259 procedure Set_Flag210 (N : Node_Id; Val : Boolean) is
8261 pragma Assert (not Locked);
8262 pragma Assert (Nkind (N) in N_Entity);
8265 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag210
:= Val
;
8268 procedure Set_Flag211
(N
: Node_Id
; Val
: Boolean) is
8270 pragma Assert
(not Locked
);
8271 pragma Assert
(Nkind
(N
) in N_Entity
);
8274 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag211 := Val;
8277 procedure Set_Flag212 (N : Node_Id; Val : Boolean) is
8279 pragma Assert (not Locked);
8280 pragma Assert (Nkind (N) in N_Entity);
8283 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag212
:= Val
;
8286 procedure Set_Flag213
(N
: Node_Id
; Val
: Boolean) is
8288 pragma Assert
(not Locked
);
8289 pragma Assert
(Nkind
(N
) in N_Entity
);
8292 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag213 := Val;
8295 procedure Set_Flag214 (N : Node_Id; Val : Boolean) is
8297 pragma Assert (not Locked);
8298 pragma Assert (Nkind (N) in N_Entity);
8301 (Nodes
.Table
(N
+ 4).Field12
'Unrestricted_Access)).Flag214
:= Val
;
8304 procedure Set_Flag215
(N
: Node_Id
; Val
: Boolean) is
8306 pragma Assert
(not Locked
);
8307 pragma Assert
(Nkind
(N
) in N_Entity
);
8310 (Nodes.Table (N + 4).Field12'Unrestricted_Access)).Flag215 := Val;
8313 procedure Set_Flag216 (N : Node_Id; Val : Boolean) is
8315 pragma Assert (not Locked);
8316 pragma Assert (Nkind (N) in N_Entity);
8317 Nodes.Table (N + 4).In_List := Val;
8320 procedure Set_Flag217 (N : Node_Id; Val : Boolean) is
8322 pragma Assert (not Locked);
8323 pragma Assert (Nkind (N) in N_Entity);
8324 Nodes.Table (N + 4).Has_Aspects := Val;
8327 procedure Set_Flag218 (N : Node_Id; Val : Boolean) is
8329 pragma Assert (not Locked);
8330 pragma Assert (Nkind (N) in N_Entity);
8331 Nodes.Table (N + 4).Rewrite_Ins := Val;
8334 procedure Set_Flag219 (N : Node_Id; Val : Boolean) is
8336 pragma Assert (not Locked);
8337 pragma Assert (Nkind (N) in N_Entity);
8338 Nodes.Table (N + 4).Analyzed := Val;
8341 procedure Set_Flag220 (N : Node_Id; Val : Boolean) is
8343 pragma Assert (not Locked);
8344 pragma Assert (Nkind (N) in N_Entity);
8345 Nodes.Table (N + 4).Comes_From_Source := Val;
8348 procedure Set_Flag221 (N : Node_Id; Val : Boolean) is
8350 pragma Assert (not Locked);
8351 pragma Assert (Nkind (N) in N_Entity);
8352 Nodes.Table (N + 4).Error_Posted := Val;
8355 procedure Set_Flag222 (N : Node_Id; Val : Boolean) is
8357 pragma Assert (not Locked);
8358 pragma Assert (Nkind (N) in N_Entity);
8359 Nodes.Table (N + 4).Flag4 := Val;
8362 procedure Set_Flag223 (N : Node_Id; Val : Boolean) is
8364 pragma Assert (not Locked);
8365 pragma Assert (Nkind (N) in N_Entity);
8366 Nodes.Table (N + 4).Flag5 := Val;
8369 procedure Set_Flag224 (N : Node_Id; Val : Boolean) is
8371 pragma Assert (not Locked);
8372 pragma Assert (Nkind (N) in N_Entity);
8373 Nodes.Table (N + 4).Flag6 := Val;
8376 procedure Set_Flag225 (N : Node_Id; Val : Boolean) is
8378 pragma Assert (not Locked);
8379 pragma Assert (Nkind (N) in N_Entity);
8380 Nodes.Table (N + 4).Flag7 := Val;
8383 procedure Set_Flag226 (N : Node_Id; Val : Boolean) is
8385 pragma Assert (not Locked);
8386 pragma Assert (Nkind (N) in N_Entity);
8387 Nodes.Table (N + 4).Flag8 := Val;
8390 procedure Set_Flag227 (N : Node_Id; Val : Boolean) is
8392 pragma Assert (not Locked);
8393 pragma Assert (Nkind (N) in N_Entity);
8394 Nodes.Table (N + 4).Flag9 := Val;
8397 procedure Set_Flag228 (N : Node_Id; Val : Boolean) is
8399 pragma Assert (not Locked);
8400 pragma Assert (Nkind (N) in N_Entity);
8401 Nodes.Table (N + 4).Flag10 := Val;
8404 procedure Set_Flag229 (N : Node_Id; Val : Boolean) is
8406 pragma Assert (not Locked);
8407 pragma Assert (Nkind (N) in N_Entity);
8408 Nodes.Table (N + 4).Flag11 := Val;
8411 procedure Set_Flag230 (N : Node_Id; Val : Boolean) is
8413 pragma Assert (not Locked);
8414 pragma Assert (Nkind (N) in N_Entity);
8415 Nodes.Table (N + 4).Flag12 := Val;
8418 procedure Set_Flag231 (N : Node_Id; Val : Boolean) is
8420 pragma Assert (not Locked);
8421 pragma Assert (Nkind (N) in N_Entity);
8422 Nodes.Table (N + 4).Flag13 := Val;
8425 procedure Set_Flag232 (N : Node_Id; Val : Boolean) is
8427 pragma Assert (not Locked);
8428 pragma Assert (Nkind (N) in N_Entity);
8429 Nodes.Table (N + 4).Flag14 := Val;
8432 procedure Set_Flag233 (N : Node_Id; Val : Boolean) is
8434 pragma Assert (not Locked);
8435 pragma Assert (Nkind (N) in N_Entity);
8436 Nodes.Table (N + 4).Flag15 := Val;
8439 procedure Set_Flag234 (N : Node_Id; Val : Boolean) is
8441 pragma Assert (not Locked);
8442 pragma Assert (Nkind (N) in N_Entity);
8443 Nodes.Table (N + 4).Flag16 := Val;
8446 procedure Set_Flag235 (N : Node_Id; Val : Boolean) is
8448 pragma Assert (not Locked);
8449 pragma Assert (Nkind (N) in N_Entity);
8450 Nodes.Table (N + 4).Flag17 := Val;
8453 procedure Set_Flag236 (N : Node_Id; Val : Boolean) is
8455 pragma Assert (not Locked);
8456 pragma Assert (Nkind (N) in N_Entity);
8457 Nodes.Table (N + 4).Flag18 := Val;
8460 procedure Set_Flag237 (N : Node_Id; Val : Boolean) is
8462 pragma Assert (not Locked);
8463 pragma Assert (Nkind (N) in N_Entity);
8464 Nodes.Table (N + 4).Pflag1 := Val;
8467 procedure Set_Flag238 (N : Node_Id; Val : Boolean) is
8469 pragma Assert (not Locked);
8470 pragma Assert (Nkind (N) in N_Entity);
8471 Nodes.Table (N + 4).Pflag2 := Val;
8474 procedure Set_Flag239 (N : Node_Id; Val : Boolean) is
8476 pragma Assert (not Locked);
8477 pragma Assert (Nkind (N) in N_Entity);
8480 (Nodes
.Table
(N
+ 3).Nkind
'Unrestricted_Access)).Flag239
:= Val
;
8483 procedure Set_Flag240
(N
: Node_Id
; Val
: Boolean) is
8485 pragma Assert
(not Locked
);
8486 pragma Assert
(Nkind
(N
) in N_Entity
);
8489 (Nodes.Table (N + 3).Nkind'Unrestricted_Access)).Flag240 := Val;
8492 procedure Set_Flag241 (N : Node_Id; Val : Boolean) is
8494 pragma Assert (not Locked);
8495 pragma Assert (Nkind (N) in N_Entity);
8498 (Nodes
.Table
(N
+ 3).Nkind
'Unrestricted_Access)).Flag241
:= Val
;
8501 procedure Set_Flag242
(N
: Node_Id
; Val
: Boolean) is
8503 pragma Assert
(not Locked
);
8504 pragma Assert
(Nkind
(N
) in N_Entity
);
8507 (Nodes.Table (N + 3).Nkind'Unrestricted_Access)).Flag242 := Val;
8510 procedure Set_Flag243 (N : Node_Id; Val : Boolean) is
8512 pragma Assert (not Locked);
8513 pragma Assert (Nkind (N) in N_Entity);
8516 (Nodes
.Table
(N
+ 3).Nkind
'Unrestricted_Access)).Flag243
:= Val
;
8519 procedure Set_Flag244
(N
: Node_Id
; Val
: Boolean) is
8521 pragma Assert
(not Locked
);
8522 pragma Assert
(Nkind
(N
) in N_Entity
);
8525 (Nodes.Table (N + 3).Nkind'Unrestricted_Access)).Flag244 := Val;
8528 procedure Set_Flag245 (N : Node_Id; Val : Boolean) is
8530 pragma Assert (not Locked);
8531 pragma Assert (Nkind (N) in N_Entity);
8534 (Nodes
.Table
(N
+ 3).Nkind
'Unrestricted_Access)).Flag245
:= Val
;
8537 procedure Set_Flag246
(N
: Node_Id
; Val
: Boolean) is
8539 pragma Assert
(not Locked
);
8540 pragma Assert
(Nkind
(N
) in N_Entity
);
8543 (Nodes.Table (N + 3).Nkind'Unrestricted_Access)).Flag246 := Val;
8546 procedure Set_Flag247 (N : Node_Id; Val : Boolean) is
8548 pragma Assert (not Locked);
8549 pragma Assert (Nkind (N) in N_Entity);
8552 (Nodes
.Table
(N
+ 4).Nkind
'Unrestricted_Access)).Flag247
:= Val
;
8555 procedure Set_Flag248
(N
: Node_Id
; Val
: Boolean) is
8557 pragma Assert
(not Locked
);
8558 pragma Assert
(Nkind
(N
) in N_Entity
);
8561 (Nodes.Table (N + 4).Nkind'Unrestricted_Access)).Flag248 := Val;
8564 procedure Set_Flag249 (N : Node_Id; Val : Boolean) is
8566 pragma Assert (not Locked);
8567 pragma Assert (Nkind (N) in N_Entity);
8570 (Nodes
.Table
(N
+ 4).Nkind
'Unrestricted_Access)).Flag249
:= Val
;
8573 procedure Set_Flag250
(N
: Node_Id
; Val
: Boolean) is
8575 pragma Assert
(not Locked
);
8576 pragma Assert
(Nkind
(N
) in N_Entity
);
8579 (Nodes.Table (N + 4).Nkind'Unrestricted_Access)).Flag250 := Val;
8582 procedure Set_Flag251 (N : Node_Id; Val : Boolean) is
8584 pragma Assert (not Locked);
8585 pragma Assert (Nkind (N) in N_Entity);
8588 (Nodes
.Table
(N
+ 4).Nkind
'Unrestricted_Access)).Flag251
:= Val
;
8591 procedure Set_Flag252
(N
: Node_Id
; Val
: Boolean) is
8593 pragma Assert
(not Locked
);
8594 pragma Assert
(Nkind
(N
) in N_Entity
);
8597 (Nodes.Table (N + 4).Nkind'Unrestricted_Access)).Flag252 := Val;
8600 procedure Set_Flag253 (N : Node_Id; Val : Boolean) is
8602 pragma Assert (not Locked);
8603 pragma Assert (Nkind (N) in N_Entity);
8606 (Nodes
.Table
(N
+ 4).Nkind
'Unrestricted_Access)).Flag253
:= Val
;
8609 procedure Set_Flag254
(N
: Node_Id
; Val
: Boolean) is
8611 pragma Assert
(not Locked
);
8612 pragma Assert
(Nkind
(N
) in N_Entity
);
8615 (Nodes.Table (N + 4).Nkind'Unrestricted_Access)).Flag254 := Val;
8618 procedure Set_Flag255 (N : Node_Id; Val : Boolean) is
8620 pragma Assert (not Locked);
8621 pragma Assert (Nkind (N) in N_Entity);
8624 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag255
:= Val
;
8627 procedure Set_Flag256
(N
: Node_Id
; Val
: Boolean) is
8629 pragma Assert
(not Locked
);
8630 pragma Assert
(Nkind
(N
) in N_Entity
);
8633 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag256 := Val;
8636 procedure Set_Flag257 (N : Node_Id; Val : Boolean) is
8638 pragma Assert (not Locked);
8639 pragma Assert (Nkind (N) in N_Entity);
8642 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag257
:= Val
;
8645 procedure Set_Flag258
(N
: Node_Id
; Val
: Boolean) is
8647 pragma Assert
(not Locked
);
8648 pragma Assert
(Nkind
(N
) in N_Entity
);
8651 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag258 := Val;
8654 procedure Set_Flag259 (N : Node_Id; Val : Boolean) is
8656 pragma Assert (not Locked);
8657 pragma Assert (Nkind (N) in N_Entity);
8660 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag259
:= Val
;
8663 procedure Set_Flag260
(N
: Node_Id
; Val
: Boolean) is
8665 pragma Assert
(not Locked
);
8666 pragma Assert
(Nkind
(N
) in N_Entity
);
8669 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag260 := Val;
8672 procedure Set_Flag261 (N : Node_Id; Val : Boolean) is
8674 pragma Assert (not Locked);
8675 pragma Assert (Nkind (N) in N_Entity);
8678 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag261
:= Val
;
8681 procedure Set_Flag262
(N
: Node_Id
; Val
: Boolean) is
8683 pragma Assert
(not Locked
);
8684 pragma Assert
(Nkind
(N
) in N_Entity
);
8687 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag262 := Val;
8690 procedure Set_Flag263 (N : Node_Id; Val : Boolean) is
8692 pragma Assert (not Locked);
8693 pragma Assert (Nkind (N) in N_Entity);
8696 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag263
:= Val
;
8699 procedure Set_Flag264
(N
: Node_Id
; Val
: Boolean) is
8701 pragma Assert
(not Locked
);
8702 pragma Assert
(Nkind
(N
) in N_Entity
);
8705 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag264 := Val;
8708 procedure Set_Flag265 (N : Node_Id; Val : Boolean) is
8710 pragma Assert (not Locked);
8711 pragma Assert (Nkind (N) in N_Entity);
8714 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag265
:= Val
;
8717 procedure Set_Flag266
(N
: Node_Id
; Val
: Boolean) is
8719 pragma Assert
(not Locked
);
8720 pragma Assert
(Nkind
(N
) in N_Entity
);
8723 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag266 := Val;
8726 procedure Set_Flag267 (N : Node_Id; Val : Boolean) is
8728 pragma Assert (not Locked);
8729 pragma Assert (Nkind (N) in N_Entity);
8732 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag267
:= Val
;
8735 procedure Set_Flag268
(N
: Node_Id
; Val
: Boolean) is
8737 pragma Assert
(not Locked
);
8738 pragma Assert
(Nkind
(N
) in N_Entity
);
8741 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag268 := Val;
8744 procedure Set_Flag269 (N : Node_Id; Val : Boolean) is
8746 pragma Assert (not Locked);
8747 pragma Assert (Nkind (N) in N_Entity);
8750 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag269
:= Val
;
8753 procedure Set_Flag270
(N
: Node_Id
; Val
: Boolean) is
8755 pragma Assert
(not Locked
);
8756 pragma Assert
(Nkind
(N
) in N_Entity
);
8759 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag270 := Val;
8762 procedure Set_Flag271 (N : Node_Id; Val : Boolean) is
8764 pragma Assert (not Locked);
8765 pragma Assert (Nkind (N) in N_Entity);
8768 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag271
:= Val
;
8771 procedure Set_Flag272
(N
: Node_Id
; Val
: Boolean) is
8773 pragma Assert
(not Locked
);
8774 pragma Assert
(Nkind
(N
) in N_Entity
);
8777 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag272 := Val;
8780 procedure Set_Flag273 (N : Node_Id; Val : Boolean) is
8782 pragma Assert (not Locked);
8783 pragma Assert (Nkind (N) in N_Entity);
8786 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag273
:= Val
;
8789 procedure Set_Flag274
(N
: Node_Id
; Val
: Boolean) is
8791 pragma Assert
(not Locked
);
8792 pragma Assert
(Nkind
(N
) in N_Entity
);
8795 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag274 := Val;
8798 procedure Set_Flag275 (N : Node_Id; Val : Boolean) is
8800 pragma Assert (not Locked);
8801 pragma Assert (Nkind (N) in N_Entity);
8804 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag275
:= Val
;
8807 procedure Set_Flag276
(N
: Node_Id
; Val
: Boolean) is
8809 pragma Assert
(not Locked
);
8810 pragma Assert
(Nkind
(N
) in N_Entity
);
8813 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag276 := Val;
8816 procedure Set_Flag277 (N : Node_Id; Val : Boolean) is
8818 pragma Assert (not Locked);
8819 pragma Assert (Nkind (N) in N_Entity);
8822 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag277
:= Val
;
8825 procedure Set_Flag278
(N
: Node_Id
; Val
: Boolean) is
8827 pragma Assert
(not Locked
);
8828 pragma Assert
(Nkind
(N
) in N_Entity
);
8831 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag278 := Val;
8834 procedure Set_Flag279 (N : Node_Id; Val : Boolean) is
8836 pragma Assert (not Locked);
8837 pragma Assert (Nkind (N) in N_Entity);
8840 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag279
:= Val
;
8843 procedure Set_Flag280
(N
: Node_Id
; Val
: Boolean) is
8845 pragma Assert
(not Locked
);
8846 pragma Assert
(Nkind
(N
) in N_Entity
);
8849 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag280 := Val;
8852 procedure Set_Flag281 (N : Node_Id; Val : Boolean) is
8854 pragma Assert (not Locked);
8855 pragma Assert (Nkind (N) in N_Entity);
8858 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag281
:= Val
;
8861 procedure Set_Flag282
(N
: Node_Id
; Val
: Boolean) is
8863 pragma Assert
(not Locked
);
8864 pragma Assert
(Nkind
(N
) in N_Entity
);
8867 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag282 := Val;
8870 procedure Set_Flag283 (N : Node_Id; Val : Boolean) is
8872 pragma Assert (not Locked);
8873 pragma Assert (Nkind (N) in N_Entity);
8876 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag283
:= Val
;
8879 procedure Set_Flag284
(N
: Node_Id
; Val
: Boolean) is
8881 pragma Assert
(not Locked
);
8882 pragma Assert
(Nkind
(N
) in N_Entity
);
8885 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag284 := Val;
8888 procedure Set_Flag285 (N : Node_Id; Val : Boolean) is
8890 pragma Assert (not Locked);
8891 pragma Assert (Nkind (N) in N_Entity);
8894 (Nodes
.Table
(N
+ 5).Field12
'Unrestricted_Access)).Flag285
:= Val
;
8897 procedure Set_Flag286
(N
: Node_Id
; Val
: Boolean) is
8899 pragma Assert
(not Locked
);
8900 pragma Assert
(Nkind
(N
) in N_Entity
);
8903 (Nodes.Table (N + 5).Field12'Unrestricted_Access)).Flag286 := Val;
8906 procedure Set_Flag287 (N : Node_Id; Val : Boolean) is
8908 pragma Assert (not Locked);
8909 pragma Assert (Nkind (N) in N_Entity);
8910 Nodes.Table (N + 5).In_List := Val;
8913 procedure Set_Flag288 (N : Node_Id; Val : Boolean) is
8915 pragma Assert (not Locked);
8916 pragma Assert (Nkind (N) in N_Entity);
8917 Nodes.Table (N + 5).Has_Aspects := Val;
8920 procedure Set_Flag289 (N : Node_Id; Val : Boolean) is
8922 pragma Assert (not Locked);
8923 pragma Assert (Nkind (N) in N_Entity);
8924 Nodes.Table (N + 5).Rewrite_Ins := Val;
8927 procedure Set_Flag290 (N : Node_Id; Val : Boolean) is
8929 pragma Assert (not Locked);
8930 pragma Assert (Nkind (N) in N_Entity);
8931 Nodes.Table (N + 5).Analyzed := Val;
8934 procedure Set_Flag291 (N : Node_Id; Val : Boolean) is
8936 pragma Assert (not Locked);
8937 pragma Assert (Nkind (N) in N_Entity);
8938 Nodes.Table (N + 5).Comes_From_Source := Val;
8941 procedure Set_Flag292 (N : Node_Id; Val : Boolean) is
8943 pragma Assert (not Locked);
8944 pragma Assert (Nkind (N) in N_Entity);
8945 Nodes.Table (N + 5).Error_Posted := Val;
8948 procedure Set_Flag293 (N : Node_Id; Val : Boolean) is
8950 pragma Assert (not Locked);
8951 pragma Assert (Nkind (N) in N_Entity);
8952 Nodes.Table (N + 5).Flag4 := Val;
8955 procedure Set_Flag294 (N : Node_Id; Val : Boolean) is
8957 pragma Assert (not Locked);
8958 pragma Assert (Nkind (N) in N_Entity);
8959 Nodes.Table (N + 5).Flag5 := Val;
8962 procedure Set_Flag295 (N : Node_Id; Val : Boolean) is
8964 pragma Assert (not Locked);
8965 pragma Assert (Nkind (N) in N_Entity);
8966 Nodes.Table (N + 5).Flag6 := Val;
8969 procedure Set_Flag296 (N : Node_Id; Val : Boolean) is
8971 pragma Assert (not Locked);
8972 pragma Assert (Nkind (N) in N_Entity);
8973 Nodes.Table (N + 5).Flag7 := Val;
8976 procedure Set_Flag297 (N : Node_Id; Val : Boolean) is
8978 pragma Assert (not Locked);
8979 pragma Assert (Nkind (N) in N_Entity);
8980 Nodes.Table (N + 5).Flag8 := Val;
8983 procedure Set_Flag298 (N : Node_Id; Val : Boolean) is
8985 pragma Assert (not Locked);
8986 pragma Assert (Nkind (N) in N_Entity);
8987 Nodes.Table (N + 5).Flag9 := Val;
8990 procedure Set_Flag299 (N : Node_Id; Val : Boolean) is
8992 pragma Assert (not Locked);
8993 pragma Assert (Nkind (N) in N_Entity);
8994 Nodes.Table (N + 5).Flag10 := Val;
8997 procedure Set_Flag300 (N : Node_Id; Val : Boolean) is
8999 pragma Assert (not Locked);
9000 pragma Assert (Nkind (N) in N_Entity);
9001 Nodes.Table (N + 5).Flag11 := Val;
9004 procedure Set_Flag301 (N : Node_Id; Val : Boolean) is
9006 pragma Assert (not Locked);
9007 pragma Assert (Nkind (N) in N_Entity);
9008 Nodes.Table (N + 5).Flag12 := Val;
9011 procedure Set_Flag302 (N : Node_Id; Val : Boolean) is
9013 pragma Assert (not Locked);
9014 pragma Assert (Nkind (N) in N_Entity);
9015 Nodes.Table (N + 5).Flag13 := Val;
9018 procedure Set_Flag303 (N : Node_Id; Val : Boolean) is
9020 pragma Assert (not Locked);
9021 pragma Assert (Nkind (N) in N_Entity);
9022 Nodes.Table (N + 5).Flag14 := Val;
9025 procedure Set_Flag304 (N : Node_Id; Val : Boolean) is
9027 pragma Assert (not Locked);
9028 pragma Assert (Nkind (N) in N_Entity);
9029 Nodes.Table (N + 5).Flag15 := Val;
9032 procedure Set_Flag305 (N : Node_Id; Val : Boolean) is
9034 pragma Assert (not Locked);
9035 pragma Assert (Nkind (N) in N_Entity);
9036 Nodes.Table (N + 5).Flag16 := Val;
9039 procedure Set_Flag306 (N : Node_Id; Val : Boolean) is
9041 pragma Assert (not Locked);
9042 pragma Assert (Nkind (N) in N_Entity);
9043 Nodes.Table (N + 5).Flag17 := Val;
9046 procedure Set_Flag307 (N : Node_Id; Val : Boolean) is
9048 pragma Assert (not Locked);
9049 pragma Assert (Nkind (N) in N_Entity);
9050 Nodes.Table (N + 5).Flag18 := Val;
9053 procedure Set_Flag308 (N : Node_Id; Val : Boolean) is
9055 pragma Assert (not Locked);
9056 pragma Assert (Nkind (N) in N_Entity);
9057 Nodes.Table (N + 5).Pflag1 := Val;
9060 procedure Set_Flag309 (N : Node_Id; Val : Boolean) is
9062 pragma Assert (not Locked);
9063 pragma Assert (Nkind (N) in N_Entity);
9064 Nodes.Table (N + 5).Pflag2 := Val;
9067 procedure Set_Flag310 (N : Node_Id; Val : Boolean) is
9069 pragma Assert (not Locked);
9070 pragma Assert (Nkind (N) in N_Entity);
9073 (Nodes
.Table
(N
+ 5).Nkind
'Unrestricted_Access)).Flag310
:= Val
;
9076 procedure Set_Flag311
(N
: Node_Id
; Val
: Boolean) is
9078 pragma Assert
(not Locked
);
9079 pragma Assert
(Nkind
(N
) in N_Entity
);
9082 (Nodes.Table (N + 5).Nkind'Unrestricted_Access)).Flag311 := Val;
9085 procedure Set_Flag312 (N : Node_Id; Val : Boolean) is
9087 pragma Assert (not Locked);
9088 pragma Assert (Nkind (N) in N_Entity);
9091 (Nodes
.Table
(N
+ 5).Nkind
'Unrestricted_Access)).Flag312
:= Val
;
9094 procedure Set_Flag313
(N
: Node_Id
; Val
: Boolean) is
9096 pragma Assert
(not Locked
);
9097 pragma Assert
(Nkind
(N
) in N_Entity
);
9100 (Nodes.Table (N + 5).Nkind'Unrestricted_Access)).Flag313 := Val;
9103 procedure Set_Flag314 (N : Node_Id; Val : Boolean) is
9105 pragma Assert (not Locked);
9106 pragma Assert (Nkind (N) in N_Entity);
9109 (Nodes
.Table
(N
+ 5).Nkind
'Unrestricted_Access)).Flag314
:= Val
;
9112 procedure Set_Flag315
(N
: Node_Id
; Val
: Boolean) is
9114 pragma Assert
(not Locked
);
9115 pragma Assert
(Nkind
(N
) in N_Entity
);
9118 (Nodes.Table (N + 5).Nkind'Unrestricted_Access)).Flag315 := Val;
9121 procedure Set_Flag316 (N : Node_Id; Val : Boolean) is
9123 pragma Assert (not Locked);
9124 pragma Assert (Nkind (N) in N_Entity);
9127 (Nodes
.Table
(N
+ 5).Nkind
'Unrestricted_Access)).Flag316
:= Val
;
9130 procedure Set_Flag317
(N
: Node_Id
; Val
: Boolean) is
9132 pragma Assert
(not Locked
);
9133 pragma Assert
(Nkind
(N
) in N_Entity
);
9136 (Nodes.Table (N + 5).Nkind'Unrestricted_Access)).Flag317 := Val;
9139 procedure Set_Node1_With_Parent (N : Node_Id; Val : Node_Id) is
9141 pragma Assert (not Locked);
9142 pragma Assert (N <= Nodes.Last);
9145 Set_Parent (N => Val, Val => N);
9149 end Set_Node1_With_Parent;
9151 procedure Set_Node2_With_Parent (N : Node_Id; Val : Node_Id) is
9153 pragma Assert (not Locked);
9154 pragma Assert (N <= Nodes.Last);
9157 Set_Parent (N => Val, Val => N);
9161 end Set_Node2_With_Parent;
9163 procedure Set_Node3_With_Parent (N : Node_Id; Val : Node_Id) is
9165 pragma Assert (not Locked);
9166 pragma Assert (N <= Nodes.Last);
9169 Set_Parent (N => Val, Val => N);
9173 end Set_Node3_With_Parent;
9175 procedure Set_Node4_With_Parent (N : Node_Id; Val : Node_Id) is
9177 pragma Assert (not Locked);
9178 pragma Assert (N <= Nodes.Last);
9181 Set_Parent (N => Val, Val => N);
9185 end Set_Node4_With_Parent;
9187 procedure Set_Node5_With_Parent (N : Node_Id; Val : Node_Id) is
9189 pragma Assert (not Locked);
9190 pragma Assert (N <= Nodes.Last);
9193 Set_Parent (N => Val, Val => N);
9197 end Set_Node5_With_Parent;
9199 procedure Set_List1_With_Parent (N : Node_Id; Val : List_Id) is
9201 pragma Assert (not Locked);
9202 pragma Assert (N <= Nodes.Last);
9203 if Val /= No_List and then Val /= Error_List then
9204 Set_Parent (Val, N);
9207 end Set_List1_With_Parent;
9209 procedure Set_List2_With_Parent (N : Node_Id; Val : List_Id) is
9211 pragma Assert (not Locked);
9212 pragma Assert (N <= Nodes.Last);
9213 if Val /= No_List and then Val /= Error_List then
9214 Set_Parent (Val, N);
9217 end Set_List2_With_Parent;
9219 procedure Set_List3_With_Parent (N : Node_Id; Val : List_Id) is
9221 pragma Assert (not Locked);
9222 pragma Assert (N <= Nodes.Last);
9223 if Val /= No_List and then Val /= Error_List then
9224 Set_Parent (Val, N);
9227 end Set_List3_With_Parent;
9229 procedure Set_List4_With_Parent (N : Node_Id; Val : List_Id) is
9231 pragma Assert (not Locked);
9232 pragma Assert (N <= Nodes.Last);
9233 if Val /= No_List and then Val /= Error_List then
9234 Set_Parent (Val, N);
9237 end Set_List4_With_Parent;
9239 procedure Set_List5_With_Parent (N : Node_Id; Val : List_Id) is
9241 pragma Assert (not Locked);
9242 pragma Assert (N <= Nodes.Last);
9243 if Val /= No_List and then Val /= Error_List then
9244 Set_Parent (Val, N);
9247 end Set_List5_With_Parent;
9249 end Unchecked_Access;
9257 Nodes.Locked := False;
9258 Flags.Locked := False;
9259 Orig_Nodes.Locked := False;
9266 procedure Unlock_Nodes is
9268 pragma Assert (Locked);