phobos dependencies
monarch_dodra
monarchdodra at gmail.com
Fri Dec 20 11:10:19 PST 2013
On Friday, 20 December 2013 at 17:57:46 UTC, Andrei Alexandrescu
wrote:
> On 12/20/13 9:38 AM, H. S. Teoh wrote:
>> What about extending symbol lookup, so that if a
>> fully-qualified
>> symbol x.y.z can't be found in the current symbol tables, and
>> x/y exists
>> in the current import path, then implicitly try to import x.y
>> and lookup
>> z in that module. Then you could just write:
>>
>> void f(T)(T t) if (std.range.isInputRange!T) ...
>
> Due to a bug that's actually the case today to some extent :o).
>
>
> Andrei
In regards to template restraints, it *would* be kind of nice to
be able to trigger import only when overload resolution begins.
For example, just because a function requires
"std.range.isInputRange" to validate its inputs/overloads,
doesn't mean it *has* to be globally imported into the entire
module.
In this sense, it would be nice to be able to define an "import"
block for such a function:
//----
module wow;
void bar(T)(T t)
if (isInputRange!T)
import
{
std.range;
}
body
{
....
}
void foo()
{
....
}
//----
With such an approach, "std.range" only gets imported if a call
is "attempted" to bar. if no such call is even attempted, then
range isn't imported at all.
In this example, "foo" simply does not know about range. It is
scoped to bar.
As a client, *if* I make no calls to bar, then I will not trigger
a dependency to range in wow at all.
More information about the Digitalmars-d
mailing list