Bug 42490 - using-directive in namespace doesn't work properly
Summary: using-directive in namespace doesn't work properly
Status: RESOLVED FIXED
Alias: None
Product: gcc
Classification: Unclassified
Component: c++ (show other bugs)
Version: 4.5.0
: P3 normal
Target Milestone: ---
Assignee: Not yet assigned to anyone
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2009-12-24 15:01 UTC by Eelis
Modified: 2016-10-22 11:25 UTC (History)
3 users (show)

See Also:
Host:
Target:
Build:
Known to work:
Known to fail:
Last reconfirmed: 2010-01-07 21:05:41


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Eelis 2009-12-24 15:01:24 UTC
Consider:

  namespace B { struct C {}; }
  namespace A { namespace C { } using namespace B; }
  struct A::C c;

GCC complains:

  error: 'C' in namespace 'A' does not name a type

Not knowing much about the subtleties of name lookup myself, I'm relying on the following two sources for the code's well-formed-ness:

* Comeau 4.3.10.1 /does/ accept the code.
* The opinion of a particularly well-read regular (litb) on Freenode's C++ IRC channel.
Comment 1 Jonathan Wakely 2010-01-07 21:05:41 UTC
I think the code is valid

3.4.4 [basic.lookup.elab]/1
An elaborated-type-specifier (7.1.6.3) may be used to refer to a
previously declared class-name or enum-name even though the name has
been hidden by a non-type declaration (3.3.10).
Comment 2 Johannes Schaub 2010-02-11 23:28:15 UTC
I also think the code is valid. In this case though, there is the complication that no hiding takes place: The qualified name lookup of "X::m" for namespace members says in 3.4.3.2/2: "using-directives are ignored in any namespace, including X, directly containing one or more declarations of m". That would mean that "using namespace B;" is ignored, because "C" is declared as a namespace there. 

But 3.4.4/3 says: "If the name is a qualified-id, the name is looked up according its qualifications, as described in 3.4.3, but ignoring any non-type names that have been declared.". That is, the declaration of the namespace is ignored, thus not preventing the consideration of the using directive. 
Comment 3 Johannes Schaub 2010-02-11 23:39:02 UTC
(In reply to comment #2)
> I also think the code is valid. In this case though, there is the complication
> that no hiding takes place [...]
> 

Wasn't aware that this is also a case of hiding, but 3.3.10 about hiding actually even contains it. 
Comment 4 Eelis 2016-10-22 11:25:24 UTC
Seems to be fixed, thanks!