writeThis really shouldn't be const, it should be shared.  The problem was that 
making writeThis a shared pass by value param implied a synchronized load for 
writeThis, which is undesirable for cas. So I left the declaration of cas as 
specified in TDPL and thought I'd figure this out later. 

Sent from my iPhone

On Oct 31, 2011, at 9:06 AM, Stanislav Blinov <stanislav.bli...@gmail.com> 
wrote:

> I've been looking into cas recently and I came to wonder why it doesn't 
> provide actual support for pointers.
> 
> The current declaration of cas looks roughly like this:
> 
> bool cas(shared(T)* here, const V1 ifThis, const V2 writeThis) if 
> (__traits(compiles,mixin("*here = writeThis")))
> 
> which, with transitive const, means that if T, V1 and V2 are, say, X*, then 
> this declaration would be equivalent to
> 
> bool cas(shared(X*)* here, const(X*) ifThis, const(X*) writeThis) if 
> (__traits(compiles,mixin("*here = writeThis")))
> 
> and as such, __traits(compiles) here will obviously return false, as you 
> cannot assign const pointer to a non-const one. For example, you would not be 
> able to compile even examples from Andrei's book.
> 
> I wonder if there is some overwhelming reason why this is so, or is it just 
> that current implementation lacks specialization for pointers?

Reply via email to