------- Additional Comments From jozef at syncad dot com 2005-03-30 14:56
-------
Subject: Re: namespace bug
Hi,
This is not about the same :
7.3.4.5
d1++; // shows that there is a conflict between a symbol in your
// namespace and a symbol imported using using namespace
f(1); // shows that there is a conflict between two symbols;
// both imported from two namespaces; one directly,
// the second transitively
None of the errors indicated show that there is a conflict
between a symbol imported from a namespace and a symbol
from a higher level namespace.
But the example in the first paragraph clearly states that
the imported names hide names from the higher levels:
7.3.4.1
i = 5; // OK, C::i visible in B and hides A::i
7.3.4.5 does not conflict with 7.3.4.1. It still looks
to me reasonable that the names imported using namespace have higher
precedence than names inherited from a higher level namespace
(this would be similar to the fact that the names defined
in a namespace have higher precedence to the names inherited
from a higher level namespaces).
One more argument is that this feature is required to compile correctly STLport.
pinskia at gcc dot gnu dot org wrote:
> ------- Additional Comments From pinskia at gcc dot gnu dot org 2005-03-29
> 19:51 -------
> The reduced testcase:
> namespace dd {
> struct t1 {};
> }
> namespace ff {
> using namespace dd;
> }
> struct t1 { };
> namespace ff
> {
> typedef t1 t2;
> }
>
>
> But the use of t1 is ambiguous really as "using namespace" is not as strong
> as defining the t1 in the
> namespace ff or doing a "using dd::t1" in the namespace ff.
>
Can you provide some reference to the standard for this claim, please?
Regards,
Jozef
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=20687