toHash => pure, nothrow, const, @safe

Timon Gehr timon.gehr at gmx.ch
Tue Mar 13 16:25:03 PDT 2012


On 03/13/2012 11:39 PM, kennytm wrote:
> Andrei Alexandrescu<SeeWebsiteForEmail at erdani.org>  wrote:
>> On 3/13/12 6:02 AM, Peter Alexander wrote:
>>> On Monday, 12 March 2012 at 09:40:15 UTC, Walter Bright wrote:
>>>> On 3/12/2012 1:08 AM, Martin Nowak wrote:
>>>>> What's wrong with auto-inference. Inferred attributes are only
>>>>> strengthening
>>>>> guarantees.
>>>>
>>>> Auto-inference is currently done for lambdas and template functions -
>>>> why? - because the function's implementation is guaranteed to be
>>>> visible to the compiler. For other functions, not so, and so the
>>>> attributes must be part of the function signature.
>>>
>>> Dumb question:
>>>
>>> Why not auto-infer when the function body is available, and put the
>>> inferred attributes into the automatically generated .di file?
>>>
>>> Apologies if I've missed something completely obvious.
>>
>> Because in the general case functions call one another so there's no way
>> to figure which to look at first.
>>
>> Andrei
>
> That's no difference from template functions calling each others right?
>
>      int a()(int x) { return x==0?1:b(x-1); }
>      int b()(int x) { return x==0?1:a(x-1); }

http://d.puremagic.com/issues/show_bug.cgi?id=7205

The non-trivial issue is what to do with compile-time reflection in the 
function body. I think during reflection, the function should appear 
non-annotated to itself and all functions with inferred attributes it 
calls transitively through other functions with inferred attributes 
regardless of whether or not they are later inferred. (currently 
inference fails spectacularly for anything inside a typeof expression 
anyway, therefore it is not yet that much of an issue.)

pragma(msg, typeof({writeln("hello world");})); // "void function() pure 
@safe"


More information about the Digitalmars-d mailing list