Proposal: Relax rules for 'pure'

Walter Bright newshound2 at digitalmars.com
Wed Sep 22 20:50:21 PDT 2010


Jesse Phillips wrote:
> Walter Bright Wrote:
> 
>> Steven Schveighoffer wrote:
>>>> A pure function also cannot modify any data via its parameters. In 
>>>> other words, its parameters must be transitively const.
>>> Yes, a strongly pure function must have those traits.
>> No, that would be a weakly pure one.
>> 
>>> But, purity exists to allow for optimization.  A weakly pure function 
>>> cannot be optimized anymore than a normal function, but a strongly pure 
>>> can still be optimized even if it calls weakly-pure functions.
>>> 
>>> I'll give you an example (with a new keyword to help you understand the 
>>> difference):
>>> 
>>> weaklypure void reverse(int[] x) { for(int i = 0; i * 2 < x.length; i++) 
>>> swap(x[i], x[$-1-i]); }
>>> 
>>> pure int foo(const(int)[] x) { auto x2 = x.dup; reverse(x2); // do some
>>> calculation on x2 ... return calculation; }
>>> 
>>> Hopefully you can see how foo still is pure, while being able to call 
>>> reverse.  Essentially, weakly-pure functions can be used to build 
>>> strongly-pure functions.
>> This isn't what I was talking about - you didn't modify the contents of the
>>  array x[].
> 
> The problem is that you can't call reverse or sort unless the function is
> 'pure,' but the function can not be pure because it modifies its own
> parameters which means his example function cannot be marked pure even though
> it is.


The function in the example does not modify its parameters.


More information about the Digitalmars-d mailing list