From: Jakub Jelinek Date: Tue, 11 Dec 2007 08:22:10 +0000 (+0100) Subject: re PR c++/34238 ("static data member used, but not defined" error on member definition) X-Git-Tag: releases/gcc-4.3.0~1102 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=5b767b9d0c2c2b2646aeadfa2c8156dde7a085fc;p=thirdparty%2Fgcc.git re PR c++/34238 ("static data member used, but not defined" error on member definition) PR c++/34238 * decl2.c (cp_write_global_declarations): Revert 2007-11-22 change. * g++.dg/ext/visibility/anon7.C: Add xfail. * g++.dg/ext/visibility/anon9.C: New test. * g++.dg/ext/visibility/anon10.C: New test. From-SVN: r130771 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index f55b06a45833..f8df2b23919e 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,5 +1,8 @@ 2007-12-11 Jakub Jelinek + PR c++/34238 + * decl2.c (cp_write_global_declarations): Revert 2007-11-22 change. + PR c++/34364 * rtti.c (build_dynamic_cast): Call convert_from_reference even for dynamic_cast in a template. diff --git a/gcc/cp/decl2.c b/gcc/cp/decl2.c index 37a21f7040de..97b3ee0f3f25 100644 --- a/gcc/cp/decl2.c +++ b/gcc/cp/decl2.c @@ -3366,21 +3366,7 @@ cp_write_global_declarations (void) /* If this static data member is needed, provide it to the back end. */ if (DECL_NOT_REALLY_EXTERN (decl) && decl_needed_p (decl)) - { - /* Error on - namespace { struct A { static int i; }; } - int foo () { return A::i; } - without A::i definition (which can't be defined in - a different CU because of the anonymous namespace). - Don't do this if DECL_INITIAL is set, because for - namespace { struct A { static const int i = 4; } }; - decl_needed_p won't reliably detect whether it was - really needed. */ - if (DECL_IN_AGGR_P (decl) && DECL_INITIAL (decl) == NULL_TREE) - error ("%Jstatic data member %qD used, but not defined", - decl, decl); - DECL_EXTERNAL (decl) = 0; - } + DECL_EXTERNAL (decl) = 0; } if (VEC_length (tree, pending_statics) != 0 && wrapup_global_declarations (VEC_address (tree, pending_statics), diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 663a059da018..e6c5b41ba9ad 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,5 +1,10 @@ 2007-12-11 Jakub Jelinek + PR c++/34238 + * g++.dg/ext/visibility/anon7.C: Add xfail. + * g++.dg/ext/visibility/anon9.C: New test. + * g++.dg/ext/visibility/anon10.C: New test. + PR c++/34364 * g++.dg/rtti/dyncast2.C: New test. diff --git a/gcc/testsuite/g++.dg/ext/visibility/anon10.C b/gcc/testsuite/g++.dg/ext/visibility/anon10.C new file mode 100644 index 000000000000..8c79631b0a99 --- /dev/null +++ b/gcc/testsuite/g++.dg/ext/visibility/anon10.C @@ -0,0 +1,44 @@ +// http://bugzilla.redhat.com/411871 +// { dg-do compile } + +extern "C" int printf (const char *, ...); + +struct E +{ + template E (const volatile T&); + template E (T&); + char x[64]; +}; + +template struct D +{ + static E foo (E, ...); + static int foo (T, int); +}; + +template struct C +{ + static T ca; + static const int value = sizeof (D::foo (ca, 0)) == sizeof (int); +}; + +struct A +{ + int a; +}; + +namespace +{ + struct B + { + int a; + }; +} + +int bar (void) +{ + C a; + C b; + + return a.value + b.value; +} diff --git a/gcc/testsuite/g++.dg/ext/visibility/anon7.C b/gcc/testsuite/g++.dg/ext/visibility/anon7.C index 23a915b4b6b2..0c42ea866f9b 100644 --- a/gcc/testsuite/g++.dg/ext/visibility/anon7.C +++ b/gcc/testsuite/g++.dg/ext/visibility/anon7.C @@ -5,7 +5,7 @@ namespace { struct A { static int bar (); - static int i; // { dg-error "used, but not defined" } + static int i; // { dg-error "used, but not defined" "" { xfail *-*-* } } static int j; static int k; static int l; diff --git a/gcc/testsuite/g++.dg/ext/visibility/anon9.C b/gcc/testsuite/g++.dg/ext/visibility/anon9.C new file mode 100644 index 000000000000..bb752253b680 --- /dev/null +++ b/gcc/testsuite/g++.dg/ext/visibility/anon9.C @@ -0,0 +1,11 @@ +// PR c++/34238 +// { dg-do compile } + +namespace +{ + template struct A + { + static const bool a = true; + }; +} +struct A<> a;