Commit acb2970c by Jason Merrill Committed by Jason Merrill

re PR c++/66450 ([C++11][constexpr] Issues when delegating implicit copy…

re PR c++/66450 ([C++11][constexpr] Issues when delegating implicit copy constructor in constexpr function)

	PR c++/66450
	* constexpr.c (cxx_eval_store_expression): Avoid messing up outer
	ctx->ctor.

From-SVN: r224381
parent 881a5e60
2015-06-11 Jason Merrill <jason@redhat.com>
PR c++/66450
* constexpr.c (cxx_eval_store_expression): Avoid messing up outer
ctx->ctor.
2015-06-10 Jason Merrill <jason@redhat.com>
PR c++/66289
......
......@@ -2671,11 +2671,13 @@ cxx_eval_store_expression (const constexpr_ctx *ctx, tree t,
}
release_tree_vector (refs);
if ((AGGREGATE_TYPE_P (TREE_TYPE (t)) || VECTOR_TYPE_P (TREE_TYPE (t))))
if (AGGREGATE_TYPE_P (type) || VECTOR_TYPE_P (type))
{
/* Create a new CONSTRUCTOR in case evaluation of the initializer
wants to modify it. */
*valp = new_ctx.ctor = build_constructor (TREE_TYPE (t), NULL);
new_ctx.ctor = build_constructor (type, NULL);
if (*valp == NULL_TREE)
*valp = new_ctx.ctor;
CONSTRUCTOR_NO_IMPLICIT_ZERO (new_ctx.ctor) = true;
new_ctx.object = target;
}
......@@ -2683,8 +2685,16 @@ cxx_eval_store_expression (const constexpr_ctx *ctx, tree t,
init = cxx_eval_constant_expression (&new_ctx, init, false,
non_constant_p, overflow_p);
if (target == object)
/* The hash table might have moved since the get earlier. */
ctx->values->put (object, init);
{
/* The hash table might have moved since the get earlier. */
valp = ctx->values->get (object);
if (TREE_CODE (init) == CONSTRUCTOR)
/* An outer ctx->ctor might be pointing to *valp, so just replace
its contents. */
CONSTRUCTOR_ELTS (*valp) = CONSTRUCTOR_ELTS (init);
else
*valp = init;
}
else
*valp = init;
......
// PR c++/66450
// { dg-do compile { target c++11 } }
struct foo {
constexpr foo(int a);
constexpr foo(int a, int b, int c): a{a}, b{b}, c{c} {}
int a, b, c;
};
constexpr foo make_foo(int a) { return foo{a, a+1, a+2}; }
constexpr foo::foo(int a): foo{make_foo(a)} {}
int main() {
constexpr const foo f{3};
static_assert(f.a == 3, "");
static_assert(f.b == 4, "");
static_assert(f.c == 5, "");
}
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