aboutsummaryrefslogtreecommitdiff
path: root/gcc/ada/sinfo.ads
diff options
context:
space:
mode:
authorArnaud Charlet <charlet@gcc.gnu.org>2013-01-04 10:08:50 +0100
committerArnaud Charlet <charlet@gcc.gnu.org>2013-01-04 10:08:50 +0100
commit3a3af4c32cf7d5f4caf79031da89bc6972cdfbd3 (patch)
tree3266b4f490ae72a9e167f1807975fd0e4f1971e9 /gcc/ada/sinfo.ads
parent576f6da6398293734bac71fd55bc7aa07c521dbf (diff)
downloadgcc-3a3af4c32cf7d5f4caf79031da89bc6972cdfbd3.zip
gcc-3a3af4c32cf7d5f4caf79031da89bc6972cdfbd3.tar.gz
gcc-3a3af4c32cf7d5f4caf79031da89bc6972cdfbd3.tar.bz2
[multiple changes]
2013-01-04 Thomas Quinot <quinot@adacore.com> * sinfo.ads: Minor documentation update. 2013-01-04 Thomas Quinot <quinot@adacore.com> * sem_ch3.adb, einfo.adb (Analyze_Object_Declaration): Do not set Ekind before resolving initialization expression. 2013-01-04 Hristian Kirtchev <kirtchev@adacore.com> * checks.adb (Generate_Index_Checks): Delay the generation of the check for an indexed component where the prefix mentions Loop_Entry until the attribute has been properly expanded. * exp_ch5.adb (Expand_Loop_Entry_Attributes): Perform minor decoration of the constant that captures the value of Loop_Entry's prefix at the entry point into a loop. Generate index checks for an attribute reference that has been transformed into an indexed component. 2013-01-04 Thomas Quinot <quinot@adacore.com> * exp_prag.adb, exp_util.adb, exp_util.ads, freeze.adb, exp_aggr.adb, sem_ch13.adb (Exp_Aggr.Collect_Initialization_Statements): Nothing to do if Obj is already frozen. (Exp_Util.Find_Init_Call): Rename to... (Exp_Util.Remove_Init_Call): New subprogram, renamed from Find_Init_Call. Remove the initialization call from the enclosing list if found, and if it is from an Initialization_Statements attribute, reset it. (Exp_Util.Append_Freeze_Action): Minor code reorganization. (Exp_Util.Append_Freeze_Actions): Ensure a freeze node has been allocated (as is already done in Append_Freeze_Action). (Freeze.Freeze_Entity): For an object with captured Initialization_Statements and non-delayed freezeing, unwrap the initialization statements and insert and them directly in the enclosing list. (Sem_Ch13.Check_Address_Clause): For an object with Initialization_Statements and an address clause, unwrap the initialization statements when moving them to the freeze actions. From-SVN: r194887
Diffstat (limited to 'gcc/ada/sinfo.ads')
-rw-r--r--gcc/ada/sinfo.ads20
1 files changed, 9 insertions, 11 deletions
diff --git a/gcc/ada/sinfo.ads b/gcc/ada/sinfo.ads
index d3e7d71..08b09d2 100644
--- a/gcc/ada/sinfo.ads
+++ b/gcc/ada/sinfo.ads
@@ -7020,15 +7020,10 @@ package Sinfo is
-- a subexpression, whose value is the value of the Expression after
-- executing all the actions.
- -- Note: if the actions contain declarations, then these declarations
- -- may be referenced within the expression. It is thus appropriate for
- -- the back-end to create a scope that encompasses the construct (any
- -- declarations within the actions will definitely not be referenced
- -- once elaboration of the construct is completed).
-
- -- But we rely on freeze nodes appearing in actions being elaborated in
- -- the enclosing scope (see Exp_Aggr.Collect_Initialization_
- -- Statements)???
+ -- If the actions contain declarations, then these declarations may
+ -- be referenced within the expression. However note that there is
+ -- no proper scope associated with the expression-with-action, so the
+ -- back-end will elaborate them in the context of the enclosing scope.
-- Sprint syntax: do
-- action;
@@ -7046,7 +7041,10 @@ package Sinfo is
-- never have created this node if there weren't some actions.
-- Note: Expression may be a Null_Statement, in which case the
- -- N_Expression_With_Actions has type Standard_Void_Type.
+ -- N_Expression_With_Actions has type Standard_Void_Type. However some
+ -- backends do not support such expression-with-actions occurring
+ -- outside of a proper (non-void) expression, so this should just be
+ -- used as an intermediate representation within the front-end.
--------------------
-- Free Statement --
@@ -7183,7 +7181,7 @@ package Sinfo is
-- the exception to be raised (i.e. it is equivalent to a raise
-- statement that raises the corresponding exception). This use
-- is distinguished by the fact that the Etype in this case is
- -- Standard_Void_Type, In the subexpression case, the Etype is the
+ -- Standard_Void_Type; in the subexpression case, the Etype is the
-- same as the type of the subexpression which it replaces.
-- If Condition is empty, then the raise is unconditional. If the