From 4e3f6d8529cfab76897fa4f1618409efdd468ae7 Mon Sep 17 00:00:00 2001
From: Jason Merrill <jason@redhat.com>
Date: Thu, 3 Dec 2009 19:26:27 -0500
Subject: [PATCH] re PR c++/42266 ([C++0x] ICE with decltype and variadic
 templates)

	PR c++/42266
	* cvt.c (convert_from_reference): Do nothing if TREE_TYPE is null.

From-SVN: r154964
---
 gcc/cp/ChangeLog                        |  5 ++++
 gcc/cp/cvt.c                            |  3 ++-
 gcc/testsuite/ChangeLog                 |  5 ++++
 gcc/testsuite/g++.dg/cpp0x/variadic97.C | 35 +++++++++++++++++++++++++
 4 files changed, 47 insertions(+), 1 deletion(-)
 create mode 100644 gcc/testsuite/g++.dg/cpp0x/variadic97.C

diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog
index f11ee70f0408..deb59030bd00 100644
--- a/gcc/cp/ChangeLog
+++ b/gcc/cp/ChangeLog
@@ -1,3 +1,8 @@
+2009-12-03  Jason Merrill  <jason@redhat.com>
+
+	PR c++/42266
+	* cvt.c (convert_from_reference): Do nothing if TREE_TYPE is null.
+
 2009-12-03  Dodji Seketeli  <dodji@redhat.com>
 
 	PR c++/42217
diff --git a/gcc/cp/cvt.c b/gcc/cp/cvt.c
index 8c5b001dd15c..6f3b56e43ce6 100644
--- a/gcc/cp/cvt.c
+++ b/gcc/cp/cvt.c
@@ -506,7 +506,8 @@ convert_to_reference (tree reftype, tree expr, int convtype,
 tree
 convert_from_reference (tree val)
 {
-  if (TREE_CODE (TREE_TYPE (val)) == REFERENCE_TYPE)
+  if (TREE_TYPE (val)
+      && TREE_CODE (TREE_TYPE (val)) == REFERENCE_TYPE)
     {
       tree t = TREE_TYPE (TREE_TYPE (val));
       tree ref = build1 (INDIRECT_REF, t, val);
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 0f9311b577b8..ff7a355f451b 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2009-12-03  Jason Merrill  <jason@redhat.com>
+
+	PR c++/42266
+	* g++.dg/cpp0x/variadic97.C: New.
+
 2009-12-03  Jakub Jelinek  <jakub@redhat.com>
 
 	PR middle-end/42049
diff --git a/gcc/testsuite/g++.dg/cpp0x/variadic97.C b/gcc/testsuite/g++.dg/cpp0x/variadic97.C
new file mode 100644
index 000000000000..a2070319ebd3
--- /dev/null
+++ b/gcc/testsuite/g++.dg/cpp0x/variadic97.C
@@ -0,0 +1,35 @@
+// PR c++/42266
+// { dg-options -std=c++0x }
+
+template<typename... _Elements>
+  class tuple;
+
+template<typename _Arg>
+  class _Mu;
+
+template<typename _Signature>
+  struct _Bind;
+
+template<typename _Functor, typename... _Bound_args>
+  class _Bind<_Functor(_Bound_args...)>
+  {
+    template<typename... _Args, typename
+             = decltype(_Functor()(_Mu<_Bound_args>()(_Bound_args(),
+                                                      tuple<_Args...>())...) )>
+      void __call() { }
+  };
+
+template<typename _Functor, typename _Arg>
+  _Bind<_Functor(_Arg)>
+  bind(_Functor, _Arg) { }
+
+struct State
+{
+  bool ready() { return true; }
+
+  void f()
+  {
+    bind(&State::ready, this);
+  }
+};
+
-- 
GitLab