diff options
author | charlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4> | 2015-10-26 10:57:17 +0000 |
---|---|---|
committer | charlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4> | 2015-10-26 10:57:17 +0000 |
commit | 2f06c88a4b3fbf91cf3c60c23f663c65aa7267d3 (patch) | |
tree | 0d8feb8c9db7f87829392d60519c795fc82583d1 /gcc/ada/sem_util.adb | |
parent | 83d39cd3661f8245aede1103a513136c5f39627f (diff) | |
download | gcc-2f06c88a4b3fbf91cf3c60c23f663c65aa7267d3.tar.gz |
2015-10-26 Claire Dross <dross@adacore.com>
* sem_aux.ads (Number_Components): Can return 0 when called on
an empty record.
2015-10-26 Hristian Kirtchev <kirtchev@adacore.com>
* contracts.adb (Analyze_Subprogram_Body_Contract): Use
Unique_Defining_Entity instead of Corresponding_Spec_Of.
* einfo.adb SPARK_Pragma and SPARK_Aux_Pragma are now Node40 and
Node41 respectively.
(SPARK_Aux_Pragma): Update the assertion and node querry.
(SPARK_Aux_Pragma_Inherited): Update the assertion and node query.
(SPARK_Pragma): Update the assertion and node query.
(SPARK_Pragma_Inherited): Update the assertion and node query.
(Set_SPARK_Aux_Pragma): Update the assertion and node setting.
(Set_SPARK_Aux_Pragma_Inherited): Update the assertion and node setting.
(Set_SPARK_Pragma): Update the assertion and node setting.
(Set_SPARK_Pragma_Inherited): Update the assertion and node setting.
(Write_Field32_Name): Remove the output for SPARK_Pragma.
(Write_Field33_Name): Remove the output for SPARK_Aux_Pragma.
(Write_Field40_Name): Add output for SPARK_Pragma.
(Write_Field41_Name): Add output for SPARK_Aux_Pragma.
* einfo.ads Rewrite the documentation on attributes
SPARK_Pragma, SPARK_Aux_Pragma, SPARK_Pragma_Inherited and
SPARK_Aux_Pragma_Inherited. Update their uses in nodes.
* exp_ch4.adb (Create_Anonymous_Master): Use
Unique_Defining_Entity instead of Corresponding_Spec_Of.
* exp_ch9.adb (Expand_Entry_Declaration): Mark the barrier
function as such.
(Expand_N_Task_Body): Mark the task body as such.
(Expand_N_Task_Type_Declaration): Mark the task body as such.
* exp_unst.adb (Visit_Node): Use Unique_Defining_Entity instead
of Corresponding_Spec_Of.
* sem_attr.adb (Analyze_Attribute_Old_Result): Use
Unique_Defining_Entity instead of Corresponding_Spec_Of.
* sem_ch6.adb (Analyze_Subprogram_Body_Helper): Entry barrier
functions do not inherit the SPARK_Mode from the context.
(Build_Subprogram_Declaration): The matching spec is now marked
as a source construct to mimic the original stand alone body.
* sem_ch7.adb (Analyze_Package_Body_Helper): Code cleanup.
* sem_ch9.adb Add with and use clauses for Contracts.
(Analyze_Entry_Body): An entry body freezes the contract of
the nearest enclosing package body. The entry body now inherits
the SPARK_Mode from the context.
(Analyze_Entry_Declaration): A protected entry declaration now inherits
the SPARK_Mode from the context.
(Analyze_Protected_Body): A protected body freezes
the contract of the nearest enclosing package body. Set the
Etype of a protected body as this is neede for proper aspect
analysis. Protected bodies can now carry meaningful aspects and
those are now analyzed.
(Analyze_Protected_Type_Declaration): A protected type now inherits the
SPARK_Mode from the context.
(Analyze_Task_Body): A task body freezes the contract of the
nearest enclosing package body. Set the Etype of a task body
as this is needed for proper aspect analysis. A task body
now inherits the SPARK_Mode from the context. Task bodies
can now carry meaningful aspects and those are now analyzed.
(Analyze_Task_Type_Declaration): A task type declaration now
inherits the SPARK_Mode of from the context.
* sem_ch10.adb (Analyze_Protected_Body_Stub): Protected body
stubs can now carry meaningful aspects.
(Analyze_Task_Body_Stub): Task body stubs can now carry meaningful
aspects.
* sem_ch13.adb (Analyze_Aspect_Specifications): Aspects SPARK_Mode
Warnings now use routine Insert_Pragma as means of insertion into
the tree.
(Insert_After_SPARK_Mode): Clean up documentation.
(Insert_Pragma): Clean up documentation. The routine is now
capable of operating on synchronized units.
* sem_prag.adb (Add_Entity_To_Name_Buffer): New routine.
(Analyze_Contract_Cases_In_Decl_Part): Use
Unique_Defining_Entity instead of Corresponding_Spec_Of.
(Analyze_Depends_Global): Use Unique_Defining_Entity instead
of Corresponding_Spec_Of.
(Analyze_Depends_In_Decl_Part): Use Unique_Defining_Entity instead of
Corresponding_Spec_Of.
(Analyze_Global_In_Decl_Part): Use Unique_Defining_Entity instead of
Corresponding_Spec_Of.
(Analyze_Pragma): Use Unique_Defining_Entity instead of
Corresponding_Spec_Of.
Update the detection of an illegal pragma Ghost when it applies
to a task or protected unit. Reimplement the handling of
pragma SPARK_Mode.
(Analyze_Pre_Post_Condition_In_Decl_Part): Use Unique_Defining_Entity
instead of Corresponding_Spec_Of.
(Analyze_Test_Case_In_Decl_Part): Use Unique_Defining_Entity instead of
Corresponding_Spec_Of.
(Check_Library_Level_Entity): Update the comment on usage.
Reimplemented to offer a more specialized errror context.
(Check_Pragma_Conformance): Update profile and comment on usage.
Handle error message output on single protected or task units.
(Collect_Subprogram_Inputs_Outputs): Use Unique_Defining_Entity
instead of Corresponding_Spec_Of.
(Process_Body): New routine.
(Process_Overloadable): New routine.
(Process_Private_Part): New routine.
(Process_Statement_Part): New routine.
(Process_Visible_Part): New routine.
(Set_SPARK_Context): New routine.
(Set_SPARK_Flags): Removed.
* sem_util.adb (Corresponding_Spec_Of): Removed.
(Unique_Entity): Reimplemented to handle many more cases.
* sem_util.ads (Corresponding_Spec_Of): Removed.
(Unique_Defining_Entity): Update the comment on usage.
* sinfo.ads (Is_Entry_Barrier_Function): Update the assertion.
(Is_Task_Body_Procedure): New routine.
(Set_Is_Entry_Barrier_Function): Update the assertion.
(Set_Is_Task_Body_Procedure): New routine.
* sinfo.adb Update the documentation of attribute
Is_Entry_Barrier_Function along with use in nodes. Add new
attribute Is_Task_Body_Procedure along with use in nodes.
(Is_Task_Body_Procedure): New routine along with pragma Inline.
(Set_Is_Task_Body_Procedure): New routine along with pragma Inline.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@229328 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/ada/sem_util.adb')
-rw-r--r-- | gcc/ada/sem_util.adb | 128 |
1 files changed, 69 insertions, 59 deletions
diff --git a/gcc/ada/sem_util.adb b/gcc/ada/sem_util.adb index 634b4790c61..4a86c71ab59 100644 --- a/gcc/ada/sem_util.adb +++ b/gcc/ada/sem_util.adb @@ -4766,27 +4766,6 @@ package body Sem_Util is end if; end Corresponding_Generic_Type; - --------------------------- - -- Corresponding_Spec_Of -- - --------------------------- - - function Corresponding_Spec_Of (Decl : Node_Id) return Entity_Id is - begin - if Nkind_In (Decl, N_Package_Body, N_Subprogram_Body) - and then Present (Corresponding_Spec (Decl)) - then - return Corresponding_Spec (Decl); - - elsif Nkind_In (Decl, N_Package_Body_Stub, N_Subprogram_Body_Stub) - and then Present (Corresponding_Spec_Of_Stub (Decl)) - then - return Corresponding_Spec_Of_Stub (Decl); - - else - return Defining_Entity (Decl); - end if; - end Corresponding_Spec_Of; - -------------------- -- Current_Entity -- -------------------- @@ -19031,9 +19010,31 @@ package body Sem_Util is U := Full_View (E); end if; - when Type_Kind => - if Present (Full_View (E)) then - U := Full_View (E); + when Entry_Kind => + if Nkind (Parent (E)) = N_Entry_Body then + declare + Prot_Item : Entity_Id; + begin + -- Traverse the entity list of the protected type and locate + -- an entry declaration which matches the entry body. + + Prot_Item := First_Entity (Scope (E)); + while Present (Prot_Item) loop + if Ekind (Prot_Item) = E_Entry + and then Corresponding_Body (Parent (Prot_Item)) = E + then + U := Prot_Item; + exit; + end if; + + Next_Entity (Prot_Item); + end loop; + end; + end if; + + when Formal_Kind => + if Present (Spec_Entity (E)) then + U := Spec_Entity (E); end if; when E_Package_Body => @@ -19043,7 +19044,30 @@ package body Sem_Util is P := Parent (P); end if; - U := Corresponding_Spec (P); + if Nkind (P) = N_Package_Body + and then Present (Corresponding_Spec (P)) + then + U := Corresponding_Spec (P); + + elsif Nkind (P) = N_Package_Body_Stub + and then Present (Corresponding_Spec_Of_Stub (P)) + then + U := Corresponding_Spec_Of_Stub (P); + end if; + + when E_Protected_Body => + P := Parent (E); + + if Nkind (P) = N_Protected_Body + and then Present (Corresponding_Spec (P)) + then + U := Corresponding_Spec (P); + + elsif Nkind (P) = N_Protected_Body_Stub + and then Present (Corresponding_Spec_Of_Stub (P)) + then + U := Corresponding_Spec_Of_Stub (P); + end if; when E_Subprogram_Body => P := Parent (E); @@ -19054,48 +19078,34 @@ package body Sem_Util is P := Parent (P); - if Nkind (P) = N_Subprogram_Body_Stub then - if Present (Library_Unit (P)) then - - -- Get to the function or procedure (generic) entity through - -- the body entity. - - U := - Unique_Entity (Defining_Entity (Get_Body_From_Stub (P))); - end if; - else + if Nkind (P) = N_Subprogram_Body + and then Present (Corresponding_Spec (P)) + then U := Corresponding_Spec (P); - end if; - when Formal_Kind => - if Present (Spec_Entity (E)) then - U := Spec_Entity (E); + elsif Nkind (P) = N_Subprogram_Body_Stub + and then Present (Corresponding_Spec_Of_Stub (P)) + then + U := Corresponding_Spec_Of_Stub (P); end if; when E_Task_Body => P := Parent (E); - U := Corresponding_Spec (P); - when E_Entry => - if Nkind (Parent (E)) = N_Entry_Body then - declare - Decl : Entity_Id := First_Entity (Scope (E)); - begin - -- Traverse the entity list of the protected object - -- and locate an entry declaration with a matching - -- Corresponding_Body. + if Nkind (P) = N_Task_Body + and then Present (Corresponding_Spec (P)) + then + U := Corresponding_Spec (P); - while Present (Decl) loop - if Ekind (Decl) = E_Entry - and then Corresponding_Body (Parent (Decl)) = E - then - U := Decl; - exit; - end if; - Next_Entity (Decl); - end loop; - pragma Assert (Present (Decl)); - end; + elsif Nkind (P) = N_Task_Body_Stub + and then Present (Corresponding_Spec_Of_Stub (P)) + then + U := Corresponding_Spec_Of_Stub (P); + end if; + + when Type_Kind => + if Present (Full_View (E)) then + U := Full_View (E); end if; when others => |