On Sun, Sep 21, 2014 at 02:55:47PM +0200, Timon Gehr via Digitalmars-d wrote:
> On 09/21/2014 07:29 AM, deadalnix wrote:
> >
> >Free goodie: when you import, all symbol are resolved via the
> >expected import resolution mechanism. All ? No, the root package is
> >imported in the local scope.
> >
> >foo(int a) {
> >   import a.b.c;
> >   // a is now a package and not the parameter a anymore.
> >}
> 
> For local imports, DMD imports _all_ symbols into the local scope,
> shadowing anything that was there, which is plain broken (as Sӧnke's
> example shows).  BTW: how do you suggest to treat the root package? I
> think importing into the local scope is fine, but the above example
> should emit an error because the parameter and the package conflict.
> 
> (The following code does not compile either:
> int std;
> import std.conv;)

I also think it's OK to import symbols into the local scope, but I don't
think conflicts should cause errors immediately, only when you actually
try to reference an ambiguous symbol. I.e., this should work:

        string foo(string text) {
                import std.conv; // includes std.conv.text
                return "";      // but `text` is never referenced
        }

but this should emit an error:

        string foo(string text) {
                import std.conv; // includes std.conv.text
                return text;    // error: parameter `text` conflicts with 
std.conv.text
        }


T

-- 
In order to understand recursion you must first understand recursion.

Reply via email to