[multiple changes]
2011-08-29 Hristian Kirtchev <kirtchev@adacore.com> * exp_util.adb (Process_Statements_For_Controlled_Objects): Whenever a statement list is wrapped in a block, the block is explicitly analyzed in order to properly redecorate the entities and create a servicing finalizer. 2011-08-29 Tristan Gingold <gingold@adacore.com> * sinfo.ads, sinfo.adb (Zero_Cost_Handling): Remove. (Set_Zero_Cost_Handling): Remove. 2011-08-29 Thomas Quinot <quinot@adacore.com> * par_sco.adb, scos.ads, put_scos.adb, get_scos.adb: Minor reformatting From-SVN: r178162
This commit is contained in:
parent
1197ddb11e
commit
25b589cbd5
@ -1,3 +1,19 @@
|
|||||||
|
2011-08-29 Hristian Kirtchev <kirtchev@adacore.com>
|
||||||
|
|
||||||
|
* exp_util.adb (Process_Statements_For_Controlled_Objects): Whenever a
|
||||||
|
statement list is wrapped in a block, the block is explicitly analyzed
|
||||||
|
in order to properly redecorate the entities and create a servicing
|
||||||
|
finalizer.
|
||||||
|
|
||||||
|
2011-08-29 Tristan Gingold <gingold@adacore.com>
|
||||||
|
|
||||||
|
* sinfo.ads, sinfo.adb (Zero_Cost_Handling): Remove.
|
||||||
|
(Set_Zero_Cost_Handling): Remove.
|
||||||
|
|
||||||
|
2011-08-29 Thomas Quinot <quinot@adacore.com>
|
||||||
|
|
||||||
|
* par_sco.adb, scos.ads, put_scos.adb, get_scos.adb: Minor reformatting
|
||||||
|
|
||||||
2011-08-29 Geert Bosch <bosch@adacore.com>
|
2011-08-29 Geert Bosch <bosch@adacore.com>
|
||||||
|
|
||||||
* s-vaflop-vms-alpha.adb (Neg_F): Use subtraction instead of negation
|
* s-vaflop-vms-alpha.adb (Neg_F): Use subtraction instead of negation
|
||||||
|
@ -5483,9 +5483,17 @@ package body Exp_Util is
|
|||||||
Statements => L));
|
Statements => L));
|
||||||
end Wrap_Statements_In_Block;
|
end Wrap_Statements_In_Block;
|
||||||
|
|
||||||
|
-- Local variables
|
||||||
|
|
||||||
|
Block : Node_Id;
|
||||||
|
|
||||||
-- Start of processing for Process_Statements_For_Controlled_Objects
|
-- Start of processing for Process_Statements_For_Controlled_Objects
|
||||||
|
|
||||||
begin
|
begin
|
||||||
|
-- Whenever a non-handled statement list is wrapped in a block, the
|
||||||
|
-- block must be explicitly analyzed to redecorate all entities in the
|
||||||
|
-- list and ensure that a finalizer is properly built.
|
||||||
|
|
||||||
case Nkind (N) is
|
case Nkind (N) is
|
||||||
when N_Elsif_Part |
|
when N_Elsif_Part |
|
||||||
N_If_Statement |
|
N_If_Statement |
|
||||||
@ -5500,8 +5508,10 @@ package body Exp_Util is
|
|||||||
and then Requires_Cleanup_Actions
|
and then Requires_Cleanup_Actions
|
||||||
(Then_Statements (N), False, False)
|
(Then_Statements (N), False, False)
|
||||||
then
|
then
|
||||||
Set_Then_Statements (N, New_List (
|
Block := Wrap_Statements_In_Block (Then_Statements (N));
|
||||||
Wrap_Statements_In_Block (Then_Statements (N))));
|
Set_Then_Statements (N, New_List (Block));
|
||||||
|
|
||||||
|
Analyze (Block);
|
||||||
end if;
|
end if;
|
||||||
|
|
||||||
-- Check the "else statements" for conditional entry calls, if
|
-- Check the "else statements" for conditional entry calls, if
|
||||||
@ -5515,8 +5525,10 @@ package body Exp_Util is
|
|||||||
and then Requires_Cleanup_Actions
|
and then Requires_Cleanup_Actions
|
||||||
(Else_Statements (N), False, False)
|
(Else_Statements (N), False, False)
|
||||||
then
|
then
|
||||||
Set_Else_Statements (N, New_List (
|
Block := Wrap_Statements_In_Block (Else_Statements (N));
|
||||||
Wrap_Statements_In_Block (Else_Statements (N))));
|
Set_Else_Statements (N, New_List (Block));
|
||||||
|
|
||||||
|
Analyze (Block);
|
||||||
end if;
|
end if;
|
||||||
|
|
||||||
when N_Abortable_Part |
|
when N_Abortable_Part |
|
||||||
@ -5532,8 +5544,10 @@ package body Exp_Util is
|
|||||||
and then not Are_Wrapped (Statements (N))
|
and then not Are_Wrapped (Statements (N))
|
||||||
and then Requires_Cleanup_Actions (Statements (N), False, False)
|
and then Requires_Cleanup_Actions (Statements (N), False, False)
|
||||||
then
|
then
|
||||||
Set_Statements (N, New_List (
|
Block := Wrap_Statements_In_Block (Statements (N));
|
||||||
Wrap_Statements_In_Block (Statements (N))));
|
Set_Statements (N, New_List (Block));
|
||||||
|
|
||||||
|
Analyze (Block);
|
||||||
end if;
|
end if;
|
||||||
|
|
||||||
when others =>
|
when others =>
|
||||||
|
@ -307,7 +307,7 @@ begin
|
|||||||
|
|
||||||
-- Decision entry
|
-- Decision entry
|
||||||
|
|
||||||
when 'I' | 'E' | 'G' | 'P' | 'W' | 'X' =>
|
when 'E' | 'G' | 'I' | 'P' | 'W' | 'X' =>
|
||||||
Dtyp := C;
|
Dtyp := C;
|
||||||
Skip_Spaces;
|
Skip_Spaces;
|
||||||
|
|
||||||
|
@ -1423,7 +1423,7 @@ package body Par_SCO is
|
|||||||
-- Output for disabled pragmas is suppressed later
|
-- Output for disabled pragmas is suppressed later
|
||||||
-- on, when we output the decision line in
|
-- on, when we output the decision line in
|
||||||
-- Put_SCOs, depending on marker sets by
|
-- Put_SCOs, depending on marker sets by
|
||||||
-- Set_SCO_Pragma_Disabled.
|
-- Set_SCO_Pragma_Enabled.
|
||||||
|
|
||||||
if Nam = Name_Check then
|
if Nam = Name_Check then
|
||||||
Next (Arg);
|
Next (Arg);
|
||||||
|
@ -156,7 +156,7 @@ begin
|
|||||||
|
|
||||||
-- Decision
|
-- Decision
|
||||||
|
|
||||||
when 'I' | 'E' | 'G' | 'P' | 'W' | 'X' =>
|
when 'E' | 'G' | 'I' | 'P' | 'W' | 'X' =>
|
||||||
Start := Start + 1;
|
Start := Start + 1;
|
||||||
|
|
||||||
-- For disabled pragma, or nested decision therein, skip
|
-- For disabled pragma, or nested decision therein, skip
|
||||||
|
@ -152,7 +152,6 @@ package SCOs is
|
|||||||
-- E EXIT statement
|
-- E EXIT statement
|
||||||
-- F FOR loop statement (from FOR through end of iteration scheme)
|
-- F FOR loop statement (from FOR through end of iteration scheme)
|
||||||
-- I IF statement (from IF through end of condition)
|
-- I IF statement (from IF through end of condition)
|
||||||
-- p disabled PRAGMA
|
|
||||||
-- P PRAGMA
|
-- P PRAGMA
|
||||||
-- R extended RETURN statement
|
-- R extended RETURN statement
|
||||||
-- W WHILE loop statement (from WHILE through end of condition)
|
-- W WHILE loop statement (from WHILE through end of condition)
|
||||||
@ -227,15 +226,15 @@ package SCOs is
|
|||||||
|
|
||||||
-- Here * is one of the following characters:
|
-- Here * is one of the following characters:
|
||||||
|
|
||||||
-- I decision in IF statement or conditional expression
|
|
||||||
-- E decision in EXIT WHEN statement
|
-- E decision in EXIT WHEN statement
|
||||||
-- G decision in entry guard
|
-- G decision in entry guard
|
||||||
|
-- I decision in IF statement or conditional expression
|
||||||
-- P decision in pragma Assert/Check/Pre_Condition/Post_Condition
|
-- P decision in pragma Assert/Check/Pre_Condition/Post_Condition
|
||||||
-- W decision in WHILE iteration scheme
|
-- W decision in WHILE iteration scheme
|
||||||
-- X decision appearing in some other expression context
|
-- X decision appearing in some other expression context
|
||||||
|
|
||||||
-- For I, E, G, P, W, sloc is the source location of the IF, EXIT,
|
-- For E, G, I, P, W, sloc is the source location of the EXIT, ENTRY, IF,
|
||||||
-- ENTRY, PRAGMA or WHILE token, respectively
|
-- PRAGMA or WHILE token, respectively
|
||||||
|
|
||||||
-- For X, sloc is omitted
|
-- For X, sloc is omitted
|
||||||
|
|
||||||
@ -388,10 +387,16 @@ package SCOs is
|
|||||||
-- statements on a single CS line (possibly followed by Cs continuation
|
-- statements on a single CS line (possibly followed by Cs continuation
|
||||||
-- lines).
|
-- lines).
|
||||||
|
|
||||||
-- Decision (IF/EXIT/WHILE)
|
-- Note: for a pragma that may be disabled (Debug, Assert, PPC, Check),
|
||||||
-- C1 = 'I'/'E'/'W' (for IF/EXIT/WHILE)
|
-- the entry is initially created with C2 = 'p', to mark it as disabled.
|
||||||
|
-- Later on during semantic analysis, if the pragma is enabled,
|
||||||
|
-- Set_SCO_Pragma_Enabled changes C2 to 'P' to cause the entry to be
|
||||||
|
-- emitted in Put_SCOs.
|
||||||
|
|
||||||
|
-- Decision (EXIT/entry guard/IF/WHILE)
|
||||||
|
-- C1 = 'E'/'G'/'I'/'W' (for EXIT/entry Guard/IF/WHILE)
|
||||||
-- C2 = ' '
|
-- C2 = ' '
|
||||||
-- From = IF/EXIT/WHILE token
|
-- From = EXIT/ENTRY/IF/WHILE token
|
||||||
-- To = No_Source_Location
|
-- To = No_Source_Location
|
||||||
-- Last = unused
|
-- Last = unused
|
||||||
|
|
||||||
@ -402,14 +407,12 @@ package SCOs is
|
|||||||
-- To = No_Source_Location
|
-- To = No_Source_Location
|
||||||
-- Last = unused
|
-- Last = unused
|
||||||
|
|
||||||
-- Note: when the parse tree is first scanned, we unconditionally build
|
-- Note: when the parse tree is first scanned, we unconditionally build a
|
||||||
-- a pragma decision entry for any decision in a pragma (here as always
|
-- pragma decision entry for any decision in a pragma (here as always in
|
||||||
-- in SCO contexts, the only pragmas with decisions are Assert, Check,
|
-- SCO contexts, the only pragmas with decisions are Assert, Check,
|
||||||
-- dyadic Debug, Precondition and Postcondition).
|
-- dyadic Debug, Precondition and Postcondition). These entries will
|
||||||
--
|
-- be omitted in output if the pragma is disabled (see comments for
|
||||||
-- During analysis, if the pragma is enabled, Set_SCO_Pragma_Enabled
|
-- statement entries).
|
||||||
-- marks the statement SCO table entry as enaabled (C1 changed from 'p'
|
|
||||||
-- to 'P') to cause the entry to be emitted in Put_SCOs.
|
|
||||||
|
|
||||||
-- Decision (Expression)
|
-- Decision (Expression)
|
||||||
-- C1 = 'X'
|
-- C1 = 'X'
|
||||||
|
@ -3103,15 +3103,6 @@ package body Sinfo is
|
|||||||
return Node1 (N);
|
return Node1 (N);
|
||||||
end Withed_Body;
|
end Withed_Body;
|
||||||
|
|
||||||
function Zero_Cost_Handling
|
|
||||||
(N : Node_Id) return Boolean is
|
|
||||||
begin
|
|
||||||
pragma Assert (False
|
|
||||||
or else NT (N).Nkind = N_Exception_Handler
|
|
||||||
or else NT (N).Nkind = N_Handled_Sequence_Of_Statements);
|
|
||||||
return Flag5 (N);
|
|
||||||
end Zero_Cost_Handling;
|
|
||||||
|
|
||||||
--------------------------
|
--------------------------
|
||||||
-- Field Set Procedures --
|
-- Field Set Procedures --
|
||||||
--------------------------
|
--------------------------
|
||||||
@ -6153,15 +6144,6 @@ package body Sinfo is
|
|||||||
Set_Node1 (N, Val);
|
Set_Node1 (N, Val);
|
||||||
end Set_Withed_Body;
|
end Set_Withed_Body;
|
||||||
|
|
||||||
procedure Set_Zero_Cost_Handling
|
|
||||||
(N : Node_Id; Val : Boolean := True) is
|
|
||||||
begin
|
|
||||||
pragma Assert (False
|
|
||||||
or else NT (N).Nkind = N_Exception_Handler
|
|
||||||
or else NT (N).Nkind = N_Handled_Sequence_Of_Statements);
|
|
||||||
Set_Flag5 (N, Val);
|
|
||||||
end Set_Zero_Cost_Handling;
|
|
||||||
|
|
||||||
-------------------------
|
-------------------------
|
||||||
-- Iterator Procedures --
|
-- Iterator Procedures --
|
||||||
-------------------------
|
-------------------------
|
||||||
|
@ -1806,14 +1806,6 @@ package Sinfo is
|
|||||||
-- library unit of the with_clause and as a result loads its body.
|
-- library unit of the with_clause and as a result loads its body.
|
||||||
-- Used for a more precise unit traversal for CodePeer.
|
-- Used for a more precise unit traversal for CodePeer.
|
||||||
|
|
||||||
-- Zero_Cost_Handling (Flag5-Sem)
|
|
||||||
-- This flag is set in all handled sequence of statement and exception
|
|
||||||
-- handler nodes if exceptions are to be handled using the zero-cost
|
|
||||||
-- mechanism (see Ada.Exceptions and System.Exceptions in files
|
|
||||||
-- a-except.ads/adb and s-except.ads for full details). What gigi needs
|
|
||||||
-- to do for such a handler is simply to put the code in the handler
|
|
||||||
-- somewhere. The front end has generated all necessary labels.
|
|
||||||
|
|
||||||
--------------------------------------------------
|
--------------------------------------------------
|
||||||
-- Note on Use of End_Label and End_Span Fields --
|
-- Note on Use of End_Label and End_Span Fields --
|
||||||
--------------------------------------------------
|
--------------------------------------------------
|
||||||
@ -5957,7 +5949,6 @@ package Sinfo is
|
|||||||
-- Exception_Handlers (List5) (set to No_List if none present)
|
-- Exception_Handlers (List5) (set to No_List if none present)
|
||||||
-- At_End_Proc (Node1) (set to Empty if no clean up procedure)
|
-- At_End_Proc (Node1) (set to Empty if no clean up procedure)
|
||||||
-- First_Real_Statement (Node2-Sem)
|
-- First_Real_Statement (Node2-Sem)
|
||||||
-- Zero_Cost_Handling (Flag5-Sem)
|
|
||||||
|
|
||||||
-- Note: the parent always contains a Declarations field which contains
|
-- Note: the parent always contains a Declarations field which contains
|
||||||
-- declarations associated with the handled sequence of statements. This
|
-- declarations associated with the handled sequence of statements. This
|
||||||
@ -5983,7 +5974,6 @@ package Sinfo is
|
|||||||
-- Exception_Choices (List4)
|
-- Exception_Choices (List4)
|
||||||
-- Statements (List3)
|
-- Statements (List3)
|
||||||
-- Exception_Label (Node5-Sem) (set to Empty of not present)
|
-- Exception_Label (Node5-Sem) (set to Empty of not present)
|
||||||
-- Zero_Cost_Handling (Flag5-Sem)
|
|
||||||
-- Local_Raise_Statements (Elist1-Sem) (set to No_Elist if not present)
|
-- Local_Raise_Statements (Elist1-Sem) (set to No_Elist if not present)
|
||||||
-- Local_Raise_Not_OK (Flag7-Sem)
|
-- Local_Raise_Not_OK (Flag7-Sem)
|
||||||
-- Has_Local_Raise (Flag8-Sem)
|
-- Has_Local_Raise (Flag8-Sem)
|
||||||
@ -9001,9 +8991,6 @@ package Sinfo is
|
|||||||
function Withed_Body
|
function Withed_Body
|
||||||
(N : Node_Id) return Node_Id; -- Node1
|
(N : Node_Id) return Node_Id; -- Node1
|
||||||
|
|
||||||
function Zero_Cost_Handling
|
|
||||||
(N : Node_Id) return Boolean; -- Flag5
|
|
||||||
|
|
||||||
-- End functions (note used by xsinfo utility program to end processing)
|
-- End functions (note used by xsinfo utility program to end processing)
|
||||||
|
|
||||||
----------------------------
|
----------------------------
|
||||||
@ -9973,9 +9960,6 @@ package Sinfo is
|
|||||||
procedure Set_Withed_Body
|
procedure Set_Withed_Body
|
||||||
(N : Node_Id; Val : Node_Id); -- Node1
|
(N : Node_Id; Val : Node_Id); -- Node1
|
||||||
|
|
||||||
procedure Set_Zero_Cost_Handling
|
|
||||||
(N : Node_Id; Val : Boolean := True); -- Flag5
|
|
||||||
|
|
||||||
-------------------------
|
-------------------------
|
||||||
-- Iterator Procedures --
|
-- Iterator Procedures --
|
||||||
-------------------------
|
-------------------------
|
||||||
@ -12037,7 +12021,6 @@ package Sinfo is
|
|||||||
pragma Inline (Used_Operations);
|
pragma Inline (Used_Operations);
|
||||||
pragma Inline (Was_Originally_Stub);
|
pragma Inline (Was_Originally_Stub);
|
||||||
pragma Inline (Withed_Body);
|
pragma Inline (Withed_Body);
|
||||||
pragma Inline (Zero_Cost_Handling);
|
|
||||||
|
|
||||||
pragma Inline (Set_ABE_Is_Certain);
|
pragma Inline (Set_ABE_Is_Certain);
|
||||||
pragma Inline (Set_Abort_Present);
|
pragma Inline (Set_Abort_Present);
|
||||||
@ -12357,7 +12340,6 @@ package Sinfo is
|
|||||||
pragma Inline (Set_Used_Operations);
|
pragma Inline (Set_Used_Operations);
|
||||||
pragma Inline (Set_Was_Originally_Stub);
|
pragma Inline (Set_Was_Originally_Stub);
|
||||||
pragma Inline (Set_Withed_Body);
|
pragma Inline (Set_Withed_Body);
|
||||||
pragma Inline (Set_Zero_Cost_Handling);
|
|
||||||
|
|
||||||
--------------
|
--------------
|
||||||
-- Synonyms --
|
-- Synonyms --
|
||||||
|
Loading…
Reference in New Issue
Block a user