.sort vs sort(): std.algorithm not up to the task?

Stanislav Blinov via Digitalmars-d-learn digitalmars-d-learn at puremagic.com
Wed Jun 7 19:21:03 PDT 2017


On Thursday, 8 June 2017 at 01:57:47 UTC, Andrew Edwards wrote:
> Ranges may be finite or infinite but, while the destination may 
> be unreachable, we can definitely tell how far we've traveled. 
> So why doesn't this work?
>
> import std.traits;
> import std.range;
>
> void main()
> {
>     string[string] aa;
>
>     // what others have referred to as
>     // standard sort works but is deprecated
>     //auto keys = aa.keys.sort;
>
>     // Error: cannot infer argument types, expected 1 argument, 
> not 2
>     import std.algorithm: sort;
>     auto keys = aa.keys.sort();
>
>     // this works but why should I have to?
>     //import std.array: array;
>     //auto keys = aa.keys.sort().array;
>
>     foreach (i, v; keys){}
> }
>
> If I hand you a chihuahua for grooming, why am I getting back a 
> pit bull? I simply want a groomed chihuahua. Why do I need to 
> consult a wizard to get back a groomed chihuahua?

aa.keys.sort() should just work as is: aa.keys returns a 
string[], and that's a random access range that can be sorted. 
What exactly is the error?


More information about the Digitalmars-d-learn mailing list