+2014-08-04 Yannick Moy <moy@adacore.com>
+
+ * sem.adb, sem.ads (In_Default_Expr): Global flag that is set
+ to True during analysis of a default component expression.
+ (Semantics): Save and restore In_Default_Expr around analysis.
+ * sem_ch3.adb, sem_ch3.ads (Analyze_Component_Declaration):
+ Call new wrapper Preanalyze_Default_Expression.
+ (Preanalyze_Default_Expression): New wrapper on
+ Preanalyze_Spec_Expression which sets and restores In_Default_Expr.
+ * sem_res.adb (Resolve_Call): Mark calls inside default
+ expressions as not inlined in GNATprove mode.
+
2014-08-04 Robert Dewar <dewar@adacore.com>
* exp_ch4.adb: Minor reformatting.
S_GNAT_Mode : constant Boolean := GNAT_Mode;
S_Global_Dis_Names : constant Boolean := Global_Discard_Names;
S_In_Assertion_Expr : constant Nat := In_Assertion_Expr;
+ S_In_Default_Expr : constant Boolean := In_Default_Expr;
S_In_Spec_Expr : constant Boolean := In_Spec_Expression;
S_Inside_A_Generic : constant Boolean := Inside_A_Generic;
S_Outer_Gen_Scope : constant Entity_Id := Outer_Generic_Scope;
Full_Analysis := True;
Inside_A_Generic := False;
In_Assertion_Expr := 0;
+ In_Default_Expr := False;
In_Spec_Expression := False;
Set_Comes_From_Source_Default (False);
Global_Discard_Names := S_Global_Dis_Names;
GNAT_Mode := S_GNAT_Mode;
In_Assertion_Expr := S_In_Assertion_Expr;
+ In_Default_Expr := S_In_Default_Expr;
In_Spec_Expression := S_In_Spec_Expr;
Inside_A_Generic := S_Inside_A_Generic;
Outer_Generic_Scope := S_Outer_Gen_Scope;
In_Assertion_Expr : Nat := 0;
-- This is set non-zero if we are within the expression of an assertion
- -- pragma or aspect. It is a counter which is incremented at the start
- -- of expanding such an expression, and decremented on completion of
- -- expanding that expression. Probably a boolean would be good enough,
- -- since we think that such expressions cannot nest, but that might not
- -- be true in the future (e.g. if let expressions are added to Ada) so
- -- we prepare for that future possibility by making it a counter.
+ -- pragma or aspect. It is a counter which is incremented at the start of
+ -- expanding such an expression, and decremented on completion of expanding
+ -- that expression. Probably a boolean would be good enough, since we think
+ -- that such expressions cannot nest, but that might not be true in the
+ -- future (e.g. if let expressions are added to Ada) so we prepare for that
+ -- future possibility by making it a counter. Like In_Spec_Expression, it
+ -- must be recursively saved on a Semantics call.
+
+ In_Default_Expr : Boolean := False;
+ -- Switch to indicate that we are analyzing a default component expression.
+ -- Like In_Spec_Expression, it must be recursively saved on a Semantics
+ -- call.
In_Inlined_Body : Boolean := False;
-- Switch to indicate that we are analyzing and resolving an inlined body.
if Present (E) then
Check_SPARK_Restriction ("default expression is not allowed", E);
- Preanalyze_Spec_Expression (E, T);
+ Preanalyze_Default_Expression (E, T);
Check_Initialization (T, E);
if Ada_Version >= Ada_2005
In_Assertion_Expr := In_Assertion_Expr - 1;
end Preanalyze_Assert_Expression;
+ -----------------------------------
+ -- Preanalyze_Default_Expression --
+ -----------------------------------
+
+ procedure Preanalyze_Default_Expression (N : Node_Id; T : Entity_Id) is
+ Save_In_Default_Expr : constant Boolean := In_Default_Expr;
+ begin
+ In_Default_Expr := True;
+ Preanalyze_Spec_Expression (N, T);
+ In_Default_Expr := Save_In_Default_Expr;
+ end Preanalyze_Default_Expression;
+
--------------------------------
-- Preanalyze_Spec_Expression --
--------------------------------
-- Wrapper on Preanalyze_Spec_Expression for assertion expressions, so that
-- In_Assertion_Expr can be properly adjusted.
+ procedure Preanalyze_Default_Expression (N : Node_Id; T : Entity_Id);
+ -- Wrapper on Preanalyze_Spec_Expression for default expressions, so that
+ -- In_Default_Expr can be properly adjusted.
+
procedure Process_Full_View (N : Node_Id; Full_T, Priv_T : Entity_Id);
-- Process some semantic actions when the full view of a private type is
-- encountered and analyzed. The first action is to create the full views
Error_Msg_N ("\call appears in assertion expression", N);
Set_Is_Inlined_Always (Nam_UA, False);
+ -- Calls cannot be inlined inside default expressions
+
+ elsif In_Default_Expr then
+ Error_Msg_NE ("?no contextual analysis of &", N, Nam);
+ Error_Msg_N ("\call appears in default expression", N);
+ Set_Is_Inlined_Always (Nam_UA, False);
+
-- Inlining should not be performed during pre-analysis
elsif Full_Analysis then