From e19482edb5848850c00fd868971f387185cfbfd3 Mon Sep 17 00:00:00 2001 From: jason Date: Thu, 6 Jul 2006 18:39:39 +0000 Subject: [PATCH] PR c++/28279 * decl2.c (finish_static_data_member_decl): Don't assert TREE_PUBLIC. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@115228 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/cp/ChangeLog | 6 ++++++ gcc/cp/decl2.c | 4 +--- gcc/testsuite/g++.dg/template/anon2.C | 15 +++++++++++++++ 3 files changed, 22 insertions(+), 3 deletions(-) create mode 100644 gcc/testsuite/g++.dg/template/anon2.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 3d3952c..b792964 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 0964bf5..defeafb 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 0000000..75285ad --- /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; + -- 2.7.4