]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
[Ada] Bad Default_Initial_Condition check for a not-default-initialized object
authorSteve Baird <baird@adacore.com>
Tue, 26 Jul 2022 00:19:29 +0000 (17:19 -0700)
committerMarc Poulhiès <poulhies@adacore.com>
Mon, 5 Sep 2022 07:21:05 +0000 (09:21 +0200)
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.

gcc/ada/exp_ch3.adb

index eee58239a62240259a0a8cce53f282474c720efd..0d826913f756d26b451dc3fb2b15f17999f410c7 100644 (file)
@@ -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