re PR c++/61433 (ICE: SIGSEGV in friend_accessible_p (search.c:778) with -std=gnu...
authorJason Merrill <jason@redhat.com>
Fri, 27 Jun 2014 21:38:24 +0000 (17:38 -0400)
committerJason Merrill <jason@gcc.gnu.org>
Fri, 27 Jun 2014 21:38:24 +0000 (17:38 -0400)
PR c++/61433
* error.c (dump_template_bindings): Don't tsubst in a clone.

From-SVN: r212091

gcc/cp/ChangeLog
gcc/cp/error.c
gcc/testsuite/g++.dg/debug/dwarf2/pr61433.C [new file with mode: 0644]

index 90ec8ad..2236a5c 100644 (file)
@@ -1,3 +1,8 @@
+2014-06-27  Jason Merrill  <jason@redhat.com>
+
+       PR c++/61433
+       * error.c (dump_template_bindings): Don't tsubst in a clone.
+
 2014-06-27  Paolo Carlini  <paolo.carlini@oracle.com>
 
        PR c++/61614
index 27a167a..fa3bdc4 100644 (file)
@@ -318,6 +318,11 @@ dump_template_bindings (cxx_pretty_printer *pp, tree parms, tree args,
   if (vec_safe_is_empty (typenames) || uses_template_parms (args))
     return;
 
+  /* Don't try to print typenames when we're processing a clone.  */
+  if (current_function_decl
+      && !DECL_LANG_SPECIFIC (current_function_decl))
+    return;
+
   FOR_EACH_VEC_SAFE_ELT (typenames, i, t)
     {
       if (need_semicolon)
diff --git a/gcc/testsuite/g++.dg/debug/dwarf2/pr61433.C b/gcc/testsuite/g++.dg/debug/dwarf2/pr61433.C
new file mode 100644 (file)
index 0000000..a63b8a9
--- /dev/null
@@ -0,0 +1,23 @@
+// PR c++/61433
+// { dg-do compile { target c++11 } }
+// { dg-options "-O -fcompare-debug -fno-inline -fno-ipa-pure-const -fipa-sra" }
+
+template <class T>
+struct A
+{
+  template <class V>
+  struct B
+  {
+    int MEM;
+  };
+};
+struct D {};
+struct C: public A<int>::B<D>
+{};
+template <class T, class U, class V>
+auto k(T t, U u, V v) -> decltype (t.U::template B<V>::MEM)
+{}
+int main()
+{
+  k( C(), A<int>(), D() );
+}