1 ------------------------------------------------------------------------------
3 -- GNAT COMPILER COMPONENTS --
5 -- E I N F O . U T I L S --
9 -- Copyright (C) 2020-2023, 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. See the GNU General Public License --
17 -- for more details. You should have received a copy of the GNU General --
18 -- Public License distributed with GNAT; see file COPYING3. If not, go to --
19 -- http://www.gnu.org/licenses for a complete copy of the license. --
21 -- GNAT was originally developed by the GNAT team at New York University. --
22 -- Extensive contributions were provided by Ada Core Technologies Inc. --
24 ------------------------------------------------------------------------------
26 with Atree
; use Atree
;
27 with Elists
; use Elists
;
28 with Nlists
; use Nlists
;
29 with Output
; use Output
;
30 with Sinfo
; use Sinfo
;
31 with Sinfo
.Utils
; use Sinfo
.Utils
;
33 package body Einfo
.Utils
is
35 -----------------------
36 -- Local subprograms --
37 -----------------------
40 (State_Id
: Entity_Id
;
41 Option_Nam
: Name_Id
) return Boolean;
42 -- Determine whether abstract state State_Id has particular option denoted
43 -- by the name Option_Nam.
45 -------------------------------------------
46 -- Aliases/Renamings of Renamed_Or_Alias --
47 -------------------------------------------
49 function Alias
(N
: Entity_Id
) return Entity_Id
is
51 return Val
: constant Entity_Id
:= Renamed_Or_Alias
(N
) do
53 (Is_Overloadable
(N
) or else Ekind
(N
) = E_Subprogram_Type
);
54 pragma Assert
(Val
in N_Entity_Id | N_Empty_Id
);
58 procedure Set_Alias
(N
: Entity_Id
; Val
: Entity_Id
) is
61 (Is_Overloadable
(N
) or else Ekind
(N
) = E_Subprogram_Type
);
62 pragma Assert
(Val
in N_Entity_Id | N_Empty_Id
);
64 Set_Renamed_Or_Alias
(N
, Val
);
67 function Renamed_Entity
(N
: Entity_Id
) return Entity_Id
is
69 return Val
: constant Entity_Id
:= Renamed_Or_Alias
(N
) do
70 pragma Assert
(not Is_Object
(N
) or else Etype
(N
) = Any_Type
);
71 pragma Assert
(Val
in N_Entity_Id | N_Empty_Id
);
75 procedure Set_Renamed_Entity
(N
: Entity_Id
; Val
: Entity_Id
) is
77 pragma Assert
(not Is_Object
(N
));
78 pragma Assert
(Val
in N_Entity_Id
);
80 Set_Renamed_Or_Alias
(N
, Val
);
81 end Set_Renamed_Entity
;
83 function Renamed_Object
(N
: Entity_Id
) return Node_Id
is
85 return Val
: constant Node_Id
:= Renamed_Or_Alias
(N
) do
86 -- Formal_Kind uses the entity, not a name of it. This happens
87 -- in front-end inlining, which also sets to Empty. Also in
88 -- Exp_Ch9, where formals are renamed for the benefit of gdb.
90 if Ekind
(N
) not in Formal_Kind
then
91 pragma Assert
(Is_Object
(N
));
92 pragma Assert
(Val
in N_Subexpr_Id | N_Empty_Id
);
98 procedure Set_Renamed_Object
(N
: Entity_Id
; Val
: Node_Id
) is
100 if Ekind
(N
) not in Formal_Kind
then
101 pragma Assert
(Is_Object
(N
));
102 pragma Assert
(Val
in N_Subexpr_Id | N_Empty_Id
);
106 Set_Renamed_Or_Alias
(N
, Val
);
107 end Set_Renamed_Object
;
109 function Renamed_Entity_Or_Object
(N
: Entity_Id
) return Node_Id
is
111 if Is_Object
(N
) then
112 return Renamed_Object
(N
);
114 return Renamed_Entity
(N
);
116 end Renamed_Entity_Or_Object
;
118 procedure Set_Renamed_Object_Of_Possibly_Void
119 (N
: Entity_Id
; Val
: Node_Id
)
122 pragma Assert
(Val
in N_Subexpr_Id
);
123 Set_Renamed_Or_Alias
(N
, Val
);
124 end Set_Renamed_Object_Of_Possibly_Void
;
131 (State_Id
: Entity_Id
;
132 Option_Nam
: Name_Id
) return Boolean
134 Decl
: constant Node_Id
:= Parent
(State_Id
);
139 pragma Assert
(Ekind
(State_Id
) = E_Abstract_State
);
141 -- The declaration of abstract states with options appear as an
142 -- extension aggregate. If this is not the case, the option is not
145 if Nkind
(Decl
) /= N_Extension_Aggregate
then
151 Opt
:= First
(Expressions
(Decl
));
152 while Present
(Opt
) loop
153 if Nkind
(Opt
) = N_Identifier
and then Chars
(Opt
) = Option_Nam
then
160 -- Complex options with various specifiers
162 Opt
:= First
(Component_Associations
(Decl
));
163 while Present
(Opt
) loop
164 Opt_Nam
:= First
(Choices
(Opt
));
166 if Nkind
(Opt_Nam
) = N_Identifier
167 and then Chars
(Opt_Nam
) = Option_Nam
178 ------------------------------
179 -- Classification Functions --
180 ------------------------------
182 function Is_Access_Object_Type
(Id
: E
) return B
is
184 return Is_Access_Type
(Id
)
185 and then Ekind
(Directly_Designated_Type
(Id
)) /= E_Subprogram_Type
;
186 end Is_Access_Object_Type
;
188 function Is_Access_Type
(Id
: E
) return B
is
190 return Ekind
(Id
) in Access_Kind
;
193 function Is_Access_Protected_Subprogram_Type
(Id
: E
) return B
is
195 return Ekind
(Id
) in Access_Protected_Kind
;
196 end Is_Access_Protected_Subprogram_Type
;
198 function Is_Access_Subprogram_Type
(Id
: E
) return B
is
200 return Is_Access_Type
(Id
)
201 and then Ekind
(Directly_Designated_Type
(Id
)) = E_Subprogram_Type
;
202 end Is_Access_Subprogram_Type
;
204 function Is_Aggregate_Type
(Id
: E
) return B
is
206 return Ekind
(Id
) in Aggregate_Kind
;
207 end Is_Aggregate_Type
;
209 function Is_Anonymous_Access_Type
(Id
: E
) return B
is
211 return Ekind
(Id
) in Anonymous_Access_Kind
;
212 end Is_Anonymous_Access_Type
;
214 function Is_Array_Type
(Id
: E
) return B
is
216 return Ekind
(Id
) in Array_Kind
;
219 function Is_Assignable
(Id
: E
) return B
is
221 return Ekind
(Id
) in Assignable_Kind
;
224 function Is_Class_Wide_Type
(Id
: E
) return B
is
226 return Ekind
(Id
) in Class_Wide_Kind
;
227 end Is_Class_Wide_Type
;
229 function Is_Composite_Type
(Id
: E
) return B
is
231 return Ekind
(Id
) in Composite_Kind
;
232 end Is_Composite_Type
;
234 function Is_Concurrent_Body
(Id
: E
) return B
is
236 return Ekind
(Id
) in Concurrent_Body_Kind
;
237 end Is_Concurrent_Body
;
239 function Is_Concurrent_Type
(Id
: E
) return B
is
241 return Ekind
(Id
) in Concurrent_Kind
;
242 end Is_Concurrent_Type
;
244 function Is_Decimal_Fixed_Point_Type
(Id
: E
) return B
is
246 return Ekind
(Id
) in Decimal_Fixed_Point_Kind
;
247 end Is_Decimal_Fixed_Point_Type
;
249 function Is_Digits_Type
(Id
: E
) return B
is
251 return Ekind
(Id
) in Digits_Kind
;
254 function Is_Discrete_Or_Fixed_Point_Type
(Id
: E
) return B
is
256 return Ekind
(Id
) in Discrete_Or_Fixed_Point_Kind
;
257 end Is_Discrete_Or_Fixed_Point_Type
;
259 function Is_Discrete_Type
(Id
: E
) return B
is
261 return Ekind
(Id
) in Discrete_Kind
;
262 end Is_Discrete_Type
;
264 function Is_Elementary_Type
(Id
: E
) return B
is
266 return Ekind
(Id
) in Elementary_Kind
;
267 end Is_Elementary_Type
;
269 function Is_Entry
(Id
: E
) return B
is
271 return Ekind
(Id
) in Entry_Kind
;
274 function Is_Enumeration_Type
(Id
: E
) return B
is
276 return Ekind
(Id
) in Enumeration_Kind
;
277 end Is_Enumeration_Type
;
279 function Is_Fixed_Point_Type
(Id
: E
) return B
is
281 return Ekind
(Id
) in Fixed_Point_Kind
;
282 end Is_Fixed_Point_Type
;
284 function Is_Floating_Point_Type
(Id
: E
) return B
is
286 return Ekind
(Id
) in Float_Kind
;
287 end Is_Floating_Point_Type
;
289 function Is_Formal
(Id
: E
) return B
is
291 return Ekind
(Id
) in Formal_Kind
;
294 function Is_Formal_Object
(Id
: E
) return B
is
296 return Ekind
(Id
) in Formal_Object_Kind
;
297 end Is_Formal_Object
;
299 function Is_Generic_Subprogram
(Id
: E
) return B
is
301 return Ekind
(Id
) in Generic_Subprogram_Kind
;
302 end Is_Generic_Subprogram
;
304 function Is_Generic_Unit
(Id
: E
) return B
is
306 return Ekind
(Id
) in Generic_Unit_Kind
;
309 function Is_Ghost_Entity
(Id
: E
) return Boolean is
311 return Is_Checked_Ghost_Entity
(Id
) or else Is_Ignored_Ghost_Entity
(Id
);
314 function Is_Incomplete_Or_Private_Type
(Id
: E
) return B
is
316 return Ekind
(Id
) in Incomplete_Or_Private_Kind
;
317 end Is_Incomplete_Or_Private_Type
;
319 function Is_Incomplete_Type
(Id
: E
) return B
is
321 return Ekind
(Id
) in Incomplete_Kind
;
322 end Is_Incomplete_Type
;
324 function Is_Integer_Type
(Id
: E
) return B
is
326 return Ekind
(Id
) in Integer_Kind
;
329 function Is_Modular_Integer_Type
(Id
: E
) return B
is
331 return Ekind
(Id
) in Modular_Integer_Kind
;
332 end Is_Modular_Integer_Type
;
334 function Is_Named_Access_Type
(Id
: E
) return B
is
336 return Ekind
(Id
) in Named_Access_Kind
;
337 end Is_Named_Access_Type
;
339 function Is_Named_Number
(Id
: E
) return B
is
341 return Ekind
(Id
) in Named_Kind
;
344 function Is_Numeric_Type
(Id
: E
) return B
is
346 return Ekind
(Id
) in Numeric_Kind
;
349 function Is_Object
(Id
: E
) return B
is
351 return Ekind
(Id
) in Object_Kind
;
354 function Is_Ordinary_Fixed_Point_Type
(Id
: E
) return B
is
356 return Ekind
(Id
) in Ordinary_Fixed_Point_Kind
;
357 end Is_Ordinary_Fixed_Point_Type
;
359 function Is_Overloadable
(Id
: E
) return B
is
361 return Ekind
(Id
) in Overloadable_Kind
;
364 function Is_Private_Type
(Id
: E
) return B
is
366 return Ekind
(Id
) in Private_Kind
;
369 function Is_Protected_Type
(Id
: E
) return B
is
371 return Ekind
(Id
) in Protected_Kind
;
372 end Is_Protected_Type
;
374 function Is_Real_Type
(Id
: E
) return B
is
376 return Ekind
(Id
) in Real_Kind
;
379 function Is_Record_Type
(Id
: E
) return B
is
381 return Ekind
(Id
) in Record_Kind
;
384 function Is_Scalar_Type
(Id
: E
) return B
is
386 return Ekind
(Id
) in Scalar_Kind
;
389 function Is_Signed_Integer_Type
(Id
: E
) return B
is
391 return Ekind
(Id
) in Signed_Integer_Kind
;
392 end Is_Signed_Integer_Type
;
394 function Is_Subprogram
(Id
: E
) return B
is
396 return Ekind
(Id
) in Subprogram_Kind
;
399 function Is_Subprogram_Or_Entry
(Id
: E
) return B
is
401 return Ekind
(Id
) in Subprogram_Kind
403 Ekind
(Id
) in Entry_Kind
;
404 end Is_Subprogram_Or_Entry
;
406 function Is_Subprogram_Or_Generic_Subprogram
(Id
: E
) return B
is
408 return Ekind
(Id
) in Subprogram_Kind
410 Ekind
(Id
) in Generic_Subprogram_Kind
;
411 end Is_Subprogram_Or_Generic_Subprogram
;
413 function Is_Task_Type
(Id
: E
) return B
is
415 return Ekind
(Id
) in Task_Kind
;
418 function Is_Type
(Id
: E
) return B
is
420 return Ekind
(Id
) in Type_Kind
;
423 ------------------------------------------
424 -- Type Representation Attribute Fields --
425 ------------------------------------------
427 function Known_Alignment
(E
: Entity_Id
) return B
is
429 -- For some reason, Empty is passed to this sometimes
431 return No
(E
) or else not Field_Is_Initial_Zero
(E
, F_Alignment
);
434 procedure Reinit_Alignment
(Id
: E
) is
436 Reinit_Field_To_Zero
(Id
, F_Alignment
);
437 end Reinit_Alignment
;
439 procedure Copy_Alignment
(To
, From
: E
) is
441 if Known_Alignment
(From
) then
442 Set_Alignment
(To
, Alignment
(From
));
444 Reinit_Alignment
(To
);
448 function Known_Component_Bit_Offset
(E
: Entity_Id
) return B
is
450 return Present
(Component_Bit_Offset
(E
));
451 end Known_Component_Bit_Offset
;
453 function Known_Static_Component_Bit_Offset
(E
: Entity_Id
) return B
is
455 return Known_Component_Bit_Offset
(E
)
456 and then Component_Bit_Offset
(E
) >= Uint_0
;
457 end Known_Static_Component_Bit_Offset
;
459 function Known_Component_Size
(E
: Entity_Id
) return B
is
461 return Present
(Component_Size
(E
));
462 end Known_Component_Size
;
464 function Known_Static_Component_Size
(E
: Entity_Id
) return B
is
466 return Known_Component_Size
(E
) and then Component_Size
(E
) >= Uint_0
;
467 end Known_Static_Component_Size
;
469 function Known_Esize
(E
: Entity_Id
) return B
is
471 return Present
(Esize
(E
));
474 function Known_Static_Esize
(E
: Entity_Id
) return B
is
476 return Known_Esize
(E
)
477 and then Esize
(E
) >= Uint_0
478 and then not Is_Generic_Type
(E
);
479 end Known_Static_Esize
;
481 procedure Reinit_Esize
(Id
: E
) is
483 Reinit_Field_To_Zero
(Id
, F_Esize
);
486 procedure Copy_Esize
(To
, From
: E
) is
488 if Known_Esize
(From
) then
489 Set_Esize
(To
, Esize
(From
));
495 function Known_Normalized_First_Bit
(E
: Entity_Id
) return B
is
497 return Present
(Normalized_First_Bit
(E
));
498 end Known_Normalized_First_Bit
;
500 function Known_Static_Normalized_First_Bit
(E
: Entity_Id
) return B
is
502 return Known_Normalized_First_Bit
(E
)
503 and then Normalized_First_Bit
(E
) >= Uint_0
;
504 end Known_Static_Normalized_First_Bit
;
506 function Known_Normalized_Position
(E
: Entity_Id
) return B
is
508 return Present
(Normalized_Position
(E
));
509 end Known_Normalized_Position
;
511 function Known_Static_Normalized_Position
(E
: Entity_Id
) return B
is
513 return Known_Normalized_Position
(E
)
514 and then Normalized_Position
(E
) >= Uint_0
;
515 end Known_Static_Normalized_Position
;
517 function Known_RM_Size
(E
: Entity_Id
) return B
is
519 return Present
(RM_Size
(E
));
522 function Known_Static_RM_Size
(E
: Entity_Id
) return B
is
524 return Known_RM_Size
(E
)
525 and then RM_Size
(E
) >= Uint_0
526 and then not Is_Generic_Type
(E
);
527 end Known_Static_RM_Size
;
529 procedure Reinit_RM_Size
(Id
: E
) is
531 Reinit_Field_To_Zero
(Id
, F_RM_Size
);
534 procedure Copy_RM_Size
(To
, From
: E
) is
536 if Known_RM_Size
(From
) then
537 Set_RM_Size
(To
, RM_Size
(From
));
543 -------------------------------
544 -- Reinit_Component_Location --
545 -------------------------------
547 procedure Reinit_Component_Location
(Id
: E
) is
549 Set_Normalized_First_Bit
(Id
, No_Uint
);
550 Set_Component_Bit_Offset
(Id
, No_Uint
);
552 Set_Normalized_Position
(Id
, No_Uint
);
553 end Reinit_Component_Location
;
555 ------------------------------
556 -- Reinit_Object_Size_Align --
557 ------------------------------
559 procedure Reinit_Object_Size_Align
(Id
: E
) is
562 Reinit_Alignment
(Id
);
563 end Reinit_Object_Size_Align
;
569 procedure Init_Size
(Id
: E
; V
: Int
) is
571 pragma Assert
(Is_Type
(Id
));
572 pragma Assert
(not Known_Esize
(Id
) or else Esize
(Id
) = V
);
573 pragma Assert
(not Known_RM_Size
(Id
) or else RM_Size
(Id
) = V
);
575 Set_Esize
(Id
, UI_From_Int
(V
));
576 Set_RM_Size
(Id
, UI_From_Int
(V
));
579 -----------------------
580 -- Reinit_Size_Align --
581 -----------------------
583 procedure Reinit_Size_Align
(Id
: E
) is
585 pragma Assert
(Ekind
(Id
) in Type_Kind | E_Void
);
588 Reinit_Alignment
(Id
);
589 end Reinit_Size_Align
;
595 function Address_Clause
(Id
: E
) return Node_Id
is
597 return Get_Attribute_Definition_Clause
(Id
, Attribute_Address
);
604 function Aft_Value
(Id
: E
) return U
is
606 Delta_Val
: Ureal
:= Delta_Value
(Id
);
608 while Delta_Val
< Ureal_Tenth
loop
609 Delta_Val
:= Delta_Val
* Ureal_10
;
610 Result
:= Result
+ 1;
613 return UI_From_Int
(Result
);
616 ----------------------
617 -- Alignment_Clause --
618 ----------------------
620 function Alignment_Clause
(Id
: E
) return Node_Id
is
622 return Get_Attribute_Definition_Clause
(Id
, Attribute_Alignment
);
623 end Alignment_Clause
;
629 procedure Append_Entity
(Id
: Entity_Id
; Scop
: Entity_Id
) is
630 Last
: constant Entity_Id
:= Last_Entity
(Scop
);
633 Set_Scope
(Id
, Scop
);
634 Set_Prev_Entity
(Id
, Empty
); -- Empty <-- Id
636 -- The entity chain is empty
639 Set_First_Entity
(Scop
, Id
);
641 -- Otherwise the entity chain has at least one element
644 Link_Entities
(Last
, Id
); -- Last <-- Id, Last --> Id
647 -- NOTE: The setting of the Next_Entity attribute of Id must happen
648 -- here as opposed to at the beginning of the routine because doing
649 -- so causes the binder to hang. It is not clear why ???
651 Set_Next_Entity
(Id
, Empty
); -- Id --> Empty
653 Set_Last_Entity
(Scop
, Id
);
660 function Base_Type
(Id
: E
) return E
is
662 if Is_Base_Type
(Id
) then
665 pragma Assert
(Is_Type
(Id
));
670 ----------------------
671 -- Declaration_Node --
672 ----------------------
674 function Declaration_Node
(Id
: E
) return Node_Id
is
678 if Ekind
(Id
) = E_Incomplete_Type
679 and then Present
(Full_View
(Id
))
681 P
:= Parent
(Full_View
(Id
));
686 while Nkind
(P
) in N_Selected_Component | N_Expanded_Name
687 or else (Nkind
(P
) = N_Defining_Program_Unit_Name
688 and then Is_Child_Unit
(Id
))
694 and then Nkind
(P
) not in
695 N_Full_Type_Declaration | N_Subtype_Declaration
700 -- Declarations are sometimes removed by replacing them with other
701 -- irrelevant nodes. For example, a declare expression can be turned
702 -- into a literal by constant folding. In these cases we want to
706 N_Assignment_Statement
708 | N_Procedure_Call_Statement
709 | N_Subtype_Indication
715 -- The following Assert indicates what kinds of nodes can be returned;
716 -- they are not all "declarations".
718 if Serious_Errors_Detected
= 0 then
720 (Nkind
(P
) in N_Is_Decl | N_Empty
,
721 "Declaration_Node incorrect kind: " & Node_Kind
'Image (Nkind
(P
)));
725 end Declaration_Node
;
727 ---------------------
728 -- Designated_Type --
729 ---------------------
731 function Designated_Type
(Id
: E
) return E
is
732 Desig_Type
: Entity_Id
;
735 Desig_Type
:= Directly_Designated_Type
(Id
);
737 if No
(Desig_Type
) then
738 pragma Assert
(Error_Posted
(Id
));
742 if Is_Incomplete_Type
(Desig_Type
)
743 and then Present
(Full_View
(Desig_Type
))
745 return Full_View
(Desig_Type
);
748 if Is_Class_Wide_Type
(Desig_Type
)
749 and then Is_Incomplete_Type
(Etype
(Desig_Type
))
750 and then Present
(Full_View
(Etype
(Desig_Type
)))
751 and then Present
(Class_Wide_Type
(Full_View
(Etype
(Desig_Type
))))
753 return Class_Wide_Type
(Full_View
(Etype
(Desig_Type
)));
759 ----------------------
760 -- Entry_Index_Type --
761 ----------------------
763 function Entry_Index_Type
(Id
: E
) return E
is
765 pragma Assert
(Ekind
(Id
) = E_Entry_Family
);
766 return Etype
(Discrete_Subtype_Definition
(Parent
(Id
)));
767 end Entry_Index_Type
;
769 ---------------------
770 -- First_Component --
771 ---------------------
773 function First_Component
(Id
: E
) return Entity_Id
is
778 (Is_Concurrent_Type
(Id
)
779 or else Is_Incomplete_Or_Private_Type
(Id
)
780 or else Is_Record_Type
(Id
));
782 Comp_Id
:= First_Entity
(Id
);
783 while Present
(Comp_Id
) loop
784 exit when Ekind
(Comp_Id
) = E_Component
;
785 Next_Entity
(Comp_Id
);
791 -------------------------------------
792 -- First_Component_Or_Discriminant --
793 -------------------------------------
795 function First_Component_Or_Discriminant
(Id
: E
) return Entity_Id
is
800 (Is_Concurrent_Type
(Id
)
801 or else Is_Incomplete_Or_Private_Type
(Id
)
802 or else Is_Record_Type
(Id
)
803 or else Has_Discriminants
(Id
));
805 Comp_Id
:= First_Entity
(Id
);
806 while Present
(Comp_Id
) loop
807 exit when Ekind
(Comp_Id
) in E_Component | E_Discriminant
;
808 Next_Entity
(Comp_Id
);
812 end First_Component_Or_Discriminant
;
818 function First_Formal
(Id
: E
) return Entity_Id
is
823 (Is_Generic_Subprogram
(Id
)
824 or else Is_Overloadable
(Id
)
825 or else Ekind
(Id
) in E_Entry_Family
827 | E_Subprogram_Type
);
829 if Ekind
(Id
) = E_Enumeration_Literal
then
833 Formal
:= First_Entity
(Id
);
835 -- Deal with the common, non-generic case first
837 if No
(Formal
) or else Is_Formal
(Formal
) then
841 -- The first/next entity chain of a generic subprogram contains all
842 -- generic formal parameters, followed by the formal parameters.
844 if Is_Generic_Subprogram
(Id
) then
845 while Present
(Formal
) and then not Is_Formal
(Formal
) loop
846 Next_Entity
(Formal
);
855 ------------------------------
856 -- First_Formal_With_Extras --
857 ------------------------------
859 function First_Formal_With_Extras
(Id
: E
) return Entity_Id
is
864 (Is_Generic_Subprogram
(Id
)
865 or else Is_Overloadable
(Id
)
866 or else Ekind
(Id
) in E_Entry_Family
868 | E_Subprogram_Type
);
870 if Ekind
(Id
) = E_Enumeration_Literal
then
874 Formal
:= First_Entity
(Id
);
876 -- The first/next entity chain of a generic subprogram contains all
877 -- generic formal parameters, followed by the formal parameters. Go
878 -- directly to the parameters by skipping the formal part.
880 if Is_Generic_Subprogram
(Id
) then
881 while Present
(Formal
) and then not Is_Formal
(Formal
) loop
882 Next_Entity
(Formal
);
886 if Present
(Formal
) and then Is_Formal
(Formal
) then
889 return Extra_Formals
(Id
); -- Empty if no extra formals
892 end First_Formal_With_Extras
;
898 function Float_Rep
(N
: Entity_Id
) return Float_Rep_Kind
is
899 pragma Unreferenced
(N
);
900 pragma Assert
(Float_Rep_Kind
'First = Float_Rep_Kind
'Last);
902 -- There is only one value, so we don't need to store it, see types.ads.
904 Val
: constant Float_Rep_Kind
:= IEEE_Binary
;
910 -------------------------------------
911 -- Get_Attribute_Definition_Clause --
912 -------------------------------------
914 function Get_Attribute_Definition_Clause
916 Id
: Attribute_Id
) return Node_Id
921 N
:= First_Rep_Item
(E
);
922 while Present
(N
) loop
923 if Nkind
(N
) = N_Attribute_Definition_Clause
924 and then Get_Attribute_Id
(Chars
(N
)) = Id
933 end Get_Attribute_Definition_Clause
;
935 ---------------------------
936 -- Get_Class_Wide_Pragma --
937 ---------------------------
939 function Get_Class_Wide_Pragma
941 Id
: Pragma_Id
) return Node_Id
947 Items
:= Contract
(E
);
953 Item
:= Pre_Post_Conditions
(Items
);
954 while Present
(Item
) loop
955 if Nkind
(Item
) = N_Pragma
956 and then Get_Pragma_Id
(Pragma_Name_Unmapped
(Item
)) = Id
957 and then Class_Present
(Item
)
962 Item
:= Next_Pragma
(Item
);
966 end Get_Class_Wide_Pragma
;
972 function Get_Full_View
(T
: Entity_Id
) return Entity_Id
is
974 if Is_Incomplete_Type
(T
) and then Present
(Full_View
(T
)) then
975 return Full_View
(T
);
977 elsif Is_Class_Wide_Type
(T
)
978 and then Is_Incomplete_Type
(Root_Type
(T
))
979 and then Present
(Full_View
(Root_Type
(T
)))
981 return Class_Wide_Type
(Full_View
(Root_Type
(T
)));
992 function Get_Pragma
(E
: Entity_Id
; Id
: Pragma_Id
) return Node_Id
is
994 -- Classification pragmas
996 Is_CLS
: constant Boolean :=
997 Id
= Pragma_Abstract_State
or else
998 Id
= Pragma_Attach_Handler
or else
999 Id
= Pragma_Async_Readers
or else
1000 Id
= Pragma_Async_Writers
or else
1001 Id
= Pragma_Constant_After_Elaboration
or else
1002 Id
= Pragma_Depends
or else
1003 Id
= Pragma_Effective_Reads
or else
1004 Id
= Pragma_Effective_Writes
or else
1005 Id
= Pragma_Extensions_Visible
or else
1006 Id
= Pragma_Global
or else
1007 Id
= Pragma_Initial_Condition
or else
1008 Id
= Pragma_Initializes
or else
1009 Id
= Pragma_Interrupt_Handler
or else
1010 Id
= Pragma_No_Caching
or else
1011 Id
= Pragma_Part_Of
or else
1012 Id
= Pragma_Refined_Depends
or else
1013 Id
= Pragma_Refined_Global
or else
1014 Id
= Pragma_Refined_State
or else
1015 Id
= Pragma_Volatile_Function
;
1017 -- Contract / subprogram variant / test case pragmas
1019 Is_CTC
: constant Boolean :=
1020 Id
= Pragma_Always_Terminates
or else
1021 Id
= Pragma_Contract_Cases
or else
1022 Id
= Pragma_Exceptional_Cases
or else
1023 Id
= Pragma_Subprogram_Variant
or else
1024 Id
= Pragma_Test_Case
;
1026 -- Pre / postcondition pragmas
1028 Is_PPC
: constant Boolean :=
1029 Id
= Pragma_Precondition
or else
1030 Id
= Pragma_Postcondition
or else
1031 Id
= Pragma_Refined_Post
;
1033 In_Contract
: constant Boolean := Is_CLS
or Is_CTC
or Is_PPC
;
1039 -- Handle pragmas that appear in N_Contract nodes. Those have to be
1040 -- extracted from their specialized list.
1043 Items
:= Contract
(E
);
1049 Item
:= Classifications
(Items
);
1052 Item
:= Contract_Test_Cases
(Items
);
1055 Item
:= Pre_Post_Conditions
(Items
);
1061 Item
:= First_Rep_Item
(E
);
1064 while Present
(Item
) loop
1065 if Nkind
(Item
) = N_Pragma
1066 and then Get_Pragma_Id
(Pragma_Name_Unmapped
(Item
)) = Id
1070 -- All nodes in N_Contract are chained using Next_Pragma
1072 elsif In_Contract
then
1073 Item
:= Next_Pragma
(Item
);
1078 Next_Rep_Item
(Item
);
1085 --------------------------------------
1086 -- Get_Record_Representation_Clause --
1087 --------------------------------------
1089 function Get_Record_Representation_Clause
(E
: Entity_Id
) return Node_Id
is
1093 N
:= First_Rep_Item
(E
);
1094 while Present
(N
) loop
1095 if Nkind
(N
) = N_Record_Representation_Clause
then
1103 end Get_Record_Representation_Clause
;
1105 ------------------------
1106 -- Has_Attach_Handler --
1107 ------------------------
1109 function Has_Attach_Handler
(Id
: E
) return B
is
1113 pragma Assert
(Is_Protected_Type
(Id
));
1115 Ritem
:= First_Rep_Item
(Id
);
1116 while Present
(Ritem
) loop
1117 if Nkind
(Ritem
) = N_Pragma
1118 and then Pragma_Name
(Ritem
) = Name_Attach_Handler
1122 Next_Rep_Item
(Ritem
);
1127 end Has_Attach_Handler
;
1133 function Has_DIC
(Id
: E
) return B
is
1135 return Has_Own_DIC
(Id
) or else Has_Inherited_DIC
(Id
);
1142 function Has_Entries
(Id
: E
) return B
is
1146 pragma Assert
(Is_Concurrent_Type
(Id
));
1148 Ent
:= First_Entity
(Id
);
1149 while Present
(Ent
) loop
1150 if Is_Entry
(Ent
) then
1160 ----------------------------
1161 -- Has_Foreign_Convention --
1162 ----------------------------
1164 function Has_Foreign_Convention
(Id
: E
) return B
is
1166 -- While regular Intrinsics such as the Standard operators fit in the
1167 -- "Ada" convention, those with an Interface_Name materialize GCC
1168 -- builtin imports for which Ada special treatments shouldn't apply.
1170 return Convention
(Id
) in Foreign_Convention
1171 or else (Convention
(Id
) = Convention_Intrinsic
1172 and then Present
(Interface_Name
(Id
)));
1173 end Has_Foreign_Convention
;
1175 ---------------------------
1176 -- Has_Interrupt_Handler --
1177 ---------------------------
1179 function Has_Interrupt_Handler
(Id
: E
) return B
is
1183 pragma Assert
(Is_Protected_Type
(Id
));
1185 Ritem
:= First_Rep_Item
(Id
);
1186 while Present
(Ritem
) loop
1187 if Nkind
(Ritem
) = N_Pragma
1188 and then Pragma_Name
(Ritem
) = Name_Interrupt_Handler
1192 Next_Rep_Item
(Ritem
);
1197 end Has_Interrupt_Handler
;
1199 --------------------
1200 -- Has_Invariants --
1201 --------------------
1203 function Has_Invariants
(Id
: E
) return B
is
1205 return Has_Own_Invariants
(Id
) or else Has_Inherited_Invariants
(Id
);
1208 --------------------------
1209 -- Has_Limited_View --
1210 --------------------------
1212 function Has_Limited_View
(Id
: E
) return B
is
1214 return Ekind
(Id
) = E_Package
1215 and then not Is_Generic_Instance
(Id
)
1216 and then Present
(Limited_View
(Id
));
1217 end Has_Limited_View
;
1219 --------------------------
1220 -- Has_Non_Limited_View --
1221 --------------------------
1223 function Has_Non_Limited_View
(Id
: E
) return B
is
1225 return (Ekind
(Id
) in Incomplete_Kind
1226 or else Ekind
(Id
) in Class_Wide_Kind
1227 or else Ekind
(Id
) = E_Abstract_State
)
1228 and then Present
(Non_Limited_View
(Id
));
1229 end Has_Non_Limited_View
;
1231 ---------------------------------
1232 -- Has_Non_Null_Abstract_State --
1233 ---------------------------------
1235 function Has_Non_Null_Abstract_State
(Id
: E
) return B
is
1237 pragma Assert
(Is_Package_Or_Generic_Package
(Id
));
1240 Present
(Abstract_States
(Id
))
1242 not Is_Null_State
(Node
(First_Elmt
(Abstract_States
(Id
))));
1243 end Has_Non_Null_Abstract_State
;
1245 -------------------------------------
1246 -- Has_Non_Null_Visible_Refinement --
1247 -------------------------------------
1249 function Has_Non_Null_Visible_Refinement
(Id
: E
) return B
is
1250 Constits
: Elist_Id
;
1253 -- "Refinement" is a concept applicable only to abstract states
1255 pragma Assert
(Ekind
(Id
) = E_Abstract_State
);
1256 Constits
:= Refinement_Constituents
(Id
);
1258 -- A partial refinement is always non-null. For a full refinement to be
1259 -- non-null, the first constituent must be anything other than null.
1262 Has_Partial_Visible_Refinement
(Id
)
1263 or else (Has_Visible_Refinement
(Id
)
1264 and then Present
(Constits
)
1265 and then Nkind
(Node
(First_Elmt
(Constits
))) /= N_Null
);
1266 end Has_Non_Null_Visible_Refinement
;
1268 -----------------------------
1269 -- Has_Null_Abstract_State --
1270 -----------------------------
1272 function Has_Null_Abstract_State
(Id
: E
) return B
is
1273 pragma Assert
(Is_Package_Or_Generic_Package
(Id
));
1275 States
: constant Elist_Id
:= Abstract_States
(Id
);
1278 -- Check first available state of related package. A null abstract
1279 -- state always appears as the sole element of the state list.
1283 and then Is_Null_State
(Node
(First_Elmt
(States
)));
1284 end Has_Null_Abstract_State
;
1286 ---------------------------------
1287 -- Has_Null_Visible_Refinement --
1288 ---------------------------------
1290 function Has_Null_Visible_Refinement
(Id
: E
) return B
is
1291 Constits
: Elist_Id
;
1294 -- "Refinement" is a concept applicable only to abstract states
1296 pragma Assert
(Ekind
(Id
) = E_Abstract_State
);
1297 Constits
:= Refinement_Constituents
(Id
);
1299 -- For a refinement to be null, the state's sole constituent must be a
1303 Has_Visible_Refinement
(Id
)
1304 and then Present
(Constits
)
1305 and then Nkind
(Node
(First_Elmt
(Constits
))) = N_Null
;
1306 end Has_Null_Visible_Refinement
;
1308 --------------------
1309 -- Has_Unmodified --
1310 --------------------
1312 function Has_Unmodified
(E
: Entity_Id
) return Boolean is
1314 if Has_Pragma_Unmodified
(E
) then
1316 elsif Warnings_Off
(E
) then
1317 Set_Warnings_Off_Used_Unmodified
(E
);
1324 ---------------------
1325 -- Has_Unreferenced --
1326 ---------------------
1328 function Has_Unreferenced
(E
: Entity_Id
) return Boolean is
1330 if Has_Pragma_Unreferenced
(E
) then
1332 elsif Warnings_Off
(E
) then
1333 Set_Warnings_Off_Used_Unreferenced
(E
);
1338 end Has_Unreferenced
;
1340 ----------------------
1341 -- Has_Warnings_Off --
1342 ----------------------
1344 function Has_Warnings_Off
(E
: Entity_Id
) return Boolean is
1346 if Warnings_Off
(E
) then
1347 Set_Warnings_Off_Used
(E
);
1352 end Has_Warnings_Off
;
1354 ------------------------------
1355 -- Implementation_Base_Type --
1356 ------------------------------
1358 function Implementation_Base_Type
(Id
: E
) return E
is
1363 Bastyp
:= Base_Type
(Id
);
1365 if Is_Incomplete_Or_Private_Type
(Bastyp
) then
1366 Imptyp
:= Underlying_Type
(Bastyp
);
1368 -- If we have an implementation type, then just return it,
1369 -- otherwise we return the Base_Type anyway. This can only
1370 -- happen in error situations and should avoid some error bombs.
1372 if Present
(Imptyp
) then
1373 return Base_Type
(Imptyp
);
1381 end Implementation_Base_Type
;
1383 -------------------------
1384 -- Invariant_Procedure --
1385 -------------------------
1387 function Invariant_Procedure
(Id
: E
) return Entity_Id
is
1388 Subp_Elmt
: Elmt_Id
;
1389 Subp_Id
: Entity_Id
;
1393 pragma Assert
(Is_Type
(Id
));
1395 Subps
:= Subprograms_For_Type
(Base_Type
(Id
));
1397 if Present
(Subps
) then
1398 Subp_Elmt
:= First_Elmt
(Subps
);
1399 while Present
(Subp_Elmt
) loop
1400 Subp_Id
:= Node
(Subp_Elmt
);
1402 if Is_Invariant_Procedure
(Subp_Id
) then
1406 Next_Elmt
(Subp_Elmt
);
1411 end Invariant_Procedure
;
1417 -- Global flag table allowing rapid computation of this function
1419 Entity_Is_Base_Type
: constant array (Entity_Kind
) of Boolean :=
1420 (E_Enumeration_Subtype |
1421 E_Incomplete_Subtype |
1422 E_Signed_Integer_Subtype |
1423 E_Modular_Integer_Subtype |
1424 E_Floating_Point_Subtype |
1425 E_Ordinary_Fixed_Point_Subtype |
1426 E_Decimal_Fixed_Point_Subtype |
1430 E_Record_Subtype_With_Private |
1431 E_Limited_Private_Subtype |
1433 E_Protected_Subtype |
1435 E_String_Literal_Subtype |
1436 E_Class_Wide_Subtype
=> False,
1439 function Is_Base_Type
(Id
: E
) return Boolean is
1441 return Entity_Is_Base_Type
(Ekind
(Id
));
1444 ---------------------
1445 -- Is_Boolean_Type --
1446 ---------------------
1448 function Is_Boolean_Type
(Id
: E
) return B
is
1450 return Root_Type
(Id
) = Standard_Boolean
;
1451 end Is_Boolean_Type
;
1453 ------------------------
1454 -- Is_Constant_Object --
1455 ------------------------
1457 function Is_Constant_Object
(Id
: E
) return B
is
1459 return Ekind
(Id
) in E_Constant | E_In_Parameter | E_Loop_Parameter
;
1460 end Is_Constant_Object
;
1466 function Is_Controlled
(Id
: E
) return B
is
1468 return Is_Controlled_Active
(Id
) and then not Disable_Controlled
(Id
);
1471 --------------------
1472 -- Is_Discriminal --
1473 --------------------
1475 function Is_Discriminal
(Id
: E
) return B
is
1477 return Ekind
(Id
) in E_Constant | E_In_Parameter
1478 and then Present
(Discriminal_Link
(Id
));
1481 ----------------------
1482 -- Is_Dynamic_Scope --
1483 ----------------------
1485 function Is_Dynamic_Scope
(Id
: E
) return B
is
1487 return Ekind
(Id
) in E_Block
1488 -- Including an E_Block that came from an N_Expression_With_Actions
1493 | E_Return_Statement
1497 (Ekind
(Id
) = E_Limited_Private_Type
1498 and then Present
(Full_View
(Id
))
1499 and then Ekind
(Full_View
(Id
)) = E_Task_Type
);
1500 end Is_Dynamic_Scope
;
1502 --------------------
1503 -- Is_Entity_Name --
1504 --------------------
1506 function Is_Entity_Name
(N
: Node_Id
) return Boolean is
1507 Kind
: constant Node_Kind
:= Nkind
(N
);
1510 -- Identifiers, operator symbols, expanded names are entity names.
1511 -- (But not N_Character_Literal.)
1513 return Kind
in N_Identifier | N_Operator_Symbol | N_Expanded_Name
1515 -- Attribute references are entity names if they refer to an entity.
1516 -- Note that we don't do this by testing for the presence of the
1517 -- Entity field in the N_Attribute_Reference node, since it may not
1518 -- have been set yet.
1520 or else (Kind
= N_Attribute_Reference
1521 and then Is_Entity_Attribute_Name
(Attribute_Name
(N
)));
1524 ---------------------------
1525 -- Is_Elaboration_Target --
1526 ---------------------------
1528 function Is_Elaboration_Target
(Id
: E
) return Boolean is
1531 Ekind
(Id
) in E_Constant | E_Package | E_Variable
1532 or else Is_Entry
(Id
)
1533 or else Is_Generic_Unit
(Id
)
1534 or else Is_Subprogram
(Id
)
1535 or else Is_Task_Type
(Id
);
1536 end Is_Elaboration_Target
;
1538 -----------------------
1539 -- Is_External_State --
1540 -----------------------
1542 function Is_External_State
(Id
: E
) return B
is
1544 -- To qualify, the abstract state must appear with option "external" or
1545 -- "synchronous" (SPARK RM 7.1.4(7) and (9)).
1548 Ekind
(Id
) = E_Abstract_State
1549 and then (Has_Option
(Id
, Name_External
)
1551 Has_Option
(Id
, Name_Synchronous
));
1552 end Is_External_State
;
1558 function Is_Finalizer
(Id
: E
) return B
is
1560 return Ekind
(Id
) = E_Procedure
and then Chars
(Id
) = Name_uFinalizer
;
1563 ----------------------
1564 -- Is_Full_Access --
1565 ----------------------
1567 function Is_Full_Access
(Id
: E
) return B
is
1569 return Is_Atomic
(Id
) or else Is_Volatile_Full_Access
(Id
);
1576 function Is_Null_State
(Id
: E
) return B
is
1579 Ekind
(Id
) = E_Abstract_State
and then Nkind
(Parent
(Id
)) = N_Null
;
1582 -----------------------------------
1583 -- Is_Package_Or_Generic_Package --
1584 -----------------------------------
1586 function Is_Package_Or_Generic_Package
(Id
: E
) return B
is
1588 return Ekind
(Id
) in E_Generic_Package | E_Package
;
1589 end Is_Package_Or_Generic_Package
;
1591 ---------------------
1592 -- Is_Packed_Array --
1593 ---------------------
1595 function Is_Packed_Array
(Id
: E
) return B
is
1597 return Is_Array_Type
(Id
) and then Is_Packed
(Id
);
1598 end Is_Packed_Array
;
1604 function Is_Prival
(Id
: E
) return B
is
1606 return Ekind
(Id
) in E_Constant | E_Variable
1607 and then Present
(Prival_Link
(Id
));
1610 ----------------------------
1611 -- Is_Protected_Component --
1612 ----------------------------
1614 function Is_Protected_Component
(Id
: E
) return B
is
1616 return Ekind
(Id
) = E_Component
and then Is_Protected_Type
(Scope
(Id
));
1617 end Is_Protected_Component
;
1619 ----------------------------
1620 -- Is_Protected_Interface --
1621 ----------------------------
1623 function Is_Protected_Interface
(Id
: E
) return B
is
1624 Typ
: constant Entity_Id
:= Base_Type
(Id
);
1626 if not Is_Interface
(Typ
) then
1628 elsif Is_Class_Wide_Type
(Typ
) then
1629 return Is_Protected_Interface
(Etype
(Typ
));
1631 return Protected_Present
(Type_Definition
(Parent
(Typ
)));
1633 end Is_Protected_Interface
;
1635 ------------------------------
1636 -- Is_Protected_Record_Type --
1637 ------------------------------
1639 function Is_Protected_Record_Type
(Id
: E
) return B
is
1642 Is_Concurrent_Record_Type
(Id
)
1643 and then Is_Protected_Type
(Corresponding_Concurrent_Type
(Id
));
1644 end Is_Protected_Record_Type
;
1646 -------------------------------------
1647 -- Is_Relaxed_Initialization_State --
1648 -------------------------------------
1650 function Is_Relaxed_Initialization_State
(Id
: E
) return B
is
1652 -- To qualify, the abstract state must appear with simple option
1653 -- "Relaxed_Initialization" (SPARK RM 6.10).
1656 Ekind
(Id
) = E_Abstract_State
1657 and then Has_Option
(Id
, Name_Relaxed_Initialization
);
1658 end Is_Relaxed_Initialization_State
;
1660 --------------------------------
1661 -- Is_Standard_Character_Type --
1662 --------------------------------
1664 function Is_Standard_Character_Type
(Id
: E
) return B
is
1667 and then Root_Type
(Id
) in Standard_Character
1668 | Standard_Wide_Character
1669 | Standard_Wide_Wide_Character
;
1670 end Is_Standard_Character_Type
;
1672 -----------------------------
1673 -- Is_Standard_String_Type --
1674 -----------------------------
1676 function Is_Standard_String_Type
(Id
: E
) return B
is
1679 and then Root_Type
(Id
) in Standard_String
1680 | Standard_Wide_String
1681 | Standard_Wide_Wide_String
;
1682 end Is_Standard_String_Type
;
1684 --------------------
1685 -- Is_String_Type --
1686 --------------------
1688 function Is_String_Type
(Id
: E
) return B
is
1690 return Is_Array_Type
(Id
)
1691 and then Id
/= Any_Composite
1692 and then Number_Dimensions
(Id
) = 1
1693 and then Is_Character_Type
(Component_Type
(Id
));
1696 -------------------------------
1697 -- Is_Synchronized_Interface --
1698 -------------------------------
1700 function Is_Synchronized_Interface
(Id
: E
) return B
is
1701 Typ
: constant Entity_Id
:= Base_Type
(Id
);
1704 if not Is_Interface
(Typ
) then
1707 elsif Is_Class_Wide_Type
(Typ
) then
1708 return Is_Synchronized_Interface
(Etype
(Typ
));
1711 return Protected_Present
(Type_Definition
(Parent
(Typ
)))
1712 or else Synchronized_Present
(Type_Definition
(Parent
(Typ
)))
1713 or else Task_Present
(Type_Definition
(Parent
(Typ
)));
1715 end Is_Synchronized_Interface
;
1717 ---------------------------
1718 -- Is_Synchronized_State --
1719 ---------------------------
1721 function Is_Synchronized_State
(Id
: E
) return B
is
1723 -- To qualify, the abstract state must appear with simple option
1724 -- "synchronous" (SPARK RM 7.1.4(9)).
1727 Ekind
(Id
) = E_Abstract_State
1728 and then Has_Option
(Id
, Name_Synchronous
);
1729 end Is_Synchronized_State
;
1731 -----------------------
1732 -- Is_Task_Interface --
1733 -----------------------
1735 function Is_Task_Interface
(Id
: E
) return B
is
1736 Typ
: constant Entity_Id
:= Base_Type
(Id
);
1738 if not Is_Interface
(Typ
) then
1740 elsif Is_Class_Wide_Type
(Typ
) then
1741 return Is_Task_Interface
(Etype
(Typ
));
1743 return Task_Present
(Type_Definition
(Parent
(Typ
)));
1745 end Is_Task_Interface
;
1747 -------------------------
1748 -- Is_Task_Record_Type --
1749 -------------------------
1751 function Is_Task_Record_Type
(Id
: E
) return B
is
1754 Is_Concurrent_Record_Type
(Id
)
1755 and then Is_Task_Type
(Corresponding_Concurrent_Type
(Id
));
1756 end Is_Task_Record_Type
;
1758 ------------------------
1759 -- Is_Wrapper_Package --
1760 ------------------------
1762 function Is_Wrapper_Package
(Id
: E
) return B
is
1764 return Ekind
(Id
) = E_Package
and then Present
(Related_Instance
(Id
));
1765 end Is_Wrapper_Package
;
1771 function Last_Formal
(Id
: E
) return Entity_Id
is
1776 (Is_Overloadable
(Id
)
1777 or else Ekind
(Id
) in E_Entry_Family
1779 | E_Subprogram_Type
);
1781 if Ekind
(Id
) = E_Enumeration_Literal
then
1785 Formal
:= First_Formal
(Id
);
1787 if Present
(Formal
) then
1788 while Present
(Next_Formal
(Formal
)) loop
1789 Next_Formal
(Formal
);
1801 procedure Link_Entities
(First
, Second
: Entity_Id
) is
1803 if Present
(Second
) then
1804 Set_Prev_Entity
(Second
, First
); -- First <-- Second
1807 Set_Next_Entity
(First
, Second
); -- First --> Second
1810 ------------------------
1811 -- Machine_Emax_Value --
1812 ------------------------
1814 function Machine_Emax_Value
(Id
: E
) return Uint
is
1815 Digs
: constant Pos
:= UI_To_Int
(Digits_Value
(Base_Type
(Id
)));
1818 case Float_Rep
(Id
) is
1821 when 1 .. 6 => return Uint_128
;
1822 when 7 .. 15 => return 2**10;
1823 when 16 .. 33 => return 2**14;
1824 when others => return No_Uint
;
1827 end Machine_Emax_Value
;
1829 ------------------------
1830 -- Machine_Emin_Value --
1831 ------------------------
1833 function Machine_Emin_Value
(Id
: E
) return Uint
is
1835 case Float_Rep
(Id
) is
1836 when IEEE_Binary
=> return Uint_3
- Machine_Emax_Value
(Id
);
1838 end Machine_Emin_Value
;
1840 ----------------------------
1841 -- Machine_Mantissa_Value --
1842 ----------------------------
1844 function Machine_Mantissa_Value
(Id
: E
) return Uint
is
1845 Digs
: constant Pos
:= UI_To_Int
(Digits_Value
(Base_Type
(Id
)));
1848 case Float_Rep
(Id
) is
1851 when 1 .. 6 => return Uint_24
;
1852 when 7 .. 15 => return UI_From_Int
(53);
1853 when 16 .. 18 => return Uint_64
;
1854 when 19 .. 33 => return UI_From_Int
(113);
1855 when others => return No_Uint
;
1858 end Machine_Mantissa_Value
;
1860 -------------------------
1861 -- Machine_Radix_Value --
1862 -------------------------
1864 function Machine_Radix_Value
(Id
: E
) return U
is
1866 case Float_Rep
(Id
) is
1870 end Machine_Radix_Value
;
1872 ----------------------
1873 -- Model_Emin_Value --
1874 ----------------------
1876 function Model_Emin_Value
(Id
: E
) return Uint
is
1878 return Machine_Emin_Value
(Id
);
1879 end Model_Emin_Value
;
1881 -------------------------
1882 -- Model_Epsilon_Value --
1883 -------------------------
1885 function Model_Epsilon_Value
(Id
: E
) return Ureal
is
1886 Radix
: constant Ureal
:= UR_From_Uint
(Machine_Radix_Value
(Id
));
1888 return Radix
** (1 - Model_Mantissa_Value
(Id
));
1889 end Model_Epsilon_Value
;
1891 --------------------------
1892 -- Model_Mantissa_Value --
1893 --------------------------
1895 function Model_Mantissa_Value
(Id
: E
) return Uint
is
1897 return Machine_Mantissa_Value
(Id
);
1898 end Model_Mantissa_Value
;
1900 -----------------------
1901 -- Model_Small_Value --
1902 -----------------------
1904 function Model_Small_Value
(Id
: E
) return Ureal
is
1905 Radix
: constant Ureal
:= UR_From_Uint
(Machine_Radix_Value
(Id
));
1907 return Radix
** (Model_Emin_Value
(Id
) - 1);
1908 end Model_Small_Value
;
1910 --------------------
1911 -- Next_Component --
1912 --------------------
1914 function Next_Component
(Id
: E
) return Entity_Id
is
1915 Comp_Id
: Entity_Id
;
1918 Comp_Id
:= Next_Entity
(Id
);
1919 while Present
(Comp_Id
) loop
1920 exit when Ekind
(Comp_Id
) = E_Component
;
1921 Next_Entity
(Comp_Id
);
1927 ------------------------------------
1928 -- Next_Component_Or_Discriminant --
1929 ------------------------------------
1931 function Next_Component_Or_Discriminant
(Id
: E
) return Entity_Id
is
1932 Comp_Id
: Entity_Id
;
1935 Comp_Id
:= Next_Entity
(Id
);
1936 while Present
(Comp_Id
) loop
1937 exit when Ekind
(Comp_Id
) in E_Component | E_Discriminant
;
1938 Next_Entity
(Comp_Id
);
1942 end Next_Component_Or_Discriminant
;
1944 -----------------------
1945 -- Next_Discriminant --
1946 -----------------------
1948 -- This function actually implements both Next_Discriminant and
1949 -- Next_Stored_Discriminant by making sure that the Discriminant
1950 -- returned is of the same variety as Id.
1952 function Next_Discriminant
(Id
: E
) return Entity_Id
is
1954 -- Derived Tagged types with private extensions look like this...
1956 -- E_Discriminant d1
1957 -- E_Discriminant d2
1959 -- E_Discriminant d1
1960 -- E_Discriminant d2
1963 -- so it is critical not to go past the leading discriminants
1965 D
: Entity_Id
:= Id
;
1968 pragma Assert
(Ekind
(Id
) = E_Discriminant
);
1973 or else (Ekind
(D
) /= E_Discriminant
1974 and then not Is_Itype
(D
))
1979 exit when Ekind
(D
) = E_Discriminant
1980 and then Is_Completely_Hidden
(D
) = Is_Completely_Hidden
(Id
);
1984 end Next_Discriminant
;
1990 function Next_Formal
(Id
: E
) return Entity_Id
is
1994 -- Follow the chain of declared entities as long as the kind of the
1995 -- entity corresponds to a formal parameter. Skip internal entities
1996 -- that may have been created for implicit subtypes, in the process
1997 -- of analyzing default expressions.
2003 if No
(P
) or else Is_Formal
(P
) then
2005 elsif not Is_Internal
(P
) then
2011 -----------------------------
2012 -- Next_Formal_With_Extras --
2013 -----------------------------
2015 function Next_Formal_With_Extras
(Id
: E
) return Entity_Id
is
2017 if Present
(Extra_Formal
(Id
)) then
2018 return Extra_Formal
(Id
);
2020 return Next_Formal
(Id
);
2022 end Next_Formal_With_Extras
;
2028 function Next_Index
(Id
: N
) return Node_Id
is
2030 pragma Assert
(Nkind
(Id
) in N_Is_Index
);
2031 pragma Assert
(No
(Next
(Id
)) or else Nkind
(Next
(Id
)) in N_Is_Index
);
2039 function Next_Literal
(Id
: E
) return Entity_Id
is
2041 pragma Assert
(Nkind
(Id
) in N_Entity
);
2045 ------------------------------
2046 -- Next_Stored_Discriminant --
2047 ------------------------------
2049 function Next_Stored_Discriminant
(Id
: E
) return Entity_Id
is
2051 -- See comment in Next_Discriminant
2053 return Next_Discriminant
(Id
);
2054 end Next_Stored_Discriminant
;
2056 -----------------------
2057 -- Number_Dimensions --
2058 -----------------------
2060 function Number_Dimensions
(Id
: E
) return Pos
is
2065 if Ekind
(Id
) = E_String_Literal_Subtype
then
2070 T
:= First_Index
(Id
);
2071 while Present
(T
) loop
2078 end Number_Dimensions
;
2080 --------------------
2081 -- Number_Entries --
2082 --------------------
2084 function Number_Entries
(Id
: E
) return Nat
is
2089 pragma Assert
(Is_Concurrent_Type
(Id
));
2092 Ent
:= First_Entity
(Id
);
2093 while Present
(Ent
) loop
2094 if Is_Entry
(Ent
) then
2104 --------------------
2105 -- Number_Formals --
2106 --------------------
2108 function Number_Formals
(Id
: E
) return Nat
is
2114 Formal
:= First_Formal
(Id
);
2115 while Present
(Formal
) loop
2117 Next_Formal
(Formal
);
2123 ------------------------
2124 -- Object_Size_Clause --
2125 ------------------------
2127 function Object_Size_Clause
(Id
: E
) return Node_Id
is
2129 return Get_Attribute_Definition_Clause
(Id
, Attribute_Object_Size
);
2130 end Object_Size_Clause
;
2132 --------------------
2133 -- Parameter_Mode --
2134 --------------------
2136 function Parameter_Mode
(Id
: E
) return Formal_Kind
is
2145 function DIC_Procedure
(Id
: E
) return Entity_Id
is
2146 Subp_Elmt
: Elmt_Id
;
2147 Subp_Id
: Entity_Id
;
2151 pragma Assert
(Is_Type
(Id
));
2153 Subps
:= Subprograms_For_Type
(Base_Type
(Id
));
2155 if Present
(Subps
) then
2156 Subp_Elmt
:= First_Elmt
(Subps
);
2157 while Present
(Subp_Elmt
) loop
2158 Subp_Id
:= Node
(Subp_Elmt
);
2160 -- Currently the flag Is_DIC_Procedure is set for both normal DIC
2161 -- check procedures as well as for partial DIC check procedures,
2162 -- and we don't have a flag for the partial procedures.
2164 if Is_DIC_Procedure
(Subp_Id
)
2165 and then not Is_Partial_DIC_Procedure
(Subp_Id
)
2170 Next_Elmt
(Subp_Elmt
);
2177 function Partial_DIC_Procedure
(Id
: E
) return Entity_Id
is
2178 Subp_Elmt
: Elmt_Id
;
2179 Subp_Id
: Entity_Id
;
2183 pragma Assert
(Is_Type
(Id
));
2185 Subps
:= Subprograms_For_Type
(Base_Type
(Id
));
2187 if Present
(Subps
) then
2188 Subp_Elmt
:= First_Elmt
(Subps
);
2189 while Present
(Subp_Elmt
) loop
2190 Subp_Id
:= Node
(Subp_Elmt
);
2192 if Is_Partial_DIC_Procedure
(Subp_Id
) then
2196 Next_Elmt
(Subp_Elmt
);
2201 end Partial_DIC_Procedure
;
2203 function Is_Partial_DIC_Procedure
(Id
: E
) return B
is
2204 Partial_DIC_Suffix
: constant String := "Partial_DIC";
2205 DIC_Nam
: constant String := Get_Name_String
(Chars
(Id
));
2208 pragma Assert
(Ekind
(Id
) in E_Function | E_Procedure
);
2210 -- Instead of adding a new Entity_Id flag (which are in short supply),
2211 -- we test the form of the subprogram name. When the node field and flag
2212 -- situation is eased, this should be replaced with a flag. ???
2214 if DIC_Nam
'Length > Partial_DIC_Suffix
'Length
2217 (DIC_Nam
'Last - Partial_DIC_Suffix
'Length + 1 .. DIC_Nam
'Last) =
2224 end Is_Partial_DIC_Procedure
;
2226 ---------------------------------
2227 -- Partial_Invariant_Procedure --
2228 ---------------------------------
2230 function Partial_Invariant_Procedure
(Id
: E
) return Entity_Id
is
2231 Subp_Elmt
: Elmt_Id
;
2232 Subp_Id
: Entity_Id
;
2236 pragma Assert
(Is_Type
(Id
));
2238 Subps
:= Subprograms_For_Type
(Base_Type
(Id
));
2240 if Present
(Subps
) then
2241 Subp_Elmt
:= First_Elmt
(Subps
);
2242 while Present
(Subp_Elmt
) loop
2243 Subp_Id
:= Node
(Subp_Elmt
);
2245 if Is_Partial_Invariant_Procedure
(Subp_Id
) then
2249 Next_Elmt
(Subp_Elmt
);
2254 end Partial_Invariant_Procedure
;
2256 -------------------------------------
2257 -- Partial_Refinement_Constituents --
2258 -------------------------------------
2260 function Partial_Refinement_Constituents
(Id
: E
) return L
is
2261 Constits
: Elist_Id
:= No_Elist
;
2263 procedure Add_Usable_Constituents
(Item
: E
);
2264 -- Add global item Item and/or its constituents to list Constits when
2265 -- they can be used in a global refinement within the current scope. The
2267 -- 1) If Item is an abstract state with full refinement visible, add
2268 -- its constituents.
2269 -- 2) If Item is an abstract state with only partial refinement
2270 -- visible, add both Item and its constituents.
2271 -- 3) If Item is an abstract state without a visible refinement, add
2273 -- 4) If Id is not an abstract state, add it.
2275 procedure Add_Usable_Constituents
(List
: Elist_Id
);
2276 -- Apply Add_Usable_Constituents to every constituent in List
2278 -----------------------------
2279 -- Add_Usable_Constituents --
2280 -----------------------------
2282 procedure Add_Usable_Constituents
(Item
: E
) is
2284 if Ekind
(Item
) = E_Abstract_State
then
2285 if Has_Visible_Refinement
(Item
) then
2286 Add_Usable_Constituents
(Refinement_Constituents
(Item
));
2288 elsif Has_Partial_Visible_Refinement
(Item
) then
2289 Append_New_Elmt
(Item
, Constits
);
2290 Add_Usable_Constituents
(Part_Of_Constituents
(Item
));
2293 Append_New_Elmt
(Item
, Constits
);
2297 Append_New_Elmt
(Item
, Constits
);
2299 end Add_Usable_Constituents
;
2301 procedure Add_Usable_Constituents
(List
: Elist_Id
) is
2302 Constit_Elmt
: Elmt_Id
;
2304 if Present
(List
) then
2305 Constit_Elmt
:= First_Elmt
(List
);
2306 while Present
(Constit_Elmt
) loop
2307 Add_Usable_Constituents
(Node
(Constit_Elmt
));
2308 Next_Elmt
(Constit_Elmt
);
2311 end Add_Usable_Constituents
;
2313 -- Start of processing for Partial_Refinement_Constituents
2316 -- "Refinement" is a concept applicable only to abstract states
2318 pragma Assert
(Ekind
(Id
) = E_Abstract_State
);
2320 if Has_Visible_Refinement
(Id
) then
2321 Constits
:= Refinement_Constituents
(Id
);
2323 -- A refinement may be partially visible when objects declared in the
2324 -- private part of a package are subject to a Part_Of indicator.
2326 elsif Has_Partial_Visible_Refinement
(Id
) then
2327 Add_Usable_Constituents
(Part_Of_Constituents
(Id
));
2329 -- Function should only be called when full or partial refinement is
2333 raise Program_Error
;
2337 end Partial_Refinement_Constituents
;
2339 ------------------------
2340 -- Predicate_Function --
2341 ------------------------
2343 function Predicate_Function
(Id
: E
) return Entity_Id
is
2344 Subp_Elmt
: Elmt_Id
;
2345 Subp_Id
: Entity_Id
;
2350 pragma Assert
(Is_Type
(Id
));
2352 -- If type is private and has a completion, predicate may be defined on
2355 if Is_Private_Type
(Id
)
2357 (not Has_Predicates
(Id
) or else No
(Subprograms_For_Type
(Id
)))
2358 and then Present
(Full_View
(Id
))
2360 Typ
:= Full_View
(Id
);
2362 elsif Ekind
(Id
) in E_Array_Subtype
2364 | E_Record_Subtype_With_Private
2365 and then Present
(Predicated_Parent
(Id
))
2367 Typ
:= Predicated_Parent
(Id
);
2373 Subps
:= Subprograms_For_Type
(Typ
);
2375 if Present
(Subps
) then
2376 Subp_Elmt
:= First_Elmt
(Subps
);
2377 while Present
(Subp_Elmt
) loop
2378 Subp_Id
:= Node
(Subp_Elmt
);
2380 if Ekind
(Subp_Id
) = E_Function
2381 and then Is_Predicate_Function
(Subp_Id
)
2386 Next_Elmt
(Subp_Elmt
);
2391 end Predicate_Function
;
2393 -------------------------
2394 -- Present_In_Rep_Item --
2395 -------------------------
2397 function Present_In_Rep_Item
(E
: Entity_Id
; N
: Node_Id
) return Boolean is
2401 Ritem
:= First_Rep_Item
(E
);
2403 while Present
(Ritem
) loop
2408 Next_Rep_Item
(Ritem
);
2412 end Present_In_Rep_Item
;
2414 --------------------------
2415 -- Primitive_Operations --
2416 --------------------------
2418 function Primitive_Operations
(Id
: E
) return L
is
2420 if Is_Concurrent_Type
(Id
) then
2421 if Present
(Corresponding_Record_Type
(Id
)) then
2422 return Direct_Primitive_Operations
2423 (Corresponding_Record_Type
(Id
));
2425 -- When expansion is disabled, the corresponding record type is
2426 -- absent, but if this is a tagged type with ancestors, or if the
2427 -- extension of prefixed calls for untagged types is enabled, then
2428 -- it may have associated primitive operations.
2431 return Direct_Primitive_Operations
(Id
);
2435 return Direct_Primitive_Operations
(Id
);
2437 end Primitive_Operations
;
2439 ---------------------
2440 -- Record_Rep_Item --
2441 ---------------------
2443 procedure Record_Rep_Item
(E
: Entity_Id
; N
: Node_Id
) is
2445 Set_Next_Rep_Item
(N
, First_Rep_Item
(E
));
2446 Set_First_Rep_Item
(E
, N
);
2447 end Record_Rep_Item
;
2453 procedure Remove_Entity
(Id
: Entity_Id
) is
2454 Next
: constant Entity_Id
:= Next_Entity
(Id
);
2455 Prev
: constant Entity_Id
:= Prev_Entity
(Id
);
2456 Scop
: constant Entity_Id
:= Scope
(Id
);
2457 First
: constant Entity_Id
:= First_Entity
(Scop
);
2458 Last
: constant Entity_Id
:= Last_Entity
(Scop
);
2461 -- Eliminate any existing linkages from the entity
2463 Set_Prev_Entity
(Id
, Empty
); -- Empty <-- Id
2464 Set_Next_Entity
(Id
, Empty
); -- Id --> Empty
2466 -- The eliminated entity was the only element in the entity chain
2468 if Id
= First
and then Id
= Last
then
2469 Set_First_Entity
(Scop
, Empty
);
2470 Set_Last_Entity
(Scop
, Empty
);
2472 -- The eliminated entity was the head of the entity chain
2474 elsif Id
= First
then
2475 Set_First_Entity
(Scop
, Next
);
2476 Set_Prev_Entity
(Next
, Empty
); -- Empty <-- First_Entity
2478 -- The eliminated entity was the tail of the entity chain
2480 elsif Id
= Last
then
2481 Set_Last_Entity
(Scop
, Prev
);
2482 Set_Next_Entity
(Prev
, Empty
); -- Last_Entity --> Empty
2484 -- Otherwise the eliminated entity comes from the middle of the entity
2488 Link_Entities
(Prev
, Next
); -- Prev <-- Next, Prev --> Next
2496 function Root_Type
(Id
: E
) return E
is
2497 T
, Etyp
: Entity_Id
;
2500 pragma Assert
(Nkind
(Id
) in N_Entity
);
2502 T
:= Base_Type
(Id
);
2504 if Ekind
(T
) = E_Class_Wide_Type
then
2516 -- Following test catches some error cases resulting from
2519 elsif No
(Etyp
) then
2520 Check_Error_Detected
;
2523 elsif Is_Private_Type
(T
) and then Etyp
= Full_View
(T
) then
2526 elsif Is_Private_Type
(Etyp
) and then Full_View
(Etyp
) = T
then
2532 -- Return if there is a circularity in the inheritance chain. This
2533 -- happens in some error situations and we do not want to get
2534 -- stuck in this loop.
2536 if T
= Base_Type
(Id
) then
2543 ---------------------
2544 -- Safe_Emax_Value --
2545 ---------------------
2547 function Safe_Emax_Value
(Id
: E
) return Uint
is
2549 return Machine_Emax_Value
(Id
);
2550 end Safe_Emax_Value
;
2552 ----------------------
2553 -- Safe_First_Value --
2554 ----------------------
2556 function Safe_First_Value
(Id
: E
) return Ureal
is
2558 return -Safe_Last_Value
(Id
);
2559 end Safe_First_Value
;
2561 ---------------------
2562 -- Safe_Last_Value --
2563 ---------------------
2565 function Safe_Last_Value
(Id
: E
) return Ureal
is
2566 Radix
: constant Uint
:= Machine_Radix_Value
(Id
);
2567 Mantissa
: constant Uint
:= Machine_Mantissa_Value
(Id
);
2568 Emax
: constant Uint
:= Safe_Emax_Value
(Id
);
2569 Significand
: constant Uint
:= Radix
** Mantissa
- 1;
2570 Exponent
: constant Uint
:= Emax
- Mantissa
;
2576 (Num
=> Significand
* 2 ** (Exponent
mod 4),
2577 Den
=> -Exponent
/ 4,
2582 (Num
=> Significand
,
2586 end Safe_Last_Value
;
2592 function Scope_Depth
(Id
: Scope_Kind_Id
) return Uint
is
2597 while Is_Record_Type
(Scop
) loop
2598 Scop
:= Scope
(Scop
);
2601 return Scope_Depth_Value
(Scop
);
2604 function Scope_Depth_Default_0
(Id
: Scope_Kind_Id
) return U
is
2606 if Scope_Depth_Set
(Id
) then
2607 return Scope_Depth
(Id
);
2612 end Scope_Depth_Default_0
;
2614 ---------------------
2615 -- Scope_Depth_Set --
2616 ---------------------
2618 function Scope_Depth_Set
(Id
: Scope_Kind_Id
) return B
is
2620 return not Is_Record_Type
(Id
)
2621 and then not Field_Is_Initial_Zero
(Id
, F_Scope_Depth_Value
);
2622 -- We can't call Scope_Depth_Value here, because Empty is not a valid
2623 -- value of type Uint.
2624 end Scope_Depth_Set
;
2626 --------------------
2627 -- Set_Convention --
2628 --------------------
2630 procedure Set_Convention
(E
: Entity_Id
; Val
: Snames
.Convention_Id
) is
2632 Set_Basic_Convention
(E
, Val
);
2634 if Ekind
(E
) in Access_Subprogram_Kind
2635 and then Has_Foreign_Convention
(E
)
2637 Set_Can_Use_Internal_Rep
(E
, False);
2640 -- If E is an object, including a component, and the type of E is an
2641 -- anonymous access type with no convention set, then also set the
2642 -- convention of the anonymous access type. We do not do this for
2643 -- anonymous protected types, since protected types always have the
2644 -- default convention.
2646 if Present
(Etype
(E
))
2647 and then (Is_Object
(E
)
2649 -- Allow E_Void (happens for pragma Convention appearing
2650 -- in the middle of a record applying to a component)
2652 or else Ekind
(E
) = E_Void
)
2655 Typ
: constant Entity_Id
:= Etype
(E
);
2658 if Ekind
(Typ
) in E_Anonymous_Access_Type
2659 | E_Anonymous_Access_Subprogram_Type
2660 and then not Has_Convention_Pragma
(Typ
)
2662 Set_Convention
(Typ
, Val
);
2663 Set_Has_Convention_Pragma
(Typ
);
2665 -- And for the access subprogram type, deal similarly with the
2666 -- designated E_Subprogram_Type, which is always internal.
2668 if Ekind
(Typ
) = E_Anonymous_Access_Subprogram_Type
then
2670 Dtype
: constant Entity_Id
:= Designated_Type
(Typ
);
2672 if Ekind
(Dtype
) = E_Subprogram_Type
then
2673 pragma Assert
(not Has_Convention_Pragma
(Dtype
));
2674 Set_Convention
(Dtype
, Val
);
2675 Set_Has_Convention_Pragma
(Dtype
);
2684 -----------------------
2685 -- Set_DIC_Procedure --
2686 -----------------------
2688 procedure Set_DIC_Procedure
(Id
: E
; V
: E
) is
2689 Base_Typ
: Entity_Id
;
2693 pragma Assert
(Is_Type
(Id
));
2695 Base_Typ
:= Base_Type
(Id
);
2696 Subps
:= Subprograms_For_Type
(Base_Typ
);
2699 Subps
:= New_Elmt_List
;
2700 Set_Subprograms_For_Type
(Base_Typ
, Subps
);
2703 Prepend_Elmt
(V
, Subps
);
2704 end Set_DIC_Procedure
;
2706 procedure Set_Partial_DIC_Procedure
(Id
: E
; V
: E
) is
2708 Set_DIC_Procedure
(Id
, V
);
2709 end Set_Partial_DIC_Procedure
;
2715 procedure Set_Float_Rep
2716 (Ignore_N
: Entity_Id
; Ignore_Val
: Float_Rep_Kind
) is
2718 pragma Assert
(Float_Rep_Kind
'First = Float_Rep_Kind
'Last);
2719 -- There is only one value, so we don't need to store it (see
2723 -----------------------------
2724 -- Set_Invariant_Procedure --
2725 -----------------------------
2727 procedure Set_Invariant_Procedure
(Id
: E
; V
: E
) is
2728 Base_Typ
: Entity_Id
;
2729 Subp_Elmt
: Elmt_Id
;
2730 Subp_Id
: Entity_Id
;
2734 pragma Assert
(Is_Type
(Id
));
2736 Base_Typ
:= Base_Type
(Id
);
2737 Subps
:= Subprograms_For_Type
(Base_Typ
);
2740 Subps
:= New_Elmt_List
;
2741 Set_Subprograms_For_Type
(Base_Typ
, Subps
);
2744 Subp_Elmt
:= First_Elmt
(Subps
);
2745 Prepend_Elmt
(V
, Subps
);
2747 -- Check for a duplicate invariant procedure
2749 while Present
(Subp_Elmt
) loop
2750 Subp_Id
:= Node
(Subp_Elmt
);
2752 if Is_Invariant_Procedure
(Subp_Id
) then
2753 raise Program_Error
;
2756 Next_Elmt
(Subp_Elmt
);
2758 end Set_Invariant_Procedure
;
2760 -------------------------------------
2761 -- Set_Partial_Invariant_Procedure --
2762 -------------------------------------
2764 procedure Set_Partial_Invariant_Procedure
(Id
: E
; V
: E
) is
2765 Base_Typ
: Entity_Id
;
2766 Subp_Elmt
: Elmt_Id
;
2767 Subp_Id
: Entity_Id
;
2771 pragma Assert
(Is_Type
(Id
));
2773 Base_Typ
:= Base_Type
(Id
);
2774 Subps
:= Subprograms_For_Type
(Base_Typ
);
2777 Subps
:= New_Elmt_List
;
2778 Set_Subprograms_For_Type
(Base_Typ
, Subps
);
2781 Subp_Elmt
:= First_Elmt
(Subps
);
2782 Prepend_Elmt
(V
, Subps
);
2784 -- Check for a duplicate partial invariant procedure
2786 while Present
(Subp_Elmt
) loop
2787 Subp_Id
:= Node
(Subp_Elmt
);
2789 if Is_Partial_Invariant_Procedure
(Subp_Id
) then
2790 raise Program_Error
;
2793 Next_Elmt
(Subp_Elmt
);
2795 end Set_Partial_Invariant_Procedure
;
2797 ----------------------------
2798 -- Set_Predicate_Function --
2799 ----------------------------
2801 procedure Set_Predicate_Function
(Id
: E
; V
: E
) is
2802 Subp_Elmt
: Elmt_Id
;
2803 Subp_Id
: Entity_Id
;
2807 pragma Assert
(Is_Type
(Id
) and then Has_Predicates
(Id
));
2809 Subps
:= Subprograms_For_Type
(Id
);
2812 Subps
:= New_Elmt_List
;
2813 Set_Subprograms_For_Type
(Id
, Subps
);
2816 Subp_Elmt
:= First_Elmt
(Subps
);
2817 Prepend_Elmt
(V
, Subps
);
2819 -- Check for a duplicate predication function
2821 while Present
(Subp_Elmt
) loop
2822 Subp_Id
:= Node
(Subp_Elmt
);
2824 if Ekind
(Subp_Id
) = E_Function
2825 and then Is_Predicate_Function
(Subp_Id
)
2827 raise Program_Error
;
2830 Next_Elmt
(Subp_Elmt
);
2832 end Set_Predicate_Function
;
2838 function Size_Clause
(Id
: E
) return Node_Id
is
2839 Result
: Node_Id
:= Get_Attribute_Definition_Clause
(Id
, Attribute_Size
);
2842 Result
:= Get_Attribute_Definition_Clause
(Id
, Attribute_Value_Size
);
2848 ------------------------
2849 -- Stream_Size_Clause --
2850 ------------------------
2852 function Stream_Size_Clause
(Id
: E
) return N
is
2854 return Get_Attribute_Definition_Clause
(Id
, Attribute_Stream_Size
);
2855 end Stream_Size_Clause
;
2861 function Subtype_Kind
(K
: Entity_Kind
) return Entity_Kind
is
2867 Kind
:= E_Access_Subtype
;
2869 when E_Array_Subtype
2872 Kind
:= E_Array_Subtype
;
2874 when E_Class_Wide_Subtype
2877 Kind
:= E_Class_Wide_Subtype
;
2879 when E_Decimal_Fixed_Point_Subtype
2880 | E_Decimal_Fixed_Point_Type
2882 Kind
:= E_Decimal_Fixed_Point_Subtype
;
2884 when E_Ordinary_Fixed_Point_Subtype
2885 | E_Ordinary_Fixed_Point_Type
2887 Kind
:= E_Ordinary_Fixed_Point_Subtype
;
2889 when E_Private_Subtype
2892 Kind
:= E_Private_Subtype
;
2894 when E_Limited_Private_Subtype
2895 | E_Limited_Private_Type
2897 Kind
:= E_Limited_Private_Subtype
;
2899 when E_Record_Subtype_With_Private
2900 | E_Record_Type_With_Private
2902 Kind
:= E_Record_Subtype_With_Private
;
2904 when E_Record_Subtype
2907 Kind
:= E_Record_Subtype
;
2909 when Enumeration_Kind
=>
2910 Kind
:= E_Enumeration_Subtype
;
2912 when E_Incomplete_Type
=>
2913 Kind
:= E_Incomplete_Subtype
;
2916 Kind
:= E_Floating_Point_Subtype
;
2918 when Signed_Integer_Kind
=>
2919 Kind
:= E_Signed_Integer_Subtype
;
2921 when Modular_Integer_Kind
=>
2922 Kind
:= E_Modular_Integer_Subtype
;
2924 when Protected_Kind
=>
2925 Kind
:= E_Protected_Subtype
;
2928 Kind
:= E_Task_Subtype
;
2931 raise Program_Error
;
2937 ---------------------
2938 -- Type_High_Bound --
2939 ---------------------
2941 function Type_High_Bound
(Id
: E
) return N
is
2942 Rng
: constant Node_Id
:= Scalar_Range
(Id
);
2944 if Nkind
(Rng
) = N_Subtype_Indication
then
2945 return High_Bound
(Range_Expression
(Constraint
(Rng
)));
2947 return High_Bound
(Rng
);
2949 end Type_High_Bound
;
2951 --------------------
2952 -- Type_Low_Bound --
2953 --------------------
2955 function Type_Low_Bound
(Id
: E
) return N
is
2956 Rng
: constant Node_Id
:= Scalar_Range
(Id
);
2958 if Nkind
(Rng
) = N_Subtype_Indication
then
2959 return Low_Bound
(Range_Expression
(Constraint
(Rng
)));
2961 return Low_Bound
(Rng
);
2965 ---------------------
2966 -- Underlying_Type --
2967 ---------------------
2969 function Underlying_Type
(Id
: E
) return Entity_Id
is
2971 -- For record_with_private the underlying type is always the direct full
2972 -- view. Never try to take the full view of the parent it does not make
2975 if Ekind
(Id
) = E_Record_Type_With_Private
then
2976 return Full_View
(Id
);
2978 -- If we have a class-wide type that comes from the limited view then we
2979 -- return the Underlying_Type of its nonlimited view.
2981 elsif Ekind
(Id
) = E_Class_Wide_Type
2982 and then From_Limited_With
(Id
)
2983 and then Present
(Non_Limited_View
(Id
))
2985 return Underlying_Type
(Non_Limited_View
(Id
));
2987 elsif Ekind
(Id
) in Incomplete_Or_Private_Kind
then
2989 -- If we have an incomplete or private type with a full view, then we
2990 -- return the Underlying_Type of this full view.
2992 if Present
(Full_View
(Id
)) then
2993 if Id
= Full_View
(Id
) then
2995 -- Previous error in declaration
3000 return Underlying_Type
(Full_View
(Id
));
3003 -- If we have a private type with an underlying full view, then we
3004 -- return the Underlying_Type of this underlying full view.
3006 elsif Ekind
(Id
) in Private_Kind
3007 and then Present
(Underlying_Full_View
(Id
))
3009 return Underlying_Type
(Underlying_Full_View
(Id
));
3011 -- If we have an incomplete entity that comes from the limited view
3012 -- then we return the Underlying_Type of its nonlimited view.
3014 elsif From_Limited_With
(Id
)
3015 and then Present
(Non_Limited_View
(Id
))
3017 return Underlying_Type
(Non_Limited_View
(Id
));
3019 -- Otherwise check for the case where we have a derived type or
3020 -- subtype, and if so get the Underlying_Type of the parent type.
3022 elsif Present
(Etype
(Id
)) and then Etype
(Id
) /= Id
then
3023 return Underlying_Type
(Etype
(Id
));
3025 -- Otherwise we have an incomplete or private type that has no full
3026 -- view, which means that we have not encountered the completion, so
3027 -- return Empty to indicate the underlying type is not yet known.
3033 -- For non-incomplete, non-private types, return the type itself. Also
3034 -- for entities that are not types at all return the entity itself.
3039 end Underlying_Type
;
3041 ------------------------
3042 -- Unlink_Next_Entity --
3043 ------------------------
3045 procedure Unlink_Next_Entity
(Id
: Entity_Id
) is
3046 Next
: constant Entity_Id
:= Next_Entity
(Id
);
3049 if Present
(Next
) then
3050 Set_Prev_Entity
(Next
, Empty
); -- Empty <-- Next
3053 Set_Next_Entity
(Id
, Empty
); -- Id --> Empty
3054 end Unlink_Next_Entity
;
3056 ----------------------------------
3057 -- Is_Volatile, Set_Is_Volatile --
3058 ----------------------------------
3060 function Is_Volatile
(Id
: E
) return B
is
3062 pragma Assert
(Nkind
(Id
) in N_Entity
);
3064 if Is_Type
(Id
) then
3065 return Is_Volatile_Type
(Base_Type
(Id
));
3067 return Is_Volatile_Object
(Id
);
3071 procedure Set_Is_Volatile
(Id
: E
; V
: B
:= True) is
3073 pragma Assert
(Nkind
(Id
) in N_Entity
);
3075 if Is_Type
(Id
) then
3076 Set_Is_Volatile_Type
(Id
, V
);
3078 Set_Is_Volatile_Object
(Id
, V
);
3080 end Set_Is_Volatile
;
3082 -----------------------
3083 -- Write_Entity_Info --
3084 -----------------------
3086 procedure Write_Entity_Info
(Id
: Entity_Id
; Prefix
: String) is
3088 procedure Write_Attribute
(Which
: String; Nam
: E
);
3089 -- Write attribute value with given string name
3091 procedure Write_Kind
(Id
: Entity_Id
);
3092 -- Write Ekind field of entity
3094 ---------------------
3095 -- Write_Attribute --
3096 ---------------------
3098 procedure Write_Attribute
(Which
: String; Nam
: E
) is
3102 Write_Int
(Int
(Nam
));
3104 Write_Name
(Chars
(Nam
));
3106 end Write_Attribute
;
3112 procedure Write_Kind
(Id
: Entity_Id
) is
3113 K
: constant String := Entity_Kind
'Image (Ekind
(Id
));
3117 Write_Str
(" Kind ");
3119 if Is_Type
(Id
) and then Is_Tagged_Type
(Id
) then
3120 Write_Str
("TAGGED ");
3123 Write_Str
(K
(3 .. K
'Length));
3126 if Is_Type
(Id
) and then Depends_On_Private
(Id
) then
3127 Write_Str
("Depends_On_Private ");
3131 -- Start of processing for Write_Entity_Info
3135 Write_Attribute
("Name ", Id
);
3136 Write_Int
(Int
(Id
));
3140 Write_Attribute
(" Type ", Etype
(Id
));
3142 if Id
/= Standard_Standard
then
3143 Write_Attribute
(" Scope ", Scope
(Id
));
3148 when Discrete_Kind
=>
3149 Write_Str
("Bounds: Id = ");
3151 if Present
(Scalar_Range
(Id
)) then
3152 Write_Int
(Int
(Type_Low_Bound
(Id
)));
3153 Write_Str
(" .. Id = ");
3154 Write_Int
(Int
(Type_High_Bound
(Id
)));
3156 Write_Str
("Empty");
3167 (" Component Type ", Component_Type
(Id
));
3170 Write_Str
(" Indexes ");
3172 Index
:= First_Index
(Id
);
3173 while Present
(Index
) loop
3174 Write_Attribute
(" ", Etype
(Index
));
3183 (" Directly Designated Type ",
3184 Directly_Designated_Type
(Id
));
3187 when Overloadable_Kind
=>
3188 if Present
(Homonym
(Id
)) then
3189 Write_Str
(" Homonym ");
3190 Write_Name
(Chars
(Homonym
(Id
)));
3192 Write_Int
(Int
(Homonym
(Id
)));
3199 if Ekind
(Scope
(Id
)) in Record_Kind
then
3201 " Original_Record_Component ",
3202 Original_Record_Component
(Id
));
3203 Write_Int
(Int
(Original_Record_Component
(Id
)));
3210 end Write_Entity_Info
;
3212 -------------------------
3213 -- Iterator Procedures --
3214 -------------------------
3216 procedure Next_Component
(N
: in out Node_Id
) is
3218 N
:= Next_Component
(N
);
3221 procedure Next_Component_Or_Discriminant
(N
: in out Node_Id
) is
3223 N
:= Next_Component_Or_Discriminant
(N
);
3224 end Next_Component_Or_Discriminant
;
3226 procedure Next_Discriminant
(N
: in out Node_Id
) is
3228 N
:= Next_Discriminant
(N
);
3229 end Next_Discriminant
;
3231 procedure Next_Formal
(N
: in out Node_Id
) is
3233 N
:= Next_Formal
(N
);
3236 procedure Next_Formal_With_Extras
(N
: in out Node_Id
) is
3238 N
:= Next_Formal_With_Extras
(N
);
3239 end Next_Formal_With_Extras
;
3241 procedure Next_Index
(N
: in out Node_Id
) is
3243 N
:= Next_Index
(N
);
3246 procedure Next_Inlined_Subprogram
(N
: in out Node_Id
) is
3248 N
:= Next_Inlined_Subprogram
(N
);
3249 end Next_Inlined_Subprogram
;
3251 procedure Next_Literal
(N
: in out Node_Id
) is
3253 N
:= Next_Literal
(N
);
3256 procedure Next_Stored_Discriminant
(N
: in out Node_Id
) is
3258 N
:= Next_Stored_Discriminant
(N
);
3259 end Next_Stored_Discriminant
;