aboutsummaryrefslogtreecommitdiff
path: root/gcc/cp/pt.cc
diff options
context:
space:
mode:
authorPatrick Palka <ppalka@redhat.com>2022-05-12 16:52:06 -0400
committerPatrick Palka <ppalka@redhat.com>2022-05-12 16:52:06 -0400
commit3e948d645bc9086eee28407fcc67d05b3450bb78 (patch)
treeb455149506a401eb0f8438ebdd7e7c93789fdffb /gcc/cp/pt.cc
parent995060aa5eb85a9a6d06c5cf9e87650522ccee3f (diff)
downloadgcc-3e948d645bc9086eee28407fcc67d05b3450bb78.zip
gcc-3e948d645bc9086eee28407fcc67d05b3450bb78.tar.gz
gcc-3e948d645bc9086eee28407fcc67d05b3450bb78.tar.bz2
c++: tighten TMPL_ARGS_LEVEL macro
This patch makes TMPL_ARGS_LEVEL verify the level argument is valid when the one-dimensional vector case. Doing so uncovered a couple of latent issues: in try_class_unification, we weren't correctly copying targs when it's two-dimensional, and in unify_pack_expansion it seems an inequality test needs to be reversed. This patch fixes both issues, and in passing makes the former function free the temporary copy of targs. gcc/cp/ChangeLog: * cp-tree.h (TMPL_ARGS_LEVEL): Assert LEVEL is 1 when TMPL_ARGS_HAVE_MULTIPLE_LEVELS is false. * pt.cc (try_class_unification): Correctly copy multidimensional targs. Free the copy of targs. (unify_pack_expansion): Fix level comparison.
Diffstat (limited to 'gcc/cp/pt.cc')
-rw-r--r--gcc/cp/pt.cc28
1 files changed, 14 insertions, 14 deletions
diff --git a/gcc/cp/pt.cc b/gcc/cp/pt.cc
index 06b4a7d..fa05e91 100644
--- a/gcc/cp/pt.cc
+++ b/gcc/cp/pt.cc
@@ -23398,8 +23398,6 @@ static tree
try_class_unification (tree tparms, tree targs, tree parm, tree arg,
bool explain_p)
{
- tree copy_of_targs;
-
if (!CLASSTYPE_SPECIALIZATION_OF_PRIMARY_TEMPLATE_P (arg))
return NULL_TREE;
else if (TREE_CODE (parm) == BOUND_TEMPLATE_TEMPLATE_PARM)
@@ -23438,21 +23436,23 @@ try_class_unification (tree tparms, tree targs, tree parm, tree arg,
because there are two ways to unify base classes of S<0, 1, 2>
with S<I, I, I>. If we kept the already deduced knowledge, we
would reject the possibility I=1. */
- copy_of_targs = make_tree_vec (TREE_VEC_LENGTH (targs));
+ targs = copy_template_args (targs);
+ for (tree& targ : tree_vec_range (INNERMOST_TEMPLATE_ARGS (targs)))
+ targ = NULL_TREE;
+ int err;
if (TREE_CODE (parm) == BOUND_TEMPLATE_TEMPLATE_PARM)
- {
- if (unify_bound_ttp_args (tparms, copy_of_targs, parm, arg, explain_p))
- return NULL_TREE;
- return arg;
- }
+ err = unify_bound_ttp_args (tparms, targs, parm, arg, explain_p);
+ else
+ err = unify (tparms, targs, CLASSTYPE_TI_ARGS (parm),
+ CLASSTYPE_TI_ARGS (arg), UNIFY_ALLOW_NONE, explain_p);
- /* If unification failed, we're done. */
- if (unify (tparms, copy_of_targs, CLASSTYPE_TI_ARGS (parm),
- CLASSTYPE_TI_ARGS (arg), UNIFY_ALLOW_NONE, explain_p))
- return NULL_TREE;
+ if (TMPL_ARGS_HAVE_MULTIPLE_LEVELS (targs))
+ for (tree level : tree_vec_range (targs))
+ ggc_free (level);
+ ggc_free (targs);
- return arg;
+ return err ? NULL_TREE : arg;
}
/* Given a template type PARM and a class type ARG, find the unique
@@ -23649,7 +23649,7 @@ unify_pack_expansion (tree tparms, tree targs, tree packed_parms,
/* Determine the index and level of this parameter pack. */
template_parm_level_and_index (parm_pack, &level, &idx);
- if (level < levels)
+ if (level > levels)
continue;
/* Keep track of the parameter packs and their corresponding