From: Piotr Trojanek Date: Mon, 6 Feb 2023 13:45:22 +0000 (+0100) Subject: ada: Add warning on frontend inlining of Subprogram_Variant X-Git-Tag: basepoints/gcc-15~9087 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=f2cffc11f85691e26f80b76065411ec0a27f2a49;p=thirdparty%2Fgcc.git ada: Add warning on frontend inlining of Subprogram_Variant We already warned when contracts like pre/postcondition appear together with pragma Inline_Always and they are ignored by the frontend inlining. For consistency we now also warn for Subprogram_Variant, which is similarly ignored even though this contract is only meaningful for recursive subprograms and those can't be inlined anyway (but error about this might only be emitted when full compilation is done). gcc/ada/ * sem_prag.adb (Check_Postcondition_Use_In_Inlined_Subprogram): Mention Subprogram_Variant in the comment. (Analyze_Subprogram_Variant_In_Decl_Part): Warn when contract is ignored because of pragma Inline_Always and frontend inlining. --- diff --git a/gcc/ada/sem_prag.adb b/gcc/ada/sem_prag.adb index dbc8584e2117..feaf486c3485 100644 --- a/gcc/ada/sem_prag.adb +++ b/gcc/ada/sem_prag.adb @@ -208,9 +208,10 @@ package body Sem_Prag is (Prag : Node_Id; Spec_Id : Entity_Id); -- Subsidiary to the analysis of pragmas Contract_Cases, Postcondition, - -- Precondition, Refined_Post, and Test_Case. Emit a warning when pragma - -- Prag is associated with subprogram Spec_Id subject to Inline_Always, - -- assertions are enabled and inling is done in the frontend. + -- Precondition, Refined_Post, Subprogram_Variant, and Test_Case. Emit a + -- warning when pragma Prag is associated with subprogram Spec_Id subject + -- to Inline_Always, assertions are enabled and inling is done in the + -- frontend. procedure Check_State_And_Constituent_Use (States : Elist_Id; @@ -29627,6 +29628,11 @@ package body Sem_Prag is End_Scope; end if; + -- Currently it is not possible to inline Subprogram_Variant on a + -- subprogram subject to pragma Inline_Always. + + Check_Postcondition_Use_In_Inlined_Subprogram (N, Spec_Id); + -- Otherwise the pragma is illegal else