aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPierre-Marie de Rodat <pmderodat@gcc.gnu.org>2017-09-25 09:34:10 +0000
committerPierre-Marie de Rodat <pmderodat@gcc.gnu.org>2017-09-25 09:34:10 +0000
commitd449ed7517e34dc3b24c60f2d374a94f46b220d5 (patch)
tree71a9345678d16e2df3d29e1ea1f07d3faef73557
parentf71b4cd44483310677019f5d47cabbdeedfcfc75 (diff)
downloadgcc-d449ed7517e34dc3b24c60f2d374a94f46b220d5.zip
gcc-d449ed7517e34dc3b24c60f2d374a94f46b220d5.tar.gz
gcc-d449ed7517e34dc3b24c60f2d374a94f46b220d5.tar.bz2
[multiple changes]
2017-09-25 Piotr Trojanek <trojanek@adacore.com> * adabkend.adb (Call_Back_End): Fix wording of "front-end" and "back-end" in comments. 2017-09-25 Ed Schonberg <schonberg@adacore.com> * exp_ch6.adb (Expand_Call_Helper): The extra accessibility check in a call that appears in a classwide precondition and that mentions an access formal of the subprogram, must use the accessibility level of the actual in the call. This is one case in which a reference to a formal parameter appears outside of the body of the subprogram. From-SVN: r253141
-rw-r--r--gcc/ada/ChangeLog13
-rw-r--r--gcc/ada/adabkend.adb12
-rw-r--r--gcc/ada/exp_ch6.adb14
3 files changed, 33 insertions, 6 deletions
diff --git a/gcc/ada/ChangeLog b/gcc/ada/ChangeLog
index 3780b1d..979748e 100644
--- a/gcc/ada/ChangeLog
+++ b/gcc/ada/ChangeLog
@@ -1,3 +1,16 @@
+2017-09-25 Piotr Trojanek <trojanek@adacore.com>
+
+ * adabkend.adb (Call_Back_End): Fix wording of "front-end" and
+ "back-end" in comments.
+
+2017-09-25 Ed Schonberg <schonberg@adacore.com>
+
+ * exp_ch6.adb (Expand_Call_Helper): The extra accessibility check in a
+ call that appears in a classwide precondition and that mentions an
+ access formal of the subprogram, must use the accessibility level of
+ the actual in the call. This is one case in which a reference to a
+ formal parameter appears outside of the body of the subprogram.
+
2017-09-25 Hristian Kirtchev <kirtchev@adacore.com>
* sem_res.adb (Replace_Actual_Discriminants): Replace a discriminant
diff --git a/gcc/ada/adabkend.adb b/gcc/ada/adabkend.adb
index 3c84a48..2ab4b19 100644
--- a/gcc/ada/adabkend.adb
+++ b/gcc/ada/adabkend.adb
@@ -57,10 +57,10 @@ package body Adabkend is
Write_Eol;
end if;
- -- Frontend leaves the Current_Error_Node at a location that is
- -- meaningless and confusing when emitting bugboxes from the backed. By
- -- resetting it here we default to "No source file position information
- -- available" message on backend crashes.
+ -- The front end leaves the Current_Error_Node at a location that is
+ -- meaningless and confusing when emitting bug boxes from the back end.
+ -- By resetting it here we default to "No source file position
+ -- information available" message on back end crashes.
Current_Error_Node := Empty;
@@ -91,7 +91,7 @@ package body Adabkend is
--
-- If the switch is not valid, control will not return. The switches
-- must still be scanned to skip the "-o" arguments, or internal GCC
- -- switches, which may be safely ignored by other back-ends.
+ -- switches, which may be safely ignored by other back ends.
----------------------------
-- Scan_Back_End_Switches --
@@ -251,7 +251,7 @@ package body Adabkend is
else
Add_Src_Search_Dir (Argv);
- -- Add directory to lib search so that back-end can take as
+ -- Add directory to lib search so that back end can take as
-- input ALI files if needed. Otherwise this won't have any
-- impact on the compiler.
diff --git a/gcc/ada/exp_ch6.adb b/gcc/ada/exp_ch6.adb
index c2edde6..2ee1c78 100644
--- a/gcc/ada/exp_ch6.adb
+++ b/gcc/ada/exp_ch6.adb
@@ -3004,6 +3004,20 @@ package body Exp_Ch6 is
then
Prev_Orig := Prev;
+ -- A class-wide precondition generates a test in which formals of
+ -- the subprogram are replaced by actuals that came from source.
+ -- In that case as well, the accessiblity comes from the actual.
+ -- This is the one case in which there are references to formals
+ -- outside of their subprogram.
+
+ elsif Prev_Orig /= Prev
+ and then Is_Entity_Name (Prev_Orig)
+ and then Present (Entity (Prev_Orig))
+ and then Is_Formal (Entity (Prev_Orig))
+ and then not In_Open_Scopes (Scope (Entity (Prev_Orig)))
+ then
+ Prev_Orig := Prev;
+
-- If the actual is a formal of an enclosing subprogram it is
-- the right entity, even if it is a rewriting. This happens
-- when the call is within an inherited condition or predicate.