diff options
author | Steve Baird <baird@adacore.com> | 2023-11-21 11:00:37 -0800 |
---|---|---|
committer | Marc Poulhiès <poulhies@adacore.com> | 2023-12-19 15:27:48 +0100 |
commit | 5c374c0907b4da06c163e3d15f182d91f1114ff2 (patch) | |
tree | 3c1c4814e28a9ac6f28a443153ef099af1e41721 | |
parent | 95a7771da2c0d9ac1f78f25fed40caef4ea3ab56 (diff) | |
download | gcc-5c374c0907b4da06c163e3d15f182d91f1114ff2.zip gcc-5c374c0907b4da06c163e3d15f182d91f1114ff2.tar.gz gcc-5c374c0907b4da06c163e3d15f182d91f1114ff2.tar.bz2 |
ada: Cope with Sem_Util.Enclosing_Declaration oddness.
Sem_Util.Enclosing_Declaration can return a non-empty result which is not
a declaration; clients may need to compensate for the case where an
N_Subprogram_Specification node is returned. One such client is the function
Is_Actual_Subp_Of_Inst.
gcc/ada/
* sem_ch8.adb (Is_Actual_Subp_Of_Inst): After calling
Enclosing_Declaration, add a check for the case where one more
Parent call is needed to get the enclosing declaration.
-rw-r--r-- | gcc/ada/sem_ch8.adb | 12 |
1 files changed, 11 insertions, 1 deletions
diff --git a/gcc/ada/sem_ch8.adb b/gcc/ada/sem_ch8.adb index c5bf086..2e6b1b6 100644 --- a/gcc/ada/sem_ch8.adb +++ b/gcc/ada/sem_ch8.adb @@ -2691,7 +2691,7 @@ package body Sem_Ch8 is -- Each attempt to find a suitable primitive of a particular -- type operates on its own copy of the original renaming. -- As a result the original renaming is kept decoration and - -- side-effect-free. + -- side-effect free. -- Inherit the overloaded status of the renamed subprogram name @@ -6550,6 +6550,16 @@ 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. |