From: Daniel Mercier Date: Fri, 2 Jul 2021 10:57:53 +0000 (+0200) Subject: [Ada] Set related expression for external DISCR symbols in Build_Temporary X-Git-Tag: basepoints/gcc-13~4565 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=900f9d999cc4870cc3cb70224e9694212385a4d3;p=thirdparty%2Fgcc.git [Ada] Set related expression for external DISCR symbols in Build_Temporary gcc/ada/ * exp_util.adb (Build_Temporary): In case of an external DISCR symbol, set the related expression for CodePeer so that a more comprehensible message can be emitted to the user. --- diff --git a/gcc/ada/exp_util.adb b/gcc/ada/exp_util.adb index 966548151190..ad5a6fab2e96 100644 --- a/gcc/ada/exp_util.adb +++ b/gcc/ada/exp_util.adb @@ -11656,6 +11656,7 @@ package body Exp_Util is is Temp_Id : Entity_Id; Temp_Nam : Name_Id; + Should_Set_Related_Expression : Boolean := False; begin -- The context requires an external symbol : expression is @@ -11675,6 +11676,12 @@ package body Exp_Util is else pragma Assert (Discr_Number > 0); + + -- We don't have any intelligible way of printing T_DISCR in + -- CodePeer. Thus, set a related expression in this case. + + Should_Set_Related_Expression := True; + -- Use fully qualified name to avoid ambiguities. Temp_Nam := @@ -11684,6 +11691,10 @@ package body Exp_Util is Temp_Id := Make_Defining_Identifier (Loc, Temp_Nam); + if Should_Set_Related_Expression then + Set_Related_Expression (Temp_Id, Related_Nod); + end if; + -- Otherwise generate an internal temporary else