challenge #2: implement the varargs_reduce metafunction

Andrei Alexandrescu (See Website For Email) SeeWebsiteForEmail at erdani.org
Tue Jan 23 16:56:07 PST 2007


Jarrett Billingsley wrote:
> "Andrei Alexandrescu (See Website for Email)" 
> <SeeWebsiteForEmail at erdani.org> wrote in message 
> news:ep4i7p$2n1t$4 at digitaldaemon.com...
>> My previous post defines max by availing itself of a metafunction called
>> varargs_reduce. Your challenge is to define it. varargs_reduce takes an
>> alias which it assumes is a function of two arguments, and it defines a
>> vararg function that applies that alias repeatedly, similarly to the
>> reduce primitive that is present in functional languages. Again, for
>> background on functional reduce, see e.g.:
>>
>> http://www.joelonsoftware.com/items/2006/08/01.html
>>
>> Define varargs_reduce to deduce the result type properly, and to generate 
>> code as efficient as possible.
>>
>>
>> Andrei
> 
> This post is not meant to be inflammatory.

Definitely not taken as such.

> Answer me this: are you just toying with us, tempting us with things which 
> are unimplementable without new features which are secretly being developed 
> for D?  Or are you just surreptitiously trying to get the community to write 
> a bunch of standard library metacode for you?  ;)

It's really easy. I can't right now disclose all of my agenda for 
objective reasons (I will do it later), but the gist of the matter is 
simple:

1. There are some simple tests for a language gaging very precisely the 
power of that language

2. I want D to pass those tests

3. I want to increase community's awareness of the importance of those 
tests for larger use cases, as well as gather ideas from the community 
about how to overcome D's shortcomings in passing the tests.

> How about this: start a thread in which you disclose all the fancy features 
> you (you plural, you and Walter, since you now seem to be the _team_ 
> designing D) have been planning.

We are doing it already, e.g. by describing my suggested max 
implementation. But I don't want to do that preemptively, because I'd 
bias future responses. I wished, for example, that somebody could 
suggest a better design instead of "storageof(T) T".

> For that matter, is coming up with crazy new features like inout returns and 
> opImplicitCast _all_ Walter's doing?  Or is he fixing bugs? 

Walter and I have been discussing these issues and we have agreement on 
the necessity of certain features (of which indeed better inout handling 
and opImplicitCast are two). At this point, we don't have much more of a 
design than what I've already shown. For all I know, Walter hasn't 
started implementing any of them.


Andrei



More information about the Digitalmars-d mailing list