From: Jason Merrill Date: Tue, 10 Mar 2020 21:51:46 +0000 (-0400) Subject: c++: Fix ICE with omitted template args [PR93956]. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=df15a82804e1f7f4a7432670b33387779de46549;p=gcc.git c++: Fix ICE with omitted template args [PR93956]. reshape_init only wants to work on BRACE_ENCLOSED_INITIALIZER_P, i.e. raw initializer lists, and here was getting a CONSTRUCTOR that had already been processed for type A. maybe_aggr_guide should also use that test. gcc/cp/ChangeLog 2020-03-10 Jason Merrill PR c++/93956 * pt.c (maybe_aggr_guide): Check BRACE_ENCLOSED_INITIALIZER_P. --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index e62aefde0c7..b60b1ecc604 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2020-03-10 Jason Merrill + + PR c++/93956 + * pt.c (maybe_aggr_guide): Check BRACE_ENCLOSED_INITIALIZER_P. + 2020-03-10 Jason Merrill PR c++/93922 diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 49ee3920049..179716b5680 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -28182,7 +28182,7 @@ maybe_aggr_guide (tree tmpl, tree init, vec *args) tsubst_flags_t complain = tf_none; tree parms = NULL_TREE; - if (TREE_CODE (init) == CONSTRUCTOR) + if (BRACE_ENCLOSED_INITIALIZER_P (init)) { init = reshape_init (type, init, complain); if (init == error_mark_node) diff --git a/gcc/testsuite/g++.dg/cpp1z/class-deduction70.C b/gcc/testsuite/g++.dg/cpp1z/class-deduction70.C new file mode 100644 index 00000000000..f14bdf0b8ec --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp1z/class-deduction70.C @@ -0,0 +1,7 @@ +// PR c++/93596 + +template struct A {}; +template struct B {}; +template struct C { + void foo () { B a = A { foo }; } // { dg-error "" } +};