re PR c++/28370 (undefined reference to template class static variable in an anonymou...
authorJakub Jelinek <jakub@redhat.com>
Sun, 16 Jul 2006 20:17:20 +0000 (22:17 +0200)
committerJakub Jelinek <jakub@gcc.gnu.org>
Sun, 16 Jul 2006 20:17:20 +0000 (22:17 +0200)
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.

* g++.dg/template/anon3.C: New test.

From-SVN: r115503

gcc/cp/ChangeLog
gcc/cp/decl2.c
gcc/testsuite/ChangeLog
gcc/testsuite/g++.dg/template/anon3.C [new file with mode: 0644]

index 0dd1e8ca4c26a3ed4a7f6e56cf88eafdcf3218aa..d1eb30fea24edb8e3fe20e11993d0451c08f06bf 100644 (file)
@@ -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
index f1a8a77431cda8c76f5e69c8355bb4cc751478de..dfb30f25d936d38e3550eb26eb9eeaa4ba267d1c 100644 (file)
@@ -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",
index 68b45a291ecae77666f469e434578b502d7604df..98eaa25b066650f78e6a08f88fec472b0e5b51d9 100644 (file)
@@ -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 (file)
index 0000000..eee7acd
--- /dev/null
@@ -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;
+}