From bf2f7328ffb6e4eb20b5f20fc4eeaf8fd662439d Mon Sep 17 00:00:00 2001 From: Volker Reichelt Date: Sat, 6 Aug 2005 22:22:47 +0000 Subject: [PATCH] re PR c++/19498 (ICE on invalid reference in template parameter) PR c++/19498 * pt.c (tsubst_decl) : Return ERROR_MARK_NODE if substitution of template args did not succeed. * g++.dg/template/instantiate7.C: New test. From-SVN: r102818 --- gcc/cp/ChangeLog | 6 ++++++ gcc/cp/pt.c | 2 ++ gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/g++.dg/template/instantiate7.C | 10 ++++++++++ 4 files changed, 23 insertions(+) create mode 100644 gcc/testsuite/g++.dg/template/instantiate7.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index f935d4e89dc..5593ef6f383 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2005-08-06 Volker Reichelt + + PR c++/19498 + * pt.c (tsubst_decl) : Return ERROR_MARK_NODE + if substitution of template args did not succeed. + 2005-08-06 Michael Matz * method.c (use_thunk): Call init_insn_lengths. diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index cc3c03e7fe9..bd95372478f 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -6224,6 +6224,8 @@ tsubst_decl (tree t, tree args, tsubst_flags_t complain) : DECL_TI_ARGS (DECL_TEMPLATE_RESULT (t)); full_args = tsubst_template_args (tmpl_args, args, complain, in_decl); + if (full_args == error_mark_node) + return error_mark_node; /* tsubst_template_args doesn't copy the vector if nothing changed. But, *something* should have diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 6e27aec9c24..690dbf41c20 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2005-08-06 Volker Reichelt + + PR c++/19498 + * g++.dg/template/instantiate7.C: New test. + 2005-08-06 Joseph S. Myers PR c/23113 diff --git a/gcc/testsuite/g++.dg/template/instantiate7.C b/gcc/testsuite/g++.dg/template/instantiate7.C new file mode 100644 index 00000000000..14a1a33cf21 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/instantiate7.C @@ -0,0 +1,10 @@ +// PR c++/19498 +// Origin: Volker Reichelt +// { dg-do compile } + +template struct A +{ + template struct B; // { dg-error "reference to void" } +}; + +A a; // { dg-error "instantiated" } -- 2.30.2