Commit 1586f8a3 by Eric Botcazou Committed by Eric Botcazou

decl.c (elaborate_expression_1): Add EXPR_PUBLIC_P local variable.

	* gcc-interface/decl.c (elaborate_expression_1): Add EXPR_PUBLIC_P local
	variable.  Always create the elaboration variable, if any, as constant.

From-SVN: r180541
parent e1e5852c
2011-10-26 Eric Botcazou <ebotcazou@adacore.com> 2011-10-26 Eric Botcazou <ebotcazou@adacore.com>
* gcc-interface/decl.c (elaborate_expression_1): Add EXPR_PUBLIC_P local
variable. Always create the elaboration variable, if any, as constant.
2011-10-26 Eric Botcazou <ebotcazou@adacore.com>
* gcc-interface/decl.c (gnat_to_gnu_entity) <E_Record_Subtype>: Try to * gcc-interface/decl.c (gnat_to_gnu_entity) <E_Record_Subtype>: Try to
make a packable type for fields of union types as well. make a packable type for fields of union types as well.
<is_type>: Use RECORD_OR_UNION_TYPE_P predicate. <is_type>: Use RECORD_OR_UNION_TYPE_P predicate.
......
...@@ -6085,7 +6085,8 @@ static tree ...@@ -6085,7 +6085,8 @@ static tree
elaborate_expression_1 (tree gnu_expr, Entity_Id gnat_entity, tree gnu_name, elaborate_expression_1 (tree gnu_expr, Entity_Id gnat_entity, tree gnu_name,
bool definition, bool need_debug) bool definition, bool need_debug)
{ {
const bool expr_global_p = Is_Public (gnat_entity) || global_bindings_p (); const bool expr_public_p = Is_Public (gnat_entity);
const bool expr_global_p = expr_public_p || global_bindings_p ();
bool expr_variable_p, use_variable; bool expr_variable_p, use_variable;
/* In most cases, we won't see a naked FIELD_DECL because a discriminant /* In most cases, we won't see a naked FIELD_DECL because a discriminant
...@@ -6153,11 +6154,10 @@ elaborate_expression_1 (tree gnu_expr, Entity_Id gnat_entity, tree gnu_name, ...@@ -6153,11 +6154,10 @@ elaborate_expression_1 (tree gnu_expr, Entity_Id gnat_entity, tree gnu_name,
if (use_variable || need_debug) if (use_variable || need_debug)
{ {
tree gnu_decl tree gnu_decl
= create_var_decl (create_concat_name (gnat_entity, = create_var_decl_1
IDENTIFIER_POINTER (gnu_name)), (create_concat_name (gnat_entity, IDENTIFIER_POINTER (gnu_name)),
NULL_TREE, TREE_TYPE (gnu_expr), gnu_expr, NULL_TREE, TREE_TYPE (gnu_expr), gnu_expr, true, expr_public_p,
!need_debug, Is_Public (gnat_entity), !definition, expr_global_p, !need_debug, NULL, gnat_entity);
!definition, expr_global_p, NULL, gnat_entity);
if (use_variable) if (use_variable)
return gnu_decl; return gnu_decl;
......
2011-10-26 Eric Botcazou <ebotcazou@adacore.com> 2011-10-26 Eric Botcazou <ebotcazou@adacore.com>
* gnat.dg/specs/discr1.ads: New test.
* gnat.dg/specs/discr1_pkg.ads: New helper.
2011-10-26 Eric Botcazou <ebotcazou@adacore.com>
* gnat.dg/specs/unchecked_union.ads: Rename to... * gnat.dg/specs/unchecked_union.ads: Rename to...
* gnat.dg/specs/unchecked_union1.ads: ...this. * gnat.dg/specs/unchecked_union1.ads: ...this.
* gnat.dg/specs/unchecked_union2.ads: New test. * gnat.dg/specs/unchecked_union2.ads: New test.
......
-- { dg-do compile }
-- { dg-options "-gnatct" }
with Discr1_Pkg; use Discr1_Pkg;
package Discr1 is
procedure Proc (V : Variable_String_Array);
end Discr1;
package Discr1_Pkg is
Maximum_Length : Natural := 80 ;
subtype String_Length is Natural range 0 .. Maximum_Length;
type Variable_String (Length : String_Length := 0) is
record
S : String (1 .. Length);
end record;
type Variable_String_Array is array (Natural range <>) of Variable_String;
end Discr1_Pkg;
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment