aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2010-11-03 22:15:08 -0400
committerJason Merrill <jason@gcc.gnu.org>2010-11-03 22:15:08 -0400
commitdafed7ca0bdb906406efdd84256e1cebde06b94e (patch)
tree8991911a4ae81fbf5019da8a4b437a3e44e2a825 /gcc/cp
parentbc99421e351e6f3ed3c8b5681179cd76d5f2862f (diff)
downloadgcc-dafed7ca0bdb906406efdd84256e1cebde06b94e.zip
gcc-dafed7ca0bdb906406efdd84256e1cebde06b94e.tar.gz
gcc-dafed7ca0bdb906406efdd84256e1cebde06b94e.tar.bz2
re PR c++/46293 (constexpr vs. tuple, ice)
PR c++/46293 * semantics.c (build_data_member_initialization): Handle value-init of aggregate empty base. From-SVN: r166297
Diffstat (limited to 'gcc/cp')
-rw-r--r--gcc/cp/ChangeLog4
-rw-r--r--gcc/cp/semantics.c8
2 files changed, 12 insertions, 0 deletions
diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index e384cf7..c432ca8 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,5 +1,9 @@
2010-11-03 Jason Merrill <jason@redhat.com>
+ PR c++/46293
+ * semantics.c (build_data_member_initialization): Handle
+ value-init of aggregate empty base.
+
PR c++/46289
* call.c (can_convert_array): New fn.
(build_aggr_conv): Use it.
diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c
index 562fab1..9061a89 100644
--- a/gcc/cp/semantics.c
+++ b/gcc/cp/semantics.c
@@ -5460,6 +5460,14 @@ build_data_member_initialization (tree t, VEC(constructor_elt,gc) **vec)
{
member = TREE_OPERAND (t, 0);
init = unshare_expr (TREE_OPERAND (t, 1));
+ if (TREE_CODE (member) == INDIRECT_REF)
+ {
+ /* Don't put out anything for value-init of an empty base. */
+ gcc_assert (is_empty_class (TREE_TYPE (member)));
+ gcc_assert (TREE_CODE (init) == CONSTRUCTOR
+ && CONSTRUCTOR_NELTS (init) == 0);
+ return true;
+ }
}
else
{