From: Paolo Carlini Date: Wed, 14 Sep 2011 16:19:59 +0000 (+0000) Subject: re PR c++/50391 ([C++0x] ICE on invalid code, pair with incomplete type) X-Git-Tag: releases/gcc-4.7.0~3769 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=ebb077fc775ca085013742c10fc4273ad600ce6f;p=thirdparty%2Fgcc.git re PR c++/50391 ([C++0x] ICE on invalid code, pair with incomplete type) /cp 2011-09-14 Paolo Carlini PR c++/50391 * pt.c (regenerate_decl_from_template): Don't pass an error_mark_node to build_exception_variant. /testsuite 2011-09-14 Paolo Carlini PR c++/50391 * g++.dg/cpp0x/noexcept15.C: New. From-SVN: r178857 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index aa4a31d1ca47..8b15ca663c98 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2011-09-14 Paolo Carlini + + PR c++/50391 + * pt.c (regenerate_decl_from_template): Don't pass an error_mark_node + to build_exception_variant. + 2011-09-13 Dodji Seketeli PR c++/48320 diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index 14073646a73d..ee33daf1fb9d 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -17729,7 +17729,7 @@ regenerate_decl_from_template (tree decl, tree tmpl) specs = tsubst_exception_specification (TREE_TYPE (code_pattern), args, tf_error, NULL_TREE, /*defer_ok*/false); - if (specs) + if (specs && specs != error_mark_node) TREE_TYPE (decl) = build_exception_variant (TREE_TYPE (decl), specs); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 3aa10de48531..28d1102b18d8 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2011-09-14 Paolo Carlini + + PR c++/50391 + * g++.dg/cpp0x/noexcept15.C: New. + 2011-09-14 Tom de Vries PR middle-end/50251 diff --git a/gcc/testsuite/g++.dg/cpp0x/noexcept15.C b/gcc/testsuite/g++.dg/cpp0x/noexcept15.C new file mode 100644 index 000000000000..5e8c40c2774a --- /dev/null +++ b/gcc/testsuite/g++.dg/cpp0x/noexcept15.C @@ -0,0 +1,34 @@ +// PR c++/50391 +// { dg-options -std=c++0x } + +#include + +template + struct single + { + Tp elem; // { dg-error "incomplete type" } + + constexpr single(const Tp& e) + : elem(e) { } // { dg-error "invalid field" } + + single(single&& s) // { dg-error "not a member" } + noexcept(std::is_nothrow_move_constructible::value) + : elem(s.elem) { } // { dg-error "invalid field|no member" } + }; + +template + constexpr single::type> + make_single(Tp&& x) + { + return single::type>(x); + } + +class Blob; // { dg-error "forward declaration" } + +void +foo(Blob *b) +{ + make_single(*b); +} + +// { dg-prune-output "include" }