+2011-03-26 Eric Botcazou <ebotcazou@adacore.com>
+
+ * gcc-interface/decl.c (gnat_to_gnu_entity) <object>: Create TYPE_DECL
+ for the padded type built to support a specified size or alignment.
+
2011-03-26 Eric Botcazou <ebotcazou@adacore.com>
* gcc-interface/gigi.h (finalize_from_with_types): Adjust comment.
size of the object. */
gnu_object_size = gnu_size ? gnu_size : TYPE_SIZE (gnu_type);
if (gnu_size || align > 0)
- gnu_type = maybe_pad_type (gnu_type, gnu_size, align, gnat_entity,
- false, false, definition,
- gnu_size ? true : false);
+ {
+ tree orig_type = gnu_type;
+
+ gnu_type = maybe_pad_type (gnu_type, gnu_size, align, gnat_entity,
+ false, false, definition,
+ gnu_size ? true : false);
+
+ /* If a padding record was made, declare it now since it will
+ never be declared otherwise. This is necessary to ensure
+ that its subtrees are properly marked. */
+ if (gnu_type != orig_type && !DECL_P (TYPE_NAME (gnu_type)))
+ create_type_decl (TYPE_NAME (gnu_type), gnu_type, NULL, true,
+ debug_info_p, gnat_entity);
+ }
/* If this is a renaming, avoid as much as possible to create a new
object. However, in several cases, creating it is required.
--- /dev/null
+package body Discr27 is\r
+\r
+ subtype Index is Positive range 1..4096;\r
+\r
+ function F return String is\r
+ S : String(1..1) := (others =>'w');\r
+ begin\r
+ return S;\r
+ end;\r
+\r
+ type Enum is (One, Two);\r
+\r
+ type Rec (D : Enum := One; Len : Index := 1) is record\r
+ case D is\r
+ when One => I : Integer;\r
+ when Two => A : String(1..Len);\r
+ end case;\r
+ end record;\r
+\r
+ procedure Nothing is\r
+ M : constant String := F;\r
+ C : constant Rec := (Two, M'Length, M);\r
+ begin\r
+ null;\r
+ end;\r
+\r
+ procedure Proc is begin\r
+ null;\r
+ end;\r
+\r
+end Discr27;\r