From 42aa5ada5f8cad29ee89c1d3766f45ded0f0a524 Mon Sep 17 00:00:00 2001 From: Jason Merrill Date: Mon, 13 Dec 2010 15:46:34 -0500 Subject: [PATCH] foo From-SVN: r167769 --- gcc/cp/semantics.c | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/gcc/cp/semantics.c b/gcc/cp/semantics.c index 7e4255325d2..1b3bfa33919 100644 --- a/gcc/cp/semantics.c +++ b/gcc/cp/semantics.c @@ -5485,9 +5485,20 @@ build_data_member_initialization (tree t, VEC(constructor_elt,gc) **vec) init = unshare_expr (TREE_OPERAND (t, 1)); if (TREE_CODE (member) == INDIRECT_REF) { - /* Don't put out anything for an empty base. */ - gcc_assert (is_empty_class (TREE_TYPE (member))); - return true; + tree op = TREE_OPERAND (member, 0); + STRIP_NOPS (op); + gcc_assert (TREE_CODE (op) == ADDR_EXPR); + op = TREE_OPERAND (op, 0); + if (TREE_CODE (op) == COMPONENT_REF) + /* Initializing a cv-qualified member; we just looked through + the const_cast. */ + member = op; + else + { + /* Initializing an empty base; just skip it. */ + gcc_assert (is_empty_class (TREE_TYPE (member))); + return true; + } } } else -- 2.11.4.GIT