aboutsummaryrefslogtreecommitdiff
path: root/gcc/ada
diff options
context:
space:
mode:
authorHristian Kirtchev <kirtchev@adacore.com>2018-07-16 14:11:47 +0000
committerPierre-Marie de Rodat <pmderodat@gcc.gnu.org>2018-07-16 14:11:47 +0000
commit93bc357b34765dcc12709962a074c8001677c27b (patch)
tree7e85803412e5bce56a7455172a6369b381871356 /gcc/ada
parent7da8b07f30c465a46e41202d897d74ed2ceb8396 (diff)
downloadgcc-93bc357b34765dcc12709962a074c8001677c27b.zip
gcc-93bc357b34765dcc12709962a074c8001677c27b.tar.gz
gcc-93bc357b34765dcc12709962a074c8001677c27b.tar.bz2
[Ada] Spurious error with null Abstract_State
This patch corrects the mechanism which ensures that a package with a null Abstract_State does not introduce hidden state, by ignoring internal states and variables because they do not represent the "source" hidden state. 2018-07-16 Hristian Kirtchev <kirtchev@adacore.com> gcc/ada/ * sem_util.adb (Check_No_Hidden_State): Ignore internally-generated states and variables. gcc/testsuite/ * gnat.dg/abstract_state1.adb, gnat.dg/abstract_state1.ads: New testcase. From-SVN: r262722
Diffstat (limited to 'gcc/ada')
-rw-r--r--gcc/ada/ChangeLog5
-rw-r--r--gcc/ada/sem_util.adb7
2 files changed, 12 insertions, 0 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index 1a14dae..9644f6f 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,3 +1,8 @@
+2018-07-16 Hristian Kirtchev <kirtchev@adacore.com>
+
+ * sem_util.adb (Check_No_Hidden_State): Ignore internally-generated
+ states and variables.
+
2018-07-16 Piotr Trojanek <trojanek@adacore.com>
* sinfo.ads, sinfo.adb (Withed_Body): Remove.
diff --git a/gcc/ada/sem_util.adb b/gcc/ada/sem_util.adb
index 59687f5..b6b939c 100644
--- a/gcc/ada/sem_util.adb
+++ b/gcc/ada/sem_util.adb
@@ -3228,6 +3228,13 @@ package body Sem_Util is
begin
pragma Assert (Ekind_In (Id, E_Abstract_State, E_Variable));
+ -- Nothing to do for internally-generated abstract states and variables
+ -- because they do not represent the hidden state of the source unit.
+
+ if not Comes_From_Source (Id) then
+ return;
+ end if;
+
-- Find the proper context where the object or state appears
Scop := Scope (Id);