+2010-10-18 Javier Miranda <miranda@adacore.com>
+
+ * exp_util.adb (Side_Effect_Free): Code clean up.
+
+2010-10-18 Ed Schonberg <schonberg@adacore.com>
+
+ * sem_ch8.adb (Is_Primitive_Operator_In_Use): Renamed from
+ Is_Primitive_Operator. When ending the scope of a use package scope, a
+ primitive operator remains in use if the base type has a current use
+ (type) clause.
+
+2010-10-18 Javier Miranda <miranda@adacore.com>
+
+ * einfo.ads (Is_Dynamic_Support): Add missing support for limited
+ private types whose full-view is a task type.
+ * sem_util.adb (Enclosing_Subprogram): Add missing support for limited
+ private types whose full-view is a task type.
+ * exp_ch7.adb (Find_Final_List): Minor code cleanup replacing code by
+ function Nearest_Dynamic_Scope which provides the needed functionality.
+
+2010-10-18 Arnaud Charlet <charlet@adacore.com>
+
+ * sem_prag.adb (Set_Exported): Do not generate error when exporting a
+ variable with an address clause in codepeer mode.
+
2010-10-18 Robert Dewar <dewar@adacore.com>
* g-trasym-vms-ia64.adb: Minor reformatting.
or else
Ekind (Id) = E_Task_Type
or else
+ (Ekind (Id) = E_Limited_Private_Type
+ and then Present (Full_View (Id))
+ and then Ekind (Full_View (Id)) = E_Task_Type)
+ or else
Ekind (Id) = E_Entry
or else
Ekind (Id) = E_Entry_Family
end if;
else
- if Is_Dynamic_Scope (E) then
- S := E;
- else
- S := Enclosing_Dynamic_Scope (E);
- end if;
+ S := Nearest_Dynamic_Scope (E);
-- When the finalization chain entity is 'Error', it means that there
-- should not be any chain at that level and that the enclosing one
elsif VM_Target /= No_VM
and then not Comes_From_Source (N)
- and then Is_Class_Wide_Type (Etype (N))
and then Nkind (Parent (N)) = N_Object_Renaming_Declaration
+ and then Is_Class_Wide_Type (Etype (N))
then
return True;
end if;
Id : Entity_Id;
Elmt : Elmt_Id;
- function Is_Primitive_Operator
+ function Is_Primitive_Operator_In_Use
(Op : Entity_Id;
F : Entity_Id) return Boolean;
-- Check whether Op is a primitive operator of a use-visible type
- ---------------------------
- -- Is_Primitive_Operator --
- ---------------------------
+ ----------------------------------
+ -- Is_Primitive_Operator_In_Use --
+ ----------------------------------
- function Is_Primitive_Operator
+ function Is_Primitive_Operator_In_Use
(Op : Entity_Id;
F : Entity_Id) return Boolean
is
T : constant Entity_Id := Etype (F);
begin
- return In_Use (T)
+ return (In_Use (T)
+ or else Present (Current_Use_Clause (Base_Type (T))))
and then Scope (T) = Scope (Op);
- end Is_Primitive_Operator;
+ end Is_Primitive_Operator_In_Use;
-- Start of processing for End_Use_Package
if Nkind (Id) = N_Defining_Operator_Symbol
and then
- (Is_Primitive_Operator (Id, First_Formal (Id))
+ (Is_Primitive_Operator_In_Use
+ (Id, First_Formal (Id))
or else
(Present (Next_Formal (First_Formal (Id)))
and then
- Is_Primitive_Operator
+ Is_Primitive_Operator_In_Use
(Id, Next_Formal (First_Formal (Id)))))
then
null;
Error_Pragma_Arg
("cannot export entity& that was previously imported", Arg);
- elsif Present (Address_Clause (E)) then
+ elsif Present (Address_Clause (E)) and then not CodePeer_Mode then
Error_Pragma_Arg
("cannot export entity& that has an address clause", Arg);
end if;
elsif Ekind (Dynamic_Scope) = E_Task_Type then
return Get_Task_Body_Procedure (Dynamic_Scope);
+ elsif Ekind (Dynamic_Scope) = E_Limited_Private_Type
+ and then Present (Full_View (Dynamic_Scope))
+ and then Ekind (Full_View (Dynamic_Scope)) = E_Task_Type
+ then
+ return Get_Task_Body_Procedure (Full_View (Dynamic_Scope));
+
-- No body is generated if the protected operation is eliminated
elsif Convention (Dynamic_Scope) = Convention_Protected