diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 0dd1e8ca4c26a3ed4a7f6e56cf88eafdcf3218aa..d1eb30fea24edb8e3fe20e11993d0451c08f06bf 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,10 @@ +2006-07-16 Jakub Jelinek <jakub@redhat.com> + + PR c++/28370 + * decl2.c (note_vague_linkage_var): Removed. + (finish_static_data_member_decl): Add decl to pending_statics vector + directly. Do it even for non-public decls. + 2006-07-15 Lee Millward <lee.millward@gmail.com> PR c++/28292 diff --git a/gcc/cp/decl2.c b/gcc/cp/decl2.c index f1a8a77431cda8c76f5e69c8355bb4cc751478de..dfb30f25d936d38e3550eb26eb9eeaa4ba267d1c 100644 --- a/gcc/cp/decl2.c +++ b/gcc/cp/decl2.c @@ -700,14 +700,6 @@ note_vague_linkage_fn (tree decl) } } -/* Like note_vague_linkage_fn but for variables. */ - -static void -note_vague_linkage_var (tree var) -{ - VEC_safe_push (tree, gc, pending_statics, var); -} - /* We have just processed the DECL, which is a static data member. The other parameters are as for cp_finish_decl. */ @@ -723,8 +715,8 @@ finish_static_data_member_decl (tree decl, 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 && TREE_PUBLIC (decl)) - note_vague_linkage_var (decl); + if (! processing_template_decl) + VEC_safe_push (tree, gc, pending_statics, decl); if (LOCAL_CLASS_P (current_class_type)) pedwarn ("local class %q#T shall not have static data member %q#D", diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 68b45a291ecae77666f469e434578b502d7604df..98eaa25b066650f78e6a08f88fec472b0e5b51d9 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2006-07-16 Jakub Jelinek <jakub@redhat.com> + + PR c++/28370 + * g++.dg/template/anon3.C: New test. + 2006-07-16 Paul Thomas <pault@gcc.gnu.org> PR fortran/20844 diff --git a/gcc/testsuite/g++.dg/template/anon3.C b/gcc/testsuite/g++.dg/template/anon3.C new file mode 100644 index 0000000000000000000000000000000000000000..eee7acd820f69a94429a03826ec137775ec65c8e --- /dev/null +++ b/gcc/testsuite/g++.dg/template/anon3.C @@ -0,0 +1,20 @@ +// PR c++/28370 +// { dg-do run } + +namespace +{ + template<typename T> struct A { static int *a; }; + template<typename T> int *A<T>::a = 0; +} + +int * +foo () +{ + return A<int>::a; +} + +int +main () +{ + return foo() != 0; +}