2016-12-07 Nathan Sidwell <nathan@acm.org>
* pt.c (tsubst <{NON,}TYPE_ARGUMENT_PACK>: Simplify control flow
and avoid re-tsubsting type.
===================================================================
@@ -13795,22 +13795,23 @@ tsubst (tree t, tree args, tsubst_flags_
case TYPE_ARGUMENT_PACK:
case NONTYPE_ARGUMENT_PACK:
{
- tree r = TYPE_P (t) ? cxx_make_type (code) : make_node (code);
- tree packed_out =
- tsubst_template_args (ARGUMENT_PACK_ARGS (t),
- args,
- complain,
- in_decl);
- SET_ARGUMENT_PACK_ARGS (r, packed_out);
+ tree r;
- /* For template nontype argument packs, also substitute into
- the type. */
- if (code == NONTYPE_ARGUMENT_PACK)
- TREE_TYPE (r) = tsubst (TREE_TYPE (t), args, complain, in_decl);
+ if (code == NONTYPE_ARGUMENT_PACK)
+ {
+ r = make_node (code);
+ /* Set the already-substituted type. */
+ TREE_TYPE (r) = type;
+ }
+ else
+ r = cxx_make_type (code);
- return r;
+ tree pack_args = ARGUMENT_PACK_ARGS (t);
+ pack_args = tsubst_template_args (pack_args, args, complain, in_decl);
+ SET_ARGUMENT_PACK_ARGS (r, pack_args);
+
+ return r;
}
- break;
case VOID_CST:
case INTEGER_CST: