PR c++/92594 - ICE with inherited trivial default ctor.
authorJason Merrill <jason@redhat.com>
Tue, 14 Jan 2020 06:00:48 +0000 (01:00 -0500)
committerJason Merrill <jason@redhat.com>
Tue, 14 Jan 2020 16:57:34 +0000 (11:57 -0500)
Here we were getting confused about whether or not pod_tuple has a trivial
default constructor.  bar inherits the trivial e default constructor; the
effect of calling that inherited constructor is equivalent to calling a
defaulted default constructor in bar, so let's treat it as such.

* method.c (trivial_fn_p): Treat an inherited default constructor
like a normal default constructor.

gcc/cp/ChangeLog
gcc/cp/method.c
gcc/testsuite/g++.dg/cpp0x/inh-ctor34.C [new file with mode: 0644]

index f7e5e74d281eea5252664ddb2a4334bea1da084d..3fd35b437b43a020d8f95577a03fdff4f5d86663 100644 (file)
@@ -1,5 +1,9 @@
 2020-01-14  Jason Merrill  <jason@redhat.com>
 
+       PR c++/92594 - ICE with inherited trivial default ctor.
+       * method.c (trivial_fn_p): Treat an inherited default constructor
+       like a normal default constructor.
+
        PR c++/92009 - ICE with punning of typeid.
        * rtti.c (get_tinfo_desc): Call xref_basetypes.
        * constexpr.c (cxx_fold_indirect_ref): Don't strip
index fef19e18196b991c0beab6a7c22ca07bdea003a5..e20a88febdccc130045ad43fc623aba0b921cbe6 100644 (file)
@@ -458,7 +458,12 @@ trivial_fn_p (tree fn)
   /* If fn is a clone, get the primary variant.  */
   if (tree prim = DECL_CLONED_FUNCTION (fn))
     fn = prim;
-  return type_has_trivial_fn (DECL_CONTEXT (fn), special_function_p (fn));
+  special_function_kind sfk = special_function_p (fn);
+  /* An inherited default constructor is equivalent to a non-inherited default
+     constructor, so let it be trivial.  */
+  if (sfk == sfk_inheriting_constructor && default_ctor_p (fn))
+    sfk = sfk_constructor;
+  return type_has_trivial_fn (DECL_CONTEXT (fn), sfk);
 }
 
 /* PARM is a PARM_DECL for a function which we want to forward to another
diff --git a/gcc/testsuite/g++.dg/cpp0x/inh-ctor34.C b/gcc/testsuite/g++.dg/cpp0x/inh-ctor34.C
new file mode 100644 (file)
index 0000000..9afc0e9
--- /dev/null
@@ -0,0 +1,13 @@
+// PR c++/92594
+// { dg-do compile { target c++11 } }
+
+template <typename _Head> struct tuple {
+  tuple() : _M_head_impl() {}
+  _Head _M_head_impl;
+};
+template <typename type0> struct pod_tuple { type0 _head; };
+struct e {};
+struct bar : e {
+  using e::e;
+};
+int main() { tuple<pod_tuple<bar>> a; }