diff options
author | Hristian Kirtchev <kirtchev@adacore.com> | 2018-07-17 08:07:37 +0000 |
---|---|---|
committer | Pierre-Marie de Rodat <pmderodat@gcc.gnu.org> | 2018-07-17 08:07:37 +0000 |
commit | e6bc029a34598dd3af5c6a0aacd66ee62235cdfe (patch) | |
tree | 419525e839b5e749c0c7066c2f022a0daa290b8f /gcc/builtins.c | |
parent | 014eddc6d9cec9d0fd526b1e2d3d9cb4f0674f63 (diff) | |
download | gcc-e6bc029a34598dd3af5c6a0aacd66ee62235cdfe.zip gcc-e6bc029a34598dd3af5c6a0aacd66ee62235cdfe.tar.gz gcc-e6bc029a34598dd3af5c6a0aacd66ee62235cdfe.tar.bz2 |
[Ada] Spurious error on Part_Of indicator
This patch modifies the verification of a missing Part_Of indicator to avoid
considering constants as visible state of a package instantiation because the
compiler cannot determine whether their values depend on variable input. This
diagnostic is left to GNATprove.
------------
-- Source --
------------
-- gnat.adc
pragma SPARK_Mode;
-- gen_pack.ads
generic
package Gen_Pack is
Val : constant Integer := 123;
end Gen_Pack;
-- pack.ads
with Gen_Pack;
package Pack
with Abstract_State => Pack_State
is
procedure Force_Body;
private
package Inst_1 is new Gen_Pack; -- OK
package Inst_2 is new Gen_Pack with Part_Of => Pack_State; -- OK
end Pack;
-- pack.adb
package body Pack
with Refined_State => (Pack_State => Inst_2.Val)
is
procedure Force_Body is null;
end Pack;
-----------------
-- Compilation --
-----------------
$ gcc -c pack.adb
2018-07-17 Hristian Kirtchev <kirtchev@adacore.com>
gcc/ada/
* sem_prag.adb (Has_Visible_State): Do not consider constants as
visible state because it is not possible to determine whether a
constant depends on variable input.
(Propagate_Part_Of): Add comment clarifying the behavior with respect
to constant.
From-SVN: r262782
Diffstat (limited to 'gcc/builtins.c')
0 files changed, 0 insertions, 0 deletions