Commit e4d7d8cb by Jason Merrill Committed by Jason Merrill

re PR c++/55753 ([C++11][4.7/4.8 Regression] ICE constexpr ctor,…

re PR c++/55753 ([C++11][4.7/4.8 Regression] ICE constexpr ctor, tsubst_copy_and_build, at cp/pt.c:14336)

	PR c++/55753
	* tree.c (build_aggr_init_expr): Do nothing in a template.
	* pt.c (tsubst_copy_and_build) [CALL_EXPR]: Strip an ADDR_EXPR off
	a FUNCTION_DECL before tsubsting.

From-SVN: r194986
parent 656e6f37
2013-01-07 Jason Merrill <jason@redhat.com>
PR c++/55753
* tree.c (build_aggr_init_expr): Do nothing in a template.
* pt.c (tsubst_copy_and_build) [CALL_EXPR]: Strip an ADDR_EXPR off
a FUNCTION_DECL before tsubsting.
2013-01-04 Dodji Seketeli <dodji@redhat.com> 2013-01-04 Dodji Seketeli <dodji@redhat.com>
PR c++/52343 PR c++/52343
......
...@@ -13743,6 +13743,11 @@ tsubst_copy_and_build (tree t, ...@@ -13743,6 +13743,11 @@ tsubst_copy_and_build (tree t,
else else
qualified_p = false; qualified_p = false;
if (TREE_CODE (function) == ADDR_EXPR
&& TREE_CODE (TREE_OPERAND (function, 0)) == FUNCTION_DECL)
/* Avoid error about taking the address of a constructor. */
function = TREE_OPERAND (function, 0);
function = tsubst_copy_and_build (function, args, complain, function = tsubst_copy_and_build (function, args, complain,
in_decl, in_decl,
!qualified_p, !qualified_p,
......
...@@ -412,6 +412,10 @@ build_aggr_init_expr (tree type, tree init) ...@@ -412,6 +412,10 @@ build_aggr_init_expr (tree type, tree init)
tree rval; tree rval;
int is_ctor; int is_ctor;
/* Don't build AGGR_INIT_EXPR in a template. */
if (processing_template_decl)
return init;
if (TREE_CODE (init) == CALL_EXPR) if (TREE_CODE (init) == CALL_EXPR)
fn = CALL_EXPR_FN (init); fn = CALL_EXPR_FN (init);
else if (TREE_CODE (init) == AGGR_INIT_EXPR) else if (TREE_CODE (init) == AGGR_INIT_EXPR)
......
// PR c++/55753
// { dg-options -std=c++11 }
struct A
{
double r,i;
constexpr A(double r = 0.0, double i = 0.0): r(r), i(i) {}
};
template <typename Tp>
struct B {
B() {
A((true ? 1.0 : A()));
}
};
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