From: jason Date: Mon, 10 Jun 2013 19:38:42 +0000 (+0000) Subject: * name-lookup.c (add_decl_to_level): Add decls in an anonymous X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=52306b37a14376f9c016cbde5825538159abb964;p=thirdparty%2Fgcc.git * name-lookup.c (add_decl_to_level): Add decls in an anonymous namespace to static_decls. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@199906 138bc75d-0d04-0410-961f-82ee72b054a4 --- diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index ebf71796504b..02451538a988 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2013-06-10 Jason Merrill + + * name-lookup.c (add_decl_to_level): Add decls in an anonymous + namespace to static_decls. + 2013-06-07 Sriraman Tallam PR c++/57548 diff --git a/gcc/cp/name-lookup.c b/gcc/cp/name-lookup.c index 17d5ca265165..2b1f9fbf3186 100644 --- a/gcc/cp/name-lookup.c +++ b/gcc/cp/name-lookup.c @@ -597,7 +597,9 @@ add_decl_to_level (tree decl, cp_binding_level *b) if ((VAR_P (decl) && (TREE_STATIC (decl) || DECL_EXTERNAL (decl))) || (TREE_CODE (decl) == FUNCTION_DECL - && (!TREE_PUBLIC (decl) || DECL_DECLARED_INLINE_P (decl)))) + && (!TREE_PUBLIC (decl) + || decl_anon_ns_mem_p (decl) + || DECL_DECLARED_INLINE_P (decl)))) vec_safe_push (b->static_decls, decl); } } diff --git a/gcc/testsuite/g++.dg/warn/anonymous-namespace-5.C b/gcc/testsuite/g++.dg/warn/anonymous-namespace-5.C new file mode 100644 index 000000000000..6f5a081d89e7 --- /dev/null +++ b/gcc/testsuite/g++.dg/warn/anonymous-namespace-5.C @@ -0,0 +1,8 @@ +namespace { + void f(); // { dg-message "never defined" } +} + +int main() +{ + f(); +}