+2008-06-09 Eric Botcazou <ebotcazou@adacore.com>
+
+ * decl.c (components_to_record): Adjust the packedness for the
+ qualified union as well.
+
2008-06-09 Arnaud Charlet <charlet@adacore.com>
* Make-lang.in: Use -gnatwns instead of -gnatws to make sytyle
/* Only make the QUAL_UNION_TYPE if there are any non-empty variants. */
if (gnu_variant_list)
{
+ int union_field_packed;
+
if (all_rep_and_size)
{
TYPE_SIZE (gnu_union_type) = TYPE_SIZE (gnu_record_type);
return;
}
+ /* Deal with packedness like in gnat_to_gnu_field. */
+ union_field_packed
+ = adjust_packed (gnu_union_type, gnu_record_type, packed);
+
gnu_union_field
= create_field_decl (gnu_var_name, gnu_union_type, gnu_record_type,
- packed,
+ union_field_packed,
all_rep ? TYPE_SIZE (gnu_union_type) : 0,
all_rep ? bitsize_zero_node : 0, 0);
+2008-06-09 Eric Botcazou <ebotcazou@adacore.com>
+
+ * gnat.dg/specs/pack3.ads: New test.
+ * gnat.dg/specs/pack3_pkg.ads: New helper.
+
2008-06-08 Paolo Carlini <paolo.carlini@oracle.com>
PR c++/35242
--- /dev/null
+-- { dg-do compile }
+
+with Pack3_Pkg;
+
+package Pack3 is
+
+ subtype N_TYPE is INTEGER range 0..5;
+
+ type LIST_ARRAY is array (N_TYPE range <>) of INTEGER;
+
+ type LIST (N : N_TYPE := 0) is record
+ LIST : LIST_ARRAY(1..N);
+ end record;
+ pragma PACK(LIST);
+
+ subtype CS is STRING(1..Pack3_Pkg.F);
+
+ type CSA is array (NATURAL range <>) of CS;
+
+ type REC is record
+ I1, I2 : INTEGER;
+ end record ;
+
+ type CMD is (CO, AS);
+
+ type CMD_BLOCK_TYPE (D : CMD := CO) is record
+ N : CSA (1..4);
+ case D is
+ when CO => L : LIST;
+ when AS => R : REC;
+ end case ;
+ end record;
+ pragma PACK(CMD_BLOCK_TYPE);
+
+ type CMD_TYPE is (RIGHT, WRONG);
+
+ type CMD_RESULT (D : CMD_TYPE) is record
+ case D is
+ when RIGHT => C : CMD_BLOCK_TYPE;
+ when WRONG => null;
+ end case;
+ end record ;
+ pragma PACK(CMD_RESULT);
+
+end Pack3;
--- /dev/null
+-- { dg-excess-errors "no code generated" }
+
+package Pack3_Pkg is
+
+ function F return Integer;
+
+end Pack3_Pkg;