///////////////// test.d ///////////////// struct S { int[5] i; // must be 5 or greater } void main() { void delegate() dg; (){ S s = {[1,2,3,4,5]}; auto pS = &s; dg = { assert(*pS == S([1,2,3,4,5])); }; }(); dg(); } ////////////////////////////////////////// The assection
(In reply to Vladimir Panteleev from comment #0) > The assection The assertion fails, presumably because the memory referenced by the pointer is no longer valid.
> presumably because the memory referenced by the pointer is no longer valid. Exactly, but that's to be expected, as it's not captured. The problem is rather that this isn't caught when making everything @safe with -dip1000 - the compiler should complain that the address of local `s` is assigned to a heap closure `pS` with longer lifetime.
(In reply to kinke from comment #2) > Exactly, but that's to be expected, as it's not captured. The problem is > rather that this isn't caught when making everything @safe with -dip1000 - > the compiler should complain that the address of local `s` is assigned to a > heap closure `pS` with longer lifetime. Not sure what you mean by this. s and pS should both be in the closure. As far as I can see, the code is valid even with @safe/-dip1000, and no warning should be emitted.
Oh, does the compiler only put referenced variables in the closure? I thought it was the entire frame. Now this makes sense.
This looks like the same problem as https://issues.dlang.org/show_bug.cgi?id=8538
*** This issue has been marked as a duplicate of issue 8538 ***