re PR c++/40274 (Revision 145566 caused ICE in tsubst, at cp/pt.c:9289)
PR c++/40274 * error.c (dump_template_parms): Pass all args to count_non_default_template_args. (count_non_default_template_args): Pull out the inner ones. From-SVN: r149066
This commit is contained in:
parent
b52b174919
commit
8cc77ebed0
@ -1,3 +1,10 @@
|
|||||||
|
2009-06-29 Jason Merrill <jason@redhat.com>
|
||||||
|
|
||||||
|
PR c++/40274
|
||||||
|
* error.c (dump_template_parms): Pass all args to
|
||||||
|
count_non_default_template_args.
|
||||||
|
(count_non_default_template_args): Pull out the inner ones.
|
||||||
|
|
||||||
2009-06-26 H.J. Lu <hongjiu.lu@intel.com>
|
2009-06-26 H.J. Lu <hongjiu.lu@intel.com>
|
||||||
|
|
||||||
* decl.c (duplicate_decls): Re-indent.
|
* decl.c (duplicate_decls): Re-indent.
|
||||||
|
@ -165,7 +165,8 @@ dump_template_argument (tree arg, int flags)
|
|||||||
static int
|
static int
|
||||||
count_non_default_template_args (tree args, tree params)
|
count_non_default_template_args (tree args, tree params)
|
||||||
{
|
{
|
||||||
int n = TREE_VEC_LENGTH (args);
|
tree inner_args = INNERMOST_TEMPLATE_ARGS (args);
|
||||||
|
int n = TREE_VEC_LENGTH (inner_args);
|
||||||
int last;
|
int last;
|
||||||
|
|
||||||
if (params == NULL_TREE || !flag_pretty_templates)
|
if (params == NULL_TREE || !flag_pretty_templates)
|
||||||
@ -184,7 +185,7 @@ count_non_default_template_args (tree args, tree params)
|
|||||||
def = tsubst_copy_and_build (def, args, tf_none, NULL_TREE, false, true);
|
def = tsubst_copy_and_build (def, args, tf_none, NULL_TREE, false, true);
|
||||||
--processing_template_decl;
|
--processing_template_decl;
|
||||||
}
|
}
|
||||||
if (!cp_tree_equal (TREE_VEC_ELT (args, last), def))
|
if (!cp_tree_equal (TREE_VEC_ELT (inner_args, last), def))
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1434,7 +1435,7 @@ dump_template_parms (tree info, int primary, int flags)
|
|||||||
pp_cxx_begin_template_argument_list (cxx_pp);
|
pp_cxx_begin_template_argument_list (cxx_pp);
|
||||||
|
|
||||||
/* Be careful only to print things when we have them, so as not
|
/* Be careful only to print things when we have them, so as not
|
||||||
to crash producing error messages. */
|
to crash producing error messages. */
|
||||||
if (args && !primary)
|
if (args && !primary)
|
||||||
{
|
{
|
||||||
int len, ix;
|
int len, ix;
|
||||||
@ -1443,11 +1444,9 @@ dump_template_parms (tree info, int primary, int flags)
|
|||||||
? DECL_INNERMOST_TEMPLATE_PARMS (TI_TEMPLATE (info))
|
? DECL_INNERMOST_TEMPLATE_PARMS (TI_TEMPLATE (info))
|
||||||
: NULL_TREE);
|
: NULL_TREE);
|
||||||
|
|
||||||
if (TMPL_ARGS_HAVE_MULTIPLE_LEVELS (args))
|
|
||||||
args = TREE_VEC_ELT (args, TREE_VEC_LENGTH (args) - 1);
|
|
||||||
|
|
||||||
len = count_non_default_template_args (args, params);
|
len = count_non_default_template_args (args, params);
|
||||||
|
|
||||||
|
args = INNERMOST_TEMPLATE_ARGS (args);
|
||||||
for (ix = 0; ix != len; ix++)
|
for (ix = 0; ix != len; ix++)
|
||||||
{
|
{
|
||||||
tree arg = TREE_VEC_ELT (args, ix);
|
tree arg = TREE_VEC_ELT (args, ix);
|
||||||
|
Loading…
Reference in New Issue
Block a user