OSDN Git Service

PR c++/48261
authorjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 1 Jul 2011 20:24:38 +0000 (20:24 +0000)
committerjason <jason@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 1 Jul 2011 20:24:38 +0000 (20:24 +0000)
* pt.c (lookup_template_function): Handle non-function.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@175766 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/cp/ChangeLog
gcc/cp/pt.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/template/template-id-3.C [new file with mode: 0644]

index 5cfdfbf..38ede64 100644 (file)
@@ -1,5 +1,8 @@
 2011-07-01  Jason Merrill  <jason@redhat.com>
 
+       PR c++/48261
+       * pt.c (lookup_template_function): Handle non-function.
+
        PR c++/48593
        * pt.c (tsubst_qualified_id): Check PTRMEM_OK_P.
        * tree.c (build_qualified_name): Set PTRMEM_OK_P.
index 5743159..7236e7e 100644 (file)
@@ -6622,8 +6622,12 @@ lookup_template_function (tree fns, tree arglist)
     return error_mark_node;
 
   gcc_assert (!arglist || TREE_CODE (arglist) == TREE_VEC);
-  gcc_assert (fns && (is_overloaded_fn (fns)
-                     || TREE_CODE (fns) == IDENTIFIER_NODE));
+
+  if (!is_overloaded_fn (fns) && TREE_CODE (fns) != IDENTIFIER_NODE)
+    {
+      error ("%q#D is not a function template", fns);
+      return error_mark_node;
+    }
 
   if (BASELINK_P (fns))
     {
index a201db2..c13fd9f 100644 (file)
@@ -1,5 +1,8 @@
 2011-07-01  Jason Merrill  <jason@redhat.com>
 
+       PR c++/48261
+       * g++.dg/template/template-id-3.C: New.
+
        PR c++/48593
        * g++.dg/template/qualified-id4.C: New.
 
diff --git a/gcc/testsuite/g++.dg/template/template-id-3.C b/gcc/testsuite/g++.dg/template/template-id-3.C
new file mode 100644 (file)
index 0000000..e0753ab
--- /dev/null
@@ -0,0 +1,22 @@
+// PR c++/48261
+
+typedef double (*gaddType)(double,double);
+struct Foo2
+{
+  static gaddType add;
+};
+
+template<typename T>
+struct Something
+{
+  void work()
+  {
+    double x=T::template add<double>(5.0,6.0); // { dg-error "add" }
+  }
+};
+
+int main()
+{
+  Something<Foo2> s2;
+  s2.work();
+}