aboutsummaryrefslogtreecommitdiff
path: root/gcc/ada/sem_res.adb
diff options
context:
space:
mode:
authorEd Schonberg <schonberg@adacore.com>2022-01-03 15:29:09 +0100
committerPierre-Marie de Rodat <derodat@adacore.com>2022-05-09 09:27:33 +0000
commit5081e9205a6f12c41bdd5a7d630a732120fb4e92 (patch)
treeaf78b3e26dc280ed5b4c6993d9b0135b19bc92d1 /gcc/ada/sem_res.adb
parentf1231d9a0baab25e0a07b0d6146b91e59ecfadb8 (diff)
downloadgcc-5081e9205a6f12c41bdd5a7d630a732120fb4e92.zip
gcc-5081e9205a6f12c41bdd5a7d630a732120fb4e92.tar.gz
gcc-5081e9205a6f12c41bdd5a7d630a732120fb4e92.tar.bz2
[Ada] Fix visibility inside declare_expression
The first implementation just created a scope for the analysis of the declarations and the expression, so that visibility would just work as it does for all other constructs. However this led to an annoying bug when one of the declarations or the expression itself creates a transient scope: there may be a confusion on scope exit between those two scopes. As a result visibility is handled by explicit traversal of the expression and replacement of occurrences of the local variables, see Replace_Local_Ref in Resolve_Declare_Expression (sem_res.adb). The current code does not take into account that there may be references to a local object in a subsequent declaration (not just in the expression). gcc/ada/ * sem_res.adb (Resolve_Declare_Expression): Traverse the expression to replace references to local variables that occur within declarations of the declare_expression; fix typos in comments.
Diffstat (limited to 'gcc/ada/sem_res.adb')
-rw-r--r--gcc/ada/sem_res.adb17
1 files changed, 15 insertions, 2 deletions
diff --git a/gcc/ada/sem_res.adb b/gcc/ada/sem_res.adb
index b918615..f5c8b10 100644
--- a/gcc/ada/sem_res.adb
+++ b/gcc/ada/sem_res.adb
@@ -7595,7 +7595,7 @@ package body Sem_Res is
Local : Entity_Id := Empty;
function Replace_Local (N : Node_Id) return Traverse_Result;
- -- Use a tree traversal to replace each ocurrence of the name of
+ -- Use a tree traversal to replace each occurrence of the name of
-- a local object declared in the construct, with the corresponding
-- entity. This replaces the usual way to perform name capture by
-- visibility, because it is not possible to place on the scope
@@ -7632,7 +7632,7 @@ package body Sem_Res is
procedure Replace_Local_Ref is new Traverse_Proc (Replace_Local);
- -- Start of processing for Resolve_Declare_Expression
+ -- Start of processing for Resolve_Declare_Expression
begin
@@ -7645,6 +7645,19 @@ package body Sem_Res is
then
Local := Defining_Identifier (Decl);
Replace_Local_Ref (Expr);
+
+ -- Traverse the expression to replace references to local
+ -- variables that occur within declarations of the
+ -- declare_expression.
+
+ declare
+ D : Node_Id := Next (Decl);
+ begin
+ while Present (D) loop
+ Replace_Local_Ref (D);
+ Next (D);
+ end loop;
+ end;
end if;
Next (Decl);