1 ------------------------------------------------------------------------------
3 -- GNAT COMPILER COMPONENTS --
9 -- Copyright (C) 1992-2004 Free Software Foundation, Inc. --
11 -- GNAT is free software; you can redistribute it and/or modify it under --
12 -- terms of the GNU General Public License as published by the Free Soft- --
13 -- ware Foundation; either version 2, or (at your option) any later ver- --
14 -- sion. GNAT is distributed in the hope that it will be useful, but WITH- --
15 -- OUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY --
16 -- or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License --
17 -- for more details. You should have received a copy of the GNU General --
18 -- Public License distributed with GNAT; see file COPYING. If not, write --
19 -- to the Free Software Foundation, 51 Franklin Street, Fifth Floor, --
20 -- Boston, MA 02110-1301, USA. --
22 -- GNAT was originally developed by the GNAT team at New York University. --
23 -- Extensive contributions were provided by Ada Core Technologies Inc. --
25 ------------------------------------------------------------------------------
27 with Atree
; use Atree
;
28 with Einfo
; use Einfo
;
29 with Exp_Dbug
; use Exp_Dbug
;
30 with Exp_Util
; use Exp_Util
;
31 with Freeze
; use Freeze
;
32 with Nlists
; use Nlists
;
34 with Sem_Ch8
; use Sem_Ch8
;
35 with Sinfo
; use Sinfo
;
36 with Stand
; use Stand
;
37 with Targparm
; use Targparm
;
39 package body Exp_Ch8
is
41 ---------------------------------------------
42 -- Expand_N_Exception_Renaming_Declaration --
43 ---------------------------------------------
45 procedure Expand_N_Exception_Renaming_Declaration
(N
: Node_Id
) is
46 Decl
: constant Node_Id
:= Debug_Renaming_Declaration
(N
);
49 if Present
(Decl
) then
50 Insert_Action
(N
, Decl
);
52 end Expand_N_Exception_Renaming_Declaration
;
54 ------------------------------------------
55 -- Expand_N_Object_Renaming_Declaration --
56 ------------------------------------------
58 -- Most object renaming cases can be done by just capturing the address
59 -- of the renamed object. The cases in which this is not true are when
60 -- this address is not computable, since it involves extraction of a
61 -- packed array element, or of a record component to which a component
62 -- clause applies (that can specify an arbitrary bit boundary), or where
63 -- the enclosing record itself has a non-standard representation.
65 -- In these two cases, we pre-evaluate the renaming expression, by
66 -- extracting and freezing the values of any subscripts, and then we
67 -- set the flag Is_Renaming_Of_Object which means that any reference
68 -- to the object will be handled by macro substitution in the front
69 -- end, and the back end will know to ignore the renaming declaration.
71 -- An additional odd case that requires processing by expansion is
72 -- the renaming of a discriminant of a mutable record type. The object
73 -- is a constant because it renames something that cannot be assigned to,
74 -- but in fact the underlying value can change and must be reevaluated
75 -- at each reference. Gigi does have a notion of a "constant view" of
76 -- an object, and therefore the front-end must perform the expansion.
77 -- For simplicity, and to bypass some obscure code-generation problem,
78 -- we use macro substitution for all renamed discriminants, whether the
79 -- enclosing type is constrained or not.
81 -- The other special processing required is for the case of renaming
82 -- of an object of a class wide type, where it is necessary to build
83 -- the appropriate subtype for the renamed object.
84 -- More comments needed for this para ???
86 procedure Expand_N_Object_Renaming_Declaration
(N
: Node_Id
) is
87 Nam
: constant Node_Id
:= Name
(N
);
91 procedure Evaluate_Name
(Fname
: Node_Id
);
92 -- A recursive procedure used to freeze a name in the sense described
93 -- above, i.e. any variable references or function calls are removed.
94 -- Of course the outer level variable reference must not be removed.
95 -- For example in A(J,F(K)), A is left as is, but J and F(K) are
96 -- evaluated and removed.
98 function Evaluation_Required
(Nam
: Node_Id
) return Boolean;
99 -- Determines whether it is necessary to do static name evaluation
100 -- for renaming of Nam. It is considered necessary if evaluating the
101 -- name involves indexing a packed array, or extracting a component
102 -- of a record to which a component clause applies. Note that we are
103 -- only interested in these operations if they occur as part of the
104 -- name itself, subscripts are just values that are computed as part
105 -- of the evaluation, so their form is unimportant.
111 procedure Evaluate_Name
(Fname
: Node_Id
) is
112 K
: constant Node_Kind
:= Nkind
(Fname
);
116 -- For an explicit dereference, we simply force the evaluation
117 -- of the name expression. The dereference provides a value that
118 -- is the address for the renamed object, and it is precisely
119 -- this value that we want to preserve.
121 if K
= N_Explicit_Dereference
then
122 Force_Evaluation
(Prefix
(Fname
));
124 -- For a selected component, we simply evaluate the prefix
126 elsif K
= N_Selected_Component
then
127 Evaluate_Name
(Prefix
(Fname
));
129 -- For an indexed component, or an attribute reference, we evaluate
130 -- the prefix, which is itself a name, recursively, and then force
131 -- the evaluation of all the subscripts (or attribute expressions).
133 elsif K
= N_Indexed_Component
134 or else K
= N_Attribute_Reference
136 Evaluate_Name
(Prefix
(Fname
));
138 E
:= First
(Expressions
(Fname
));
139 while Present
(E
) loop
140 Force_Evaluation
(E
);
142 if Original_Node
(E
) /= E
then
143 Set_Do_Range_Check
(E
, Do_Range_Check
(Original_Node
(E
)));
149 -- For a slice, we evaluate the prefix, as for the indexed component
150 -- case and then, if there is a range present, either directly or
151 -- as the constraint of a discrete subtype indication, we evaluate
152 -- the two bounds of this range.
154 elsif K
= N_Slice
then
155 Evaluate_Name
(Prefix
(Fname
));
158 DR
: constant Node_Id
:= Discrete_Range
(Fname
);
163 if Nkind
(DR
) = N_Range
then
164 Force_Evaluation
(Low_Bound
(DR
));
165 Force_Evaluation
(High_Bound
(DR
));
167 elsif Nkind
(DR
) = N_Subtype_Indication
then
168 Constr
:= Constraint
(DR
);
170 if Nkind
(Constr
) = N_Range_Constraint
then
171 Rexpr
:= Range_Expression
(Constr
);
173 Force_Evaluation
(Low_Bound
(Rexpr
));
174 Force_Evaluation
(High_Bound
(Rexpr
));
179 -- For a type conversion, the expression of the conversion must be
180 -- the name of an object, and we simply need to evaluate this name.
182 elsif K
= N_Type_Conversion
then
183 Evaluate_Name
(Expression
(Fname
));
185 -- For a function call, we evaluate the call
187 elsif K
= N_Function_Call
then
188 Force_Evaluation
(Fname
);
190 -- The remaining cases are direct name, operator symbol and
191 -- character literal. In all these cases, we do nothing, since
192 -- we want to reevaluate each time the renamed object is used.
199 -------------------------
200 -- Evaluation_Required --
201 -------------------------
203 function Evaluation_Required
(Nam
: Node_Id
) return Boolean is
205 if Nkind
(Nam
) = N_Indexed_Component
206 or else Nkind
(Nam
) = N_Slice
208 if Is_Packed
(Etype
(Prefix
(Nam
))) then
211 return Evaluation_Required
(Prefix
(Nam
));
214 elsif Nkind
(Nam
) = N_Selected_Component
then
216 Rec_Type
: constant Entity_Id
:= Etype
(Prefix
(Nam
));
219 if Present
(Component_Clause
(Entity
(Selector_Name
(Nam
))))
220 or else Has_Non_Standard_Rep
(Rec_Type
)
224 elsif Ekind
(Entity
(Selector_Name
(Nam
))) = E_Discriminant
225 and then Is_Record_Type
(Rec_Type
)
226 and then not Is_Concurrent_Record_Type
(Rec_Type
)
231 return Evaluation_Required
(Prefix
(Nam
));
238 end Evaluation_Required
;
240 -- Start of processing for Expand_N_Object_Renaming_Declaration
243 -- Perform name evaluation if required
245 if Evaluation_Required
(Nam
) then
247 Set_Is_Renaming_Of_Object
(Defining_Identifier
(N
));
250 -- Deal with construction of subtype in class-wide case
252 T
:= Etype
(Defining_Identifier
(N
));
254 if Is_Class_Wide_Type
(T
) then
255 Expand_Subtype_From_Expr
(N
, T
, Subtype_Mark
(N
), Name
(N
));
256 Find_Type
(Subtype_Mark
(N
));
257 Set_Etype
(Defining_Identifier
(N
), Entity
(Subtype_Mark
(N
)));
259 -- Freeze the class-wide subtype here to ensure that the subtype
260 -- and equivalent type are frozen before the renaming. This is
261 -- required for targets where Frontend_Layout_On_Target is true.
262 -- For targets where Gigi is used, class-wide subtype should not
263 -- be frozen (in that case the subtype is marked as already frozen
264 -- when it's created).
266 if Frontend_Layout_On_Target
then
267 Freeze_Before
(N
, Entity
(Subtype_Mark
(N
)));
271 -- Create renaming entry for debug information
273 Decl
:= Debug_Renaming_Declaration
(N
);
275 if Present
(Decl
) then
276 Insert_Action
(N
, Decl
);
278 end Expand_N_Object_Renaming_Declaration
;
280 -------------------------------------------
281 -- Expand_N_Package_Renaming_Declaration --
282 -------------------------------------------
284 procedure Expand_N_Package_Renaming_Declaration
(N
: Node_Id
) is
285 Decl
: constant Node_Id
:= Debug_Renaming_Declaration
(N
);
288 if Present
(Decl
) then
290 -- If we are in a compilation unit, then this is an outer
291 -- level declaration, and must have a scope of Standard
293 if Nkind
(Parent
(N
)) = N_Compilation_Unit
then
295 Aux
: constant Node_Id
:= Aux_Decls_Node
(Parent
(N
));
298 New_Scope
(Standard_Standard
);
300 if No
(Actions
(Aux
)) then
301 Set_Actions
(Aux
, New_List
(Decl
));
303 Append
(Decl
, Actions
(Aux
));
310 -- Otherwise, just insert after the package declaration
313 Insert_Action
(N
, Decl
);
316 end Expand_N_Package_Renaming_Declaration
;