From c7225acb28b72d7e09bb17b23e559c907b3b2726 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Wed, 3 Apr 2013 21:44:02 +0200 Subject: [PATCH] re PR c++/56819 (ICE: SIGSEGV in int_cst_value (tree.h:4013) with -fcompare-debug) PR debug/56819 * tree.c (strip_typedefs): Copy NON_DEFAULT_TEMPLATE_ARGS_COUNT from args to new_args. (strip_typedefs_expr): Copy NON_DEFAULT_TEMPLATE_ARGS_COUNT from t to r instead of doing {S,G}ET_NON_DEFAULT_TEMPLATE_ARGS_COUNT. * g++.dg/debug/pr56819.C: New test. From-SVN: r197454 --- gcc/cp/ChangeLog | 8 ++++++++ gcc/cp/tree.c | 13 +++++++++---- gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/g++.dg/debug/pr56819.C | 27 +++++++++++++++++++++++++++ 4 files changed, 49 insertions(+), 4 deletions(-) create mode 100644 gcc/testsuite/g++.dg/debug/pr56819.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index bd0368b400d0..1194e9a65e3c 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,11 @@ +2013-04-03 Jakub Jelinek + + PR debug/56819 + * tree.c (strip_typedefs): Copy NON_DEFAULT_TEMPLATE_ARGS_COUNT + from args to new_args. + (strip_typedefs_expr): Copy NON_DEFAULT_TEMPLATE_ARGS_COUNT from t to + r instead of doing {S,G}ET_NON_DEFAULT_TEMPLATE_ARGS_COUNT. + 2013-04-01 Jason Merrill PR c++/56794 diff --git a/gcc/cp/tree.c b/gcc/cp/tree.c index b4a538645daa..f5a43853b870 100644 --- a/gcc/cp/tree.c +++ b/gcc/cp/tree.c @@ -1229,8 +1229,13 @@ strip_typedefs (tree t) changed = true; } if (changed) - fullname = lookup_template_function (TREE_OPERAND (fullname, 0), - new_args); + { + NON_DEFAULT_TEMPLATE_ARGS_COUNT (new_args) + = NON_DEFAULT_TEMPLATE_ARGS_COUNT (args); + fullname + = lookup_template_function (TREE_OPERAND (fullname, 0), + new_args); + } else ggc_free (new_args); } @@ -1363,8 +1368,8 @@ strip_typedefs_expr (tree t) r = copy_node (t); for (i = 0; i < n; ++i) TREE_VEC_ELT (r, i) = VEC_index (tree, vec, i); - SET_NON_DEFAULT_TEMPLATE_ARGS_COUNT - (r, GET_NON_DEFAULT_TEMPLATE_ARGS_COUNT (t)); + NON_DEFAULT_TEMPLATE_ARGS_COUNT (r) + = NON_DEFAULT_TEMPLATE_ARGS_COUNT (t); } else r = t; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 461a7b63569f..27b507c16d17 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2013-04-03 Jakub Jelinek + + PR debug/56819 + * g++.dg/debug/pr56819.C: New test. + 2013-04-03 Tobias Burnus Backport from mainline: diff --git a/gcc/testsuite/g++.dg/debug/pr56819.C b/gcc/testsuite/g++.dg/debug/pr56819.C new file mode 100644 index 000000000000..62926be2fb0c --- /dev/null +++ b/gcc/testsuite/g++.dg/debug/pr56819.C @@ -0,0 +1,27 @@ +// PR debug/56819 +// { dg-do compile } +// { dg-options "-fcompare-debug" } + +template +struct A +{ + template + struct B; +}; + +template +struct C +{ + typedef int I; +}; + +template +class D +{ + typedef A E; + typedef typename T::template B F; + typedef typename C ::I I; + A foo () { return A (); } +}; + +template class D >; -- 2.47.2