From: Paolo Carlini Date: Fri, 4 Oct 2013 23:13:59 +0000 (+0000) Subject: re PR c++/58448 (ICE on invalid: tree_class_check_failed) X-Git-Tag: releases/gcc-4.9.0~3704 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=e36fae42ad580a61208c8c9bb82cc0b5964577b4;p=thirdparty%2Fgcc.git re PR c++/58448 (ICE on invalid: tree_class_check_failed) /cp 2013-10-04 Paolo Carlini PR c++/58448 * pt.c (tsubst): Use error_operand_p on parameter t. /testsuite 2013-10-04 Paolo Carlini PR c++/58448 * g++.dg/template/crash117.C: New. From-SVN: r203218 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 6327c0b8a66d..571d4edad7c4 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2013-10-04 Paolo Carlini + + PR c++/58448 + * pt.c (tsubst): Use error_operand_p on parameter t. + 2013-10-04 Marc Glisse PR c++/19476 diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index b330b78cbc84..59be037c82ec 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -11272,7 +11272,7 @@ tsubst (tree t, tree args, tsubst_flags_t complain, tree in_decl) enum tree_code code; tree type, r = NULL_TREE; - if (t == NULL_TREE || t == error_mark_node + if (t == NULL_TREE || t == integer_type_node || t == void_type_node || t == char_type_node @@ -11281,6 +11281,9 @@ tsubst (tree t, tree args, tsubst_flags_t complain, tree in_decl) || TREE_CODE (t) == TRANSLATION_UNIT_DECL) return t; + if (error_operand_p (t)) + return error_mark_node; + if (DECL_P (t)) return tsubst_decl (t, args, complain); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 566c569e5099..dd34bc603e89 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2013-10-04 Paolo Carlini + + PR c++/58448 + * g++.dg/template/crash117.C: New. + 2013-10-04 Marc Glisse PR c++/19476 diff --git a/gcc/testsuite/g++.dg/template/crash117.C b/gcc/testsuite/g++.dg/template/crash117.C new file mode 100644 index 000000000000..813140edc6ff --- /dev/null +++ b/gcc/testsuite/g++.dg/template/crash117.C @@ -0,0 +1,6 @@ +// PR c++/58448 + +class SmallVector; struct Types4; +template struct Types { + typedef Types4<>::Constructable // { dg-error "template|typedef|expected" } +} Types:: > // { dg-error "expected" }