From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 1914) id 591203857C5E; Fri, 1 Oct 2021 06:15:22 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 591203857C5E MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Content-Type: text/plain; charset="utf-8" From: Pierre-Marie de Rodat To: gcc-cvs@gcc.gnu.org Subject: [gcc r12-4015] [Ada] Implementation of AI12-0212: iterator specs in array aggregates (II) X-Act-Checkin: gcc X-Git-Author: Ed Schonberg X-Git-Refname: refs/heads/master X-Git-Oldrev: 475e1d240086365da3e240fb9199eb1c5ad511f8 X-Git-Newrev: 8b1a5da38e00348dfc359ef8418de344356ef78e Message-Id: <20211001061522.591203857C5E@sourceware.org> Date: Fri, 1 Oct 2021 06:15:22 +0000 (GMT) X-BeenThere: gcc-cvs@gcc.gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Gcc-cvs mailing list List-Unsubscribe: , List-Archive: List-Help: List-Subscribe: , X-List-Received-Date: Fri, 01 Oct 2021 06:15:22 -0000 https://gcc.gnu.org/g:8b1a5da38e00348dfc359ef8418de344356ef78e commit r12-4015-g8b1a5da38e00348dfc359ef8418de344356ef78e Author: Ed Schonberg Date: Wed Aug 11 12:52:29 2021 -0400 [Ada] Implementation of AI12-0212: iterator specs in array aggregates (II) gcc/ada/ * exp_aggr.adb (Expand_Array_Aggregate, Two_Pass_Aggregate_Expansion): Increment index for element insertion within the loop, only if upper bound has not been reached. Diff: --- gcc/ada/exp_aggr.adb | 23 +++++++++++++++++------ 1 file changed, 17 insertions(+), 6 deletions(-) diff --git a/gcc/ada/exp_aggr.adb b/gcc/ada/exp_aggr.adb index 461e4faac20..71bad3cb676 100644 --- a/gcc/ada/exp_aggr.adb +++ b/gcc/ada/exp_aggr.adb @@ -6504,6 +6504,18 @@ package body Exp_Aggr is Expressions => New_List (New_Occurrence_Of (Index_Id, Loc)))); + -- Add guard to skip last increment when upper bound is reached. + + Incr := Make_If_Statement (Loc, + Condition => + Make_Op_Ne (Loc, + Left_Opnd => New_Occurrence_Of (Index_Id, Loc), + Right_Opnd => + Make_Attribute_Reference (Loc, + Prefix => New_Occurrence_Of (Index_Type, Loc), + Attribute_Name => Name_Last)), + Then_Statements => New_List (Incr)); + One_Loop := Make_Loop_Statement (Loc, Iteration_Scheme => Make_Iteration_Scheme (Loc, @@ -6561,11 +6573,10 @@ package body Exp_Aggr is return; elsif Present (Component_Associations (N)) - and then - Nkind (First (Component_Associations (N))) - = N_Iterated_Component_Association - and then Present - (Iterator_Specification (First (Component_Associations (N)))) + and then Nkind (First (Component_Associations (N))) = + N_Iterated_Component_Association + and then + Present (Iterator_Specification (First (Component_Associations (N)))) then Two_Pass_Aggregate_Expansion (N); return; @@ -7389,7 +7400,7 @@ package body Exp_Aggr is elsif Nkind (Comp) = N_Iterated_Element_Association then return -1; - -- TBD : Create code for a loop and add to generated code, + -- ??? Need to create code for a loop and add to generated code, -- as is done for array aggregates with iterated element -- associations, instead of using Append operations.