diff options
author | Steve Baird <baird@adacore.com> | 2023-12-07 12:18:29 -0800 |
---|---|---|
committer | Marc Poulhiès <poulhies@adacore.com> | 2024-01-09 14:13:30 +0100 |
commit | 7d4c4a4d21aceabf7bae4eec608d2c6f22fc9d76 (patch) | |
tree | f6f78856a2d881871fbfd7a72df96e2bc6ef93d9 | |
parent | 85f0ae3c54ad48e62ca02e61a1aa1ab3c8664142 (diff) | |
download | gcc-7d4c4a4d21aceabf7bae4eec608d2c6f22fc9d76.zip gcc-7d4c4a4d21aceabf7bae4eec608d2c6f22fc9d76.tar.gz gcc-7d4c4a4d21aceabf7bae4eec608d2c6f22fc9d76.tar.bz2 |
ada: Fix bug in Sem_Util.Enclosing_Declaration
Fix Sem_Util.Enclosing_Declaration to not return an N_Subprogram_Specification
node. Remove code in various places that was formerly needed to cope with this
misbehavior.
gcc/ada/
* sem_util.adb (Enclosing_Declaration): Instead of returning a
subprogram specification node, return its parent (which is
presumably a subprogram declaration).
* contracts.adb (Insert_Stable_Property_Check): Remove code
formerly needed to compensate for incorrect behavior of
Sem_Util.Enclosing_Declaration.
* exp_attr.adb (In_Available_Context): Remove code formerly needed
to compensate for incorrect behavior of
Sem_Util.Enclosing_Declaration.
* sem_ch8.adb (Is_Actual_Subp_Of_Inst): Remove code formerly
needed to compensate for incorrect behavior of
Sem_Util.Enclosing_Declaration.
-rw-r--r-- | gcc/ada/contracts.adb | 12 | ||||
-rw-r--r-- | gcc/ada/exp_attr.adb | 11 | ||||
-rw-r--r-- | gcc/ada/sem_ch8.adb | 10 | ||||
-rw-r--r-- | gcc/ada/sem_util.adb | 5 |
4 files changed, 8 insertions, 30 deletions
diff --git a/gcc/ada/contracts.adb b/gcc/ada/contracts.adb index fa0d59a..21bbbf1 100644 --- a/gcc/ada/contracts.adb +++ b/gcc/ada/contracts.adb @@ -2529,17 +2529,9 @@ package body Contracts is Pragma_Argument_Associations => Args, Class_Present => Class_Present); - Subp_Decl : Node_Id := Subp_Id; + Subp_Decl : constant Node_Id := Enclosing_Declaration (Subp_Id); + pragma Assert (Is_Declaration (Subp_Decl)); begin - -- Enclosing_Declaration may return, for example, - -- a N_Procedure_Specification node. Cope with this. - loop - Subp_Decl := Enclosing_Declaration (Subp_Decl); - exit when Is_Declaration (Subp_Decl); - Subp_Decl := Parent (Subp_Decl); - pragma Assert (Present (Subp_Decl)); - end loop; - Insert_After_And_Analyze (Subp_Decl, Prag); end Insert_Stable_Property_Check; diff --git a/gcc/ada/exp_attr.adb b/gcc/ada/exp_attr.adb index 66fd684..a781f93 100644 --- a/gcc/ada/exp_attr.adb +++ b/gcc/ada/exp_attr.adb @@ -8653,17 +8653,8 @@ package body Exp_Attr is -------------------------- function In_Available_Context (Ent : Entity_Id) return Boolean is - Decl : Node_Id := Enclosing_Declaration (Ent); + Decl : constant Node_Id := Enclosing_Declaration (Ent); begin - -- Enclosing_Declaration does not always return a declaration; - -- cope with this irregularity. - if Decl in N_Subprogram_Specification_Id - and then Nkind (Parent (Decl)) in - N_Subprogram_Body | N_Subprogram_Declaration - then - Decl := Parent (Decl); - end if; - if Has_Declarations (Parent (Decl)) then return In_Subtree (Attr_Ref, Root => Parent (Decl)); elsif Is_List_Member (Decl) then diff --git a/gcc/ada/sem_ch8.adb b/gcc/ada/sem_ch8.adb index 5408be3..fc2fec5 100644 --- a/gcc/ada/sem_ch8.adb +++ b/gcc/ada/sem_ch8.adb @@ -6562,16 +6562,6 @@ package body Sem_Ch8 is Decl := Enclosing_Declaration (E); - -- Enclosing_Declaration does not always return a - -- declaration; cope with this irregularity. - if Decl in N_Subprogram_Specification_Id - and then Nkind (Parent (Decl)) in - N_Subprogram_Body | N_Subprogram_Declaration - | N_Subprogram_Renaming_Declaration - then - Decl := Parent (Decl); - end if; - -- Look for the suprogram renaming declaration built -- for a generic actual subprogram. Unclear why -- Original_Node call is needed, but sometimes it is. diff --git a/gcc/ada/sem_util.adb b/gcc/ada/sem_util.adb index 9cff9e1..01be86c 100644 --- a/gcc/ada/sem_util.adb +++ b/gcc/ada/sem_util.adb @@ -7386,6 +7386,11 @@ package body Sem_Util is Decl := Parent (Decl); end loop; + -- cope with oddness in definition of N_Declaration + if Nkind (Decl) in N_Subprogram_Specification then + Decl := Parent (Decl); + end if; + return Decl; end Enclosing_Declaration; |