re PR c++/60108 ([C++11] ICE in use_thunk, at cp/method.c:340)
authorJason Merrill <jason@redhat.com>
Fri, 21 Feb 2014 21:57:49 +0000 (16:57 -0500)
committerJason Merrill <jason@gcc.gnu.org>
Fri, 21 Feb 2014 21:57:49 +0000 (16:57 -0500)
PR c++/60108
* semantics.c (expand_or_defer_fn_1): Check DECL_DEFAULTED_FN.

From-SVN: r208030

gcc/cp/ChangeLog
gcc/cp/semantics.c
gcc/testsuite/g++.dg/cpp0x/defaulted48.C [new file with mode: 0644]

index ceecb8a..53f6c21 100644 (file)
@@ -1,5 +1,8 @@
 2014-02-21  Jason Merrill  <jason@redhat.com>
 
+       PR c++/60108
+       * semantics.c (expand_or_defer_fn_1): Check DECL_DEFAULTED_FN.
+
        PR c++/60185
        * parser.c (cp_parser_default_argument): Clear
        current_class_ptr/current_class_ref like tsubst_default_argument.
index 6f32496..85d6807 100644 (file)
@@ -3986,7 +3986,7 @@ expand_or_defer_fn_1 (tree fn)
             linkage of all functions, and as that causes writes to
             the data mapped in from the PCH file, it's advantageous
             to mark the functions at this point.  */
-         if (!DECL_IMPLICIT_INSTANTIATION (fn))
+         if (!DECL_IMPLICIT_INSTANTIATION (fn) || DECL_DEFAULTED_FN (fn))
            {
              /* This function must have external linkage, as
                 otherwise DECL_INTERFACE_KNOWN would have been
diff --git a/gcc/testsuite/g++.dg/cpp0x/defaulted48.C b/gcc/testsuite/g++.dg/cpp0x/defaulted48.C
new file mode 100644 (file)
index 0000000..727afc5
--- /dev/null
@@ -0,0 +1,17 @@
+// PR c++/60108
+// { dg-require-effective-target c++11 }
+
+template<int> struct A
+{
+  virtual ~A();
+};
+
+template<typename> struct B : A<0>, A<1>
+{
+  ~B() = default;
+};
+
+struct C : B<bool>
+{
+  C() {}
+};