aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp/cp-gimplify.c
diff options
context:
space:
mode:
authorJason Merrill <jason@redhat.com>2011-12-21 14:19:47 -0500
committerJason Merrill <jason@gcc.gnu.org>2011-12-21 14:19:47 -0500
commitc65b06073ce31831f65fce84a393c106c1ad5a07 (patch)
treef9cb257f4823f2b31482274185ea050dec8ef4e9 /gcc/cp/cp-gimplify.c
parente2c4d88e42f75633a0c55de1400dbee322438d70 (diff)
downloadgcc-c65b06073ce31831f65fce84a393c106c1ad5a07.zip
gcc-c65b06073ce31831f65fce84a393c106c1ad5a07.tar.gz
gcc-c65b06073ce31831f65fce84a393c106c1ad5a07.tar.bz2
re PR c++/51611 ([c++0x] ICE with non-static data member initializer and virtual base class)
PR c++/51611 * cp-tree.h (CONVERT_EXPR_VBASE_PATH): New. * class.c (build_base_path): Defer vbase conversion in an NSDMI. * tree.c (bot_replace): Expand it here. * cp-gimplify.c (cp_genericize_r): Make sure deferred conversion doesn't leak into GENERIC. From-SVN: r182602
Diffstat (limited to 'gcc/cp/cp-gimplify.c')
-rw-r--r--gcc/cp/cp-gimplify.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/gcc/cp/cp-gimplify.c b/gcc/cp/cp-gimplify.c
index c68069d..e06c5454 100644
--- a/gcc/cp/cp-gimplify.c
+++ b/gcc/cp/cp-gimplify.c
@@ -1100,6 +1100,8 @@ cp_genericize_r (tree *stmt_p, int *walk_subtrees, void *data)
wtd->omp_ctx = omp_ctx.outer;
splay_tree_delete (omp_ctx.variables);
}
+ else if (TREE_CODE (stmt) == CONVERT_EXPR)
+ gcc_assert (!CONVERT_EXPR_VBASE_PATH (stmt));
pointer_set_insert (p_set, *stmt_p);