Ranges

Yigal Chripun yigal100 at gmail.com
Fri Jun 19 11:26:46 PDT 2009


Steve Teale wrote:
> Robert Fraser Wrote:
> 
>> Steve Teale wrote:
>>> template isInputRange(R)
>>> {
>>>     enum bool isInputRange = is(typeof(
>>>     {
>>>         R r;             // can define a range object
>>>         if (r.empty) {}  // can test for empty
>>>         r.popFront;          // can invoke next
>>>         auto h = r.front; // can get the front of the range
>>>     }()));
>>> }
>>>
>>> I can not possibly be the only D enthusiast who finds this completely incomprehensible. 
>> Yeah, that one is a bit tricky, and what makes it worse is that it seems 
>> officially sanctioned by Walter/Andrei as the "right way" to check if a 
>> type supports some operations. Basically, if you have:
>>
>> is(typeof({ @@@ }()));
>>
>> this means "if I made a function containing @@@, would that function 
>> compile?". It's a hack which stems from the way the is expression works.
>>
>>> What is a range?
>> As others have mentioned, it's just a struct (or other type) that 
>> happens to support certain operations.
> 
> So does this mean that interfaces are just a tragic mistake. I'd always thought that what you said was a pretty good description of what an interface is!
> 

IMHO, duck-typing in D is a tragic mistake...  This should have been 
implemented with compile time interfaces.



More information about the Digitalmars-d mailing list