From 97dc8e5b5775cbb4aba4a7d7456844c15ad5d6b0 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Fri, 24 Aug 2007 01:27:34 +0200 Subject: re PR c++/32898 (Definition of variable N::i outside namespace N not rejected) PR c++/32898 * name-lookup.c (set_decl_namespace): lookup_qualified_name failure is error_mark_node rather than NULL_TREE. * pt.c (check_explicit_specialization): Likewise. * g++.dg/lookup/ns3.C: New test. From-SVN: r127749 --- gcc/cp/pt.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) (limited to 'gcc/cp/pt.c') diff --git a/gcc/cp/pt.c b/gcc/cp/pt.c index b4a9b68..2594e7d 100644 --- a/gcc/cp/pt.c +++ b/gcc/cp/pt.c @@ -1980,7 +1980,7 @@ check_explicit_specialization (tree declarator, context. */ fns = lookup_qualified_name (CP_DECL_CONTEXT (decl), dname, false, true); - if (!fns || !is_overloaded_fn (fns)) + if (fns == error_mark_node || !is_overloaded_fn (fns)) { error ("%qD is not a template function", dname); fns = error_mark_node; @@ -2215,6 +2215,8 @@ check_explicit_specialization (tree declarator, /* This specialization has the same linkage and visibility as the function template it specializes. */ TREE_PUBLIC (decl) = TREE_PUBLIC (tmpl_func); + if (! TREE_PUBLIC (decl) && DECL_INTERFACE_KNOWN (tmpl_func)) + DECL_INTERFACE_KNOWN (decl) = 1; DECL_THIS_STATIC (decl) = DECL_THIS_STATIC (tmpl_func); if (DECL_VISIBILITY_SPECIFIED (tmpl_func)) { -- cgit v1.1