@@ -3761,7 +3761,6 @@ package body Contracts is
ICW_Decl := Build_ICW_Decl;
- Ensure_Freeze_Node (Tagged_Type);
Append_Freeze_Action (Tagged_Type, ICW_Decl);
Analyze (ICW_Decl);
@@ -4034,7 +4033,6 @@ package body Contracts is
-- Add the helper to the freezing actions of the tagged type
- Ensure_Freeze_Node (Tagged_Type);
Append_Freeze_Action (Tagged_Type, Helper_Decl);
Analyze (Helper_Decl);
@@ -580,8 +580,7 @@ package body Exp_Ch3 is
-- Place body in list of freeze actions for the type.
- Ensure_Freeze_Node (Type_Id);
- Append_Freeze_Actions (Type_Id, New_List (Body_Node));
+ Append_Freeze_Action (Type_Id, Body_Node);
end Build_Access_Subprogram_Wrapper_Body;
---------------------------
@@ -458,7 +458,6 @@ package body Exp_Util is
else
Append (N, Actions (Fnode));
end if;
-
end Append_Freeze_Action;
---------------------------
@@ -2044,9 +2044,8 @@ package body Freeze is
-- node of the record type declaration to ensure that it will
-- override the internal primitive built by Derive_Subprogram.
- Ensure_Freeze_Node (R);
-
if Late_Overriding then
+ Ensure_Freeze_Node (R);
Insert_Before_And_Analyze (Freeze_Node (R), DTW_Decl);
else
Append_Freeze_Action (R, DTW_Decl);
@@ -6815,8 +6815,7 @@ package body Sem_Ch3 is
-- in a dispatch table.
if not GNATprove_Mode then
- Ensure_Freeze_Node (Id);
- Append_Freeze_Actions (Id, New_List (New_Decl));
+ Append_Freeze_Action (Id, New_Decl);
-- Under GNATprove mode there is no such problem but we do not declare
-- it in the freezing actions since they are not analyzed under this
@@ -2715,13 +2715,11 @@ package body Sem_Ch6 is
end if;
else
- Ensure_Freeze_Node (Typ);
-
declare
IR : constant Node_Id := Make_Itype_Reference (Sloc (N));
begin
Set_Itype (IR, Etype (Designator));
- Append_Freeze_Actions (Typ, New_List (IR));
+ Append_Freeze_Action (Typ, IR);
end;
end if;
@@ -4689,7 +4689,6 @@ package body Sem_Ch8 is
if Is_Tagged_Type (Etype (P))
and then In_Open_Scopes (Scope (Etype (P)))
then
- Ensure_Freeze_Node (Etype (P));
Append_Freeze_Action (Etype (P), Body_Node);
else
Rewrite (N, Body_Node);