]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
c++: clear tf_partial et al in instantiate_template [PR108960]
authorMarek Polacek <polacek@redhat.com>
Tue, 25 Jul 2023 18:36:47 +0000 (14:36 -0400)
committerMarek Polacek <polacek@redhat.com>
Tue, 25 Jul 2023 20:31:20 +0000 (16:31 -0400)
In <https://gcc.gnu.org/pipermail/gcc-patches/2023-February/612929.html>
we concluded that we might clear all flags except tf_warning_or_error
when performing instantiate_template.

PR c++/108960

gcc/cp/ChangeLog:

* pt.cc (lookup_and_finish_template_variable): Don't clear tf_partial
here.
(instantiate_template): Reset all complain flags except
tf_warning_or_error.

gcc/cp/pt.cc

index 21b08a6266a57268e5d1eb13c6798697467e133e..265e2a59a52700d6dd401b9d2f6181e1cfe99322 100644 (file)
@@ -10396,12 +10396,6 @@ lookup_and_finish_template_variable (tree templ, tree targs,
   tree var = lookup_template_variable (templ, targs, complain);
   if (var == error_mark_node)
     return error_mark_node;
-  /* We may be called while doing a partial substitution, but the
-     type of the variable template may be auto, in which case we
-     will call do_auto_deduction in mark_used (which clears tf_partial)
-     and the auto must be properly reduced at that time for the
-     deduction to work.  */
-  complain &= ~tf_partial;
   var = finish_template_variable (var, complain);
   mark_used (var);
   return var;
@@ -22008,6 +22002,14 @@ instantiate_template (tree tmpl, tree orig_args, tsubst_flags_t complain)
   if (tmpl == error_mark_node)
     return error_mark_node;
 
+  /* The other flags are not relevant anymore here, especially tf_partial
+     shouldn't be set.  For instance, we may be called while doing a partial
+     substitution of a template variable, but the type of the variable
+     template may be auto, in which case we will call do_auto_deduction
+     in mark_used (which clears tf_partial) and the auto must be properly
+     reduced at that time for the deduction to work.  */
+  complain &= tf_warning_or_error;
+
   gcc_assert (TREE_CODE (tmpl) == TEMPLATE_DECL);
 
   if (modules_p ())