On Monday, 27 October 2014 at 16:58:56 UTC, Szymon Gatner wrote:
On Monday, 27 October 2014 at 14:04:53 UTC, Marc Schütz wrote:
On Monday, 27 October 2014 at 12:40:17 UTC, Shachar Shemesh wrote:
On 27/10/14 11:31, Szymon Gatner wrote:

Right, sorry. Tho I admit I made assumptions since that was not the full
code.

I've opened a bug. It has a fully contained sample (that does not, in fact, implement smartptr).

https://issues.dlang.org/show_bug.cgi?id=13661

Strictly speaking, your opAssign is wrong, because it doesn't swap source and destination, as it should. This doesn't matter here, but it would for a smartptr.

However, that opAssign isn't even called is certainly a bug.

Why would opAssign() swap things?

This is necessary to make assignment exception safe (in the general case). It's known as the copy-and-swap idiom in C++. Here it's described in the D spec:

http://dlang.org/struct#assign-overload

For your example code it's not necessary, because there can never be exceptions, but depending on what the smart pointer does, it might throw in one of its members' opAssign, which could lead to a partially copied object.

Reply via email to