2011-02-09 Jason Merrill <jason@redhat.com>
+ * class.c (type_has_constexpr_default_constructor): Make sure the
+ caller stripped an enclosing array.
+ * init.c (perform_member_init): Strip arrays before calling it.
+
PR c++/47511
* semantics.c (potential_constant_expression_1): Handle TEMPLATE_DECL.
tree fns;
if (!CLASS_TYPE_P (t))
- return false;
+ {
+ /* The caller should have stripped an enclosing array. */
+ gcc_assert (TREE_CODE (t) != ARRAY_TYPE);
+ return false;
+ }
if (CLASSTYPE_LAZY_DEFAULT_CTOR (t))
return synthesized_default_constructor_is_constexpr (t);
fns = locate_ctor (t);
"uninitialized member %qD with %<const%> type %qT",
member, type);
+ core_type = strip_array_types (type);
+
if (DECL_DECLARED_CONSTEXPR_P (current_function_decl)
- && !type_has_constexpr_default_constructor (type))
+ && !type_has_constexpr_default_constructor (core_type))
{
if (!DECL_TEMPLATE_INSTANTIATION (current_function_decl))
error ("uninitialized member %qD in %<constexpr%> constructor",
DECL_DECLARED_CONSTEXPR_P (current_function_decl) = false;
}
- core_type = strip_array_types (type);
if (CLASS_TYPE_P (core_type)
&& (CLASSTYPE_READONLY_FIELDS_NEED_INIT (core_type)
|| CLASSTYPE_REF_FIELDS_NEED_INIT (core_type)))
2011-02-09 Jason Merrill <jason@redhat.com>
+ * g++.dg/cpp0x/regress/abi-empty7.C: New.
+
* g++.dg/cpp0x/regress: New directory.
* g++.dg/cpp0x/constexpr-regress1.C: Move to regress/regress1.C.
* g++.dg/cpp0x/constexpr-regress2.C: Move to regress/regress2.C.
--- /dev/null
+// Copy of abi/empty7.C.
+// { dg-do run { target i?86-*-* x86_64-*-* } }
+// { dg-require-effective-target ilp32 }
+// { dg-options "-fabi-version=0 -std=c++0x" }
+
+struct S1 {};
+struct S2 { virtual void f () {} S1 s1[4]; };
+struct S3 : virtual public S2 {};
+struct S4 : virtual public S2 { int i; };
+struct S5 : public S3, virtual public S4 {};
+struct S6 { S5 s5; };
+struct S7 { S1 s1[5]; };
+struct S8 : public S1, public S6, virtual public S7 { };
+
+S8 s8;
+
+int main () {
+ if ((char *)(S7 *)&s8 - (char *)&s8 != 24)
+ return 1;
+}