]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
c++: Crash when deducing template arguments [PR98790]
authorMarek Polacek <polacek@redhat.com>
Fri, 22 Jan 2021 17:50:53 +0000 (12:50 -0500)
committerMarek Polacek <polacek@redhat.com>
Fri, 22 Jan 2021 17:52:09 +0000 (12:52 -0500)
maybe_instantiate_noexcept doesn't expect to see error_mark_node, but
the new callsite I introduced in r11-6476 can pass error_mark_node to
it.  So cope.

gcc/cp/ChangeLog:

PR c++/98790
* pt.c (maybe_instantiate_noexcept): Return false if FN is
error_mark_node.

gcc/testsuite/ChangeLog:

PR c++/98790
* g++.dg/template/deduce8.C: New test.

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

index dc2e032d6dde3e464d5e439c124a60ef36fd4cf3..abef0cdc663818ae34de7eee75503760633ffdc3 100644 (file)
@@ -25323,6 +25323,9 @@ maybe_instantiate_noexcept (tree fn, tsubst_flags_t complain)
 {
   tree fntype, spec, noex, clone;
 
+  if (fn == error_mark_node)
+    return false;
+
   /* Don't instantiate a noexcept-specification from template context.  */
   if (processing_template_decl
       && (!flag_noexcept_type || type_dependent_expression_p (fn)))
diff --git a/gcc/testsuite/g++.dg/template/deduce8.C b/gcc/testsuite/g++.dg/template/deduce8.C
new file mode 100644 (file)
index 0000000..430be42
--- /dev/null
@@ -0,0 +1,21 @@
+// PR c++/98659
+// { dg-do compile }
+
+template <bool> struct enable_if;
+struct function {
+  template <typename _F> void operator=(_F);
+};
+struct map {
+  function operator[](int);
+};
+enum { E };
+template <typename> void foo ();
+template <typename T>
+typename enable_if<T::value>::type foo ();
+
+void
+bar ()
+{
+  map m;
+  m[E] = foo<int>;
+}