diff options
author | Eric Botcazou <ebotcazou@adacore.com> | 2023-04-04 19:25:11 +0200 |
---|---|---|
committer | Marc Poulhiès <poulhies@adacore.com> | 2023-05-29 10:23:21 +0200 |
commit | bbe40e766bf58158427f4c212655c376768b1c75 (patch) | |
tree | faf48cd5316e300a8d390bbb2fdc3e01915941e6 | |
parent | 6fe8909606f79db1fb2107336544b058eaeb6381 (diff) | |
download | gcc-bbe40e766bf58158427f4c212655c376768b1c75.zip gcc-bbe40e766bf58158427f4c212655c376768b1c75.tar.gz gcc-bbe40e766bf58158427f4c212655c376768b1c75.tar.bz2 |
ada: Fix internal error with pragma Compile_Time_{Warning,Error}
This happens when the pragmas are deferred to the back-end from an external
unit to the main unit that is generic, because the back-end does not compile
a main unit that is generic.
gcc/ada/
* sem_prag.adb (Process_Compile_Time_Warning_Or_Error): Do not defer
anything to the back-end when the main unit is generic.
-rw-r--r-- | gcc/ada/sem_prag.adb | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/gcc/ada/sem_prag.adb b/gcc/ada/sem_prag.adb index b74c60c..0d62b04 100644 --- a/gcc/ada/sem_prag.adb +++ b/gcc/ada/sem_prag.adb @@ -8137,7 +8137,9 @@ package body Sem_Prag is -- then. For example, if the expression is "Record_Type'Size /= 32" -- it might be known after the back end has determined the size of -- Record_Type. We do not defer validation if we're inside a generic - -- unit, because we will have more information in the instances. + -- unit, because we will have more information in the instances, and + -- this ultimately applies to the main unit itself, because it is not + -- compiled by the back end when it is generic. if Compile_Time_Known_Value (Arg1x) then Validate_Compile_Time_Warning_Or_Error (N, Sloc (Arg1)); @@ -8155,7 +8157,10 @@ package body Sem_Prag is end if; end loop; - if No (P) then + if No (P) + and then + Nkind (Unit (Cunit (Main_Unit))) not in N_Generic_Declaration + then Defer_Compile_Time_Warning_Error_To_BE (N); end if; end if; |