From: Jason Merrill Date: Thu, 6 Jul 2006 18:39:39 +0000 (-0400) Subject: re PR c++/28279 (ICE in finish_static_data_member_decl, at cp/decl2.c:716) X-Git-Tag: releases/gcc-4.2.0~2171 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=1f0b926a1fe14a4ec094be7343aa7c8cf9b70716;p=thirdparty%2Fgcc.git re PR c++/28279 (ICE in finish_static_data_member_decl, at cp/decl2.c:716) PR c++/28279 * decl2.c (finish_static_data_member_decl): Don't assert TREE_PUBLIC. From-SVN: r115228 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 3d3952cb681b..b7929640c014 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2006-07-06 Jason Merrill + + PR c++/28279 + * decl2.c (finish_static_data_member_decl): Don't assert + TREE_PUBLIC. + 2006-07-05 Jason Merrill PR c++/13983 diff --git a/gcc/cp/decl2.c b/gcc/cp/decl2.c index 0964bf5de849..defeafbf5512 100644 --- a/gcc/cp/decl2.c +++ b/gcc/cp/decl2.c @@ -713,15 +713,13 @@ finish_static_data_member_decl (tree decl, tree asmspec_tree, int flags) { - gcc_assert (TREE_PUBLIC (decl)); - DECL_CONTEXT (decl) = current_class_type; /* We cannot call pushdecl here, because that would fill in the TREE_CHAIN of our decl. Instead, we modify cp_finish_decl to do the right thing, namely, to put this decl out straight away. */ - if (! processing_template_decl) + if (! processing_template_decl && TREE_PUBLIC (decl)) note_vague_linkage_var (decl); if (LOCAL_CLASS_P (current_class_type)) diff --git a/gcc/testsuite/g++.dg/template/anon2.C b/gcc/testsuite/g++.dg/template/anon2.C new file mode 100644 index 000000000000..75285ade3798 --- /dev/null +++ b/gcc/testsuite/g++.dg/template/anon2.C @@ -0,0 +1,15 @@ +// PR c++/28279 +// finish_static_data_member_decl was confused by the anonymous +// namespace causing TREE_PUBLIC to be unset + +template +struct is_pointer_impl { + static const bool value = true; +}; + +namespace { + class prefix_name_mapper {}; +} + +static const bool val = is_pointer_impl::value; +