re PR c++/51344 (cc1plus hangs when compiling)
authorKai Tietz <ktietz@redhat.com>
Thu, 19 Jan 2012 22:15:26 +0000 (23:15 +0100)
committerKai Tietz <ktietz@gcc.gnu.org>
Thu, 19 Jan 2012 22:15:26 +0000 (23:15 +0100)
2012-01-19  Kai Tietz  <ktietz@redhat.com>

        PR c++/51344
        * decl2.c (save_template_attributes): Use merge_attributes
        instead of chaining up via TREE_CHAIN.

2012-01-19  Kai Tietz  <ktietz@redhat.com>

        * g++.dg/torture/pr51344.C: New test.

From-SVN: r183313

gcc/cp/ChangeLog
gcc/cp/decl2.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/torture/pr51344.C [new file with mode: 0644]

index adec9249adfe79437b3ca943139bcdac51dc31fb..610baa2ede2ab2bb811dc98a6001fdfb0173f31b 100644 (file)
@@ -1,3 +1,9 @@
+2012-01-19  Kai Tietz  <ktietz@redhat.com>
+
+       PR c++/51344
+       * decl2.c (save_template_attributes): Use merge_attributes
+       instead of chaining up via TREE_CHAIN.
+
 2012-01-19  Jason Merrill  <jason@redhat.com>
 
        PR c++/51889
index 270fe54bceffde3021bcae971e9bb35e5022eaa1..f51790c551d12f37538c090c227f5ce711d2df2b 100644 (file)
@@ -1199,9 +1199,9 @@ save_template_attributes (tree *attr_p, tree *decl_p)
 
   old_attrs = *q;
 
-  /* Place the late attributes at the beginning of the attribute
+  /* Merge the late attributes at the beginning with the attribute
      list.  */
-  TREE_CHAIN (tree_last (late_attrs)) = *q;
+  late_attrs = merge_attributes (late_attrs, *q);
   *q = late_attrs;
 
   if (!DECL_P (*decl_p) && *decl_p == TYPE_MAIN_VARIANT (*decl_p))
index eb1663c0e0ff61b7e5de5a46392e72d2bc2c0480..9b81745028b92dd94f0dd2889520dc2ab7471f5e 100644 (file)
@@ -1,3 +1,7 @@
+2012-01-19  Kai Tietz  <ktietz@redhat.com>
+
+       * g++.dg/torture/pr51344.C: New test.
+
 2012-01-19  Tobias Burnus  <burnus@net-b.de>
 
        PR fortran/51904
diff --git a/gcc/testsuite/g++.dg/torture/pr51344.C b/gcc/testsuite/g++.dg/torture/pr51344.C
new file mode 100644 (file)
index 0000000..482c0fa
--- /dev/null
@@ -0,0 +1,9 @@
+/* { dg-do compile } */
+template <class T>
+class B
+{
+  friend __attribute__((cdecl)) A& operator >>(A& a, B& b)
+  {
+    return a;
+  }
+};