Commit 4fdda3ce by Jason Merrill Committed by Jason Merrill

PR c++/86099 - ICE with trivial copy and non-trivial default ctor.

	* constexpr.c (instantiate_cx_fn_r): Don't synthesize trivial
	constructors.

From-SVN: r261576
parent 5cef3733
2018-06-13 Jason Merrill <jason@redhat.com>
PR c++/86099 - ICE with trivial copy and non-trivial default ctor.
* constexpr.c (instantiate_cx_fn_r): Don't synthesize trivial
constructors.
PR c++/86094 - wrong code with defaulted move ctor.
* class.c (classtype_has_non_deleted_move_ctor): New.
* tree.c (maybe_warn_parm_abi, type_has_nontrivial_copy_init):
......
......@@ -4841,6 +4841,7 @@ instantiate_cx_fn_r (tree *tp, int *walk_subtrees, void */*data*/)
if (TREE_CODE (*tp) == FUNCTION_DECL
&& DECL_DECLARED_CONSTEXPR_P (*tp)
&& !DECL_INITIAL (*tp)
&& !trivial_fn_p (*tp)
&& DECL_TEMPLOID_INSTANTIATION (*tp))
{
++function_depth;
......
// PR c++/86099
// { dg-do compile { target c++11 } }
template <int a> struct e { static constexpr int c = a; };
template <bool a> using d = e<a>;
template <bool, typename> struct aa;
template <typename...> struct j;
template <typename f, typename g> struct j<f, g> : aa<f::c, g>::h {};
template <typename i> struct n : d<i::c> {};
template <typename k, typename l = k> l m(int);
template <typename k> auto ab() -> decltype(m<k>(0));
template <typename...> struct p;
template <typename k, typename o> struct p<k, o> : e<noexcept(k(ab<o>()))> {};
template <typename> struct r;
class s;
template <typename, typename... q>
struct ac : j<d<true>, p<r<s>, q...>> {};
template <typename k> struct ae : ac<k, k> {};
template <bool, typename ad> struct aa { typedef ad h; };
template <typename k> struct w : j<n<ae<k>>, d<true>> {};
template <typename t> struct r {
t f;
int af;
r(r &&) = default;
};
template <typename k, typename = typename aa<w<k>::c, k>::h> void v(k *);
template <typename ag, typename ah, typename ai> ah aj(ag x, ah, ai) { v(x); return 0; }
template <typename> struct y { typedef int ak; };
template <typename, typename = int> class z {
public:
template <typename...> void al();
};
template <typename k, typename am> template <typename...> void z<k, am>::al() {
r<s> *u;
typename y<am>::ak a = aj(u, a, int());
}
class s {
char *an = nullptr;
};
void ao() {
z<int> b;
b.al();
}
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