From: Steve Baird Date: Tue, 26 Jul 2022 00:19:29 +0000 (-0700) Subject: [Ada] Bad Default_Initial_Condition check for a not-default-initialized object X-Git-Tag: basepoints/gcc-14~4785 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=2237f94d32c1116d221b2818c04d1db4508665af;p=thirdparty%2Fgcc.git [Ada] Bad Default_Initial_Condition check for a not-default-initialized object No Default_Initial_Condition check should be generated for an object declaration that has an explicit initial value. Previously this was implemented by testing the Has_Init_Expression flag, but this only works if the object declaration was created by the parser (since only the parser sets that attribute, at least currently). gcc/ada/ * exp_ch3.adb (Expand_N_Object_Declaration): In deciding whether to emit a DIC check, we were previously testing the Has_Init_Expression flag. Continue to test that flag as before, but add a test for the syntactic presence of an initial value in the object declaration. This new test would not supersede the old test in the case where an explicit initial value has been eliminated as part of some tree transformation. --- diff --git a/gcc/ada/exp_ch3.adb b/gcc/ada/exp_ch3.adb index eee58239a622..0d826913f756 100644 --- a/gcc/ada/exp_ch3.adb +++ b/gcc/ada/exp_ch3.adb @@ -7850,6 +7850,7 @@ package body Exp_Ch3 is and then Present (DIC_Procedure (Typ)) and then not Has_Null_Body (DIC_Procedure (Typ)) and then not Has_Init_Expression (N) + and then No (Expr) and then not Is_Imported (Def_Id) then declare