From: Ed Schonberg Date: Mon, 16 Dec 2019 10:33:54 +0000 (+0000) Subject: [Ada] Crash on conversion in branch of if-expression X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=90393d3ca7fe7547777473f4b197792f1cb3fca9;p=gcc.git [Ada] Crash on conversion in branch of if-expression 2019-12-16 Ed Schonberg gcc/ada/ * checks.adb (Apply_Float_Conversion_Check): Use node of type conversion and not its parent, when inserting the declaration for the temporary that hold the result of the conversion. Previously the declaration was inserted above the parent of the conversion, apparently as a small optimization for the subsequent traversal in Insert_Actions. Unfortunately a similar optimization takes place in Insert_Actions, assuming that the insertion point must be above the expression that creates the actions to insert. This is not correct in the presence of conditional expressions (i.e. since Ada2012), where the insertion must be in the list of actions attached to the current alternative. From-SVN: r279422 --- diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog index aa970430990..e0f821b0a28 100644 --- a/gcc/ada/ChangeLog +++ b/gcc/ada/ChangeLog @@ -1,3 +1,18 @@ +2019-12-16 Ed Schonberg + + * checks.adb (Apply_Float_Conversion_Check): Use node of type + conversion and not its parent, when inserting the declaration + for the temporary that hold the result of the conversion. + Previously the declaration was inserted above the parent of the + conversion, apparently as a small optimization for the + subsequent traversal in Insert_Actions. Unfortunately a similar + optimization takes place in Insert_Actions, assuming that the + insertion point must be above the expression that creates the + actions to insert. This is not correct in the presence of + conditional expressions (i.e. since Ada2012), where the + insertion must be in the list of actions attached to the current + alternative. + 2019-12-16 Bob Duff * sem_attr.adb (Analyze_Attribute): Use Known_RM_Size. But we diff --git a/gcc/ada/checks.adb b/gcc/ada/checks.adb index 9ca1cf0cdce..6b910fd7024 100644 --- a/gcc/ada/checks.adb +++ b/gcc/ada/checks.adb @@ -2067,7 +2067,17 @@ package body Checks is Apply_Float_Conversion_Check (Ck_Node, Target_Base); Set_Etype (Temp, Target_Base); - Insert_Action (Parent (Par), + -- Note : previously the declaration was inserted above + -- the parent of the conversion, apparently as a small + -- optimization for the subequent traversal in Insert_ + -- Actions. Unfortunately a similar optimization takes + -- place in Insert_Actions, assuming that the insertion + -- point must be above the expression that creates actions. + -- This is not correct in the presence of conditional + -- expressions, where the insertion must be in the + -- list of asctions attached to the current alternative. + + Insert_Action (Par, Make_Object_Declaration (Loc, Defining_Identifier => Temp, Object_Definition => New_Occurrence_Of (Target_Typ, Loc),