summaryrefslogtreecommitdiff
path: root/gcc/ada/sem_util.adb
diff options
context:
space:
mode:
authorcharlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4>2015-10-26 10:57:17 +0000
committercharlet <charlet@138bc75d-0d04-0410-961f-82ee72b054a4>2015-10-26 10:57:17 +0000
commit2f06c88a4b3fbf91cf3c60c23f663c65aa7267d3 (patch)
tree0d8feb8c9db7f87829392d60519c795fc82583d1 /gcc/ada/sem_util.adb
parent83d39cd3661f8245aede1103a513136c5f39627f (diff)
downloadgcc-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.adb128
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 =>