Commit 4eaee921 by Jason Merrill Committed by Jason Merrill

re PR c++/55419 (ICE in gimplify_init_ctor_preeval, at gimplify.c:3587)

	PR c++/55419
	* tree.c (build_target_expr): Don't set TREE_CONSTANT.

From-SVN: r194317
parent 3da2b176
2012-12-07 Jason Merrill <jason@redhat.com>
PR c++/55419
* tree.c (build_target_expr): Don't set TREE_CONSTANT.
2012-12-07 Aldy Hernandez <aldyh@redhat.com>
PR c++/55513
......
......@@ -329,8 +329,6 @@ build_target_expr (tree decl, tree value, tsubst_flags_t complain)
side-effects, then the optimizer should be able to get rid of
whatever code is generated anyhow. */
TREE_SIDE_EFFECTS (t) = 1;
if (literal_type_p (type))
TREE_CONSTANT (t) = TREE_CONSTANT (value);
return t;
}
......
// PR c++/55419
// { dg-options -std=c++11 }
struct P
{
P () = default;
explicit constexpr P (int x) : p (x) {}
int p;
};
struct Q
{
constexpr Q () : q (0x7f) {}
int q;
};
struct R
{
Q q;
P p;
};
void
foo (R *x)
{
*x = {};
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment