DIP 36: Rvalue References
Zach the Mystic
reachzach at gggggmail.com
Wed Apr 10 00:39:23 PDT 2013
On Wednesday, 10 April 2013 at 05:21:40 UTC, Manu wrote:
> struct X { int *p; }
> int* global;
>
> void func(scope X x) // note: is not ref
> {
> global = x.p; // <- error! scope prevents any part of x
> escaping, even
> though it's a copy.
> }
>
> This way, scope has meaning with or without ref.
I think this is a subtle point, but I don't think it's correct. I
think there's a difference between 'x.p' above, and what '&x.p'
or '&x' would give. I think 'scope' should guarantee that you
won't assign the *address* of the passed-in parameter:
void func(scope X x, ref X y) {
static X* xx = &x; // Error
static int** xpp = &x.p; // Error
xx = &y; // unsafe, but pass
xpp = &y.p; // same
}
I don't think it should guarantee that you won't copy something
that is *already* a pointer. Copying the pointer may be
dangerous, but I don't think 'scope' will be very useful if it's
supposed to track the internal pointers of aggregate types like
that. I think somebody else has to make sure that pointer is
safe. I could be wrong.
More information about the Digitalmars-d
mailing list