<div dir="auto"><div><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, 11 Oct 2024, 18:36 Jonathan M Davis via Digitalmars-d, <<a href="mailto:digitalmars-d@puremagic.com">digitalmars-d@puremagic.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">On Friday, October 11, 2024 1:25:53 AM MDT Manu via Digitalmars-d wrote:<br>
> > Aside from whatever Walter's reasoning is, there are existing constructors<br>
> > in the wild which use<br>
> ><br>
> >     this(S)<br>
><br>
> I had a moment to think on this case you present.<br>
> It's not clear to me how it actually works now; but I think it would be<br>
> interesting to explore that first; because I think the solution for this<br>
> case being reinterpreted as move-constructor is related (and equally<br>
> solved).<br>
><br>
> This function receives it's arg BY-VALUE; so it can happily accept an<br>
> r-value... but it's not actually clear how this function receives an lvalue<br>
> even in today's language?<br>
> In order for this function to receive an l-value by-value, it must first<br>
> make a copy to supply as the function's argument (but the function is<br>
> allowed to internally mutate its argument)..<br>
><br>
> ...but isn't *this* said to be the copy constructor?<br>
><br>
> This already looks like a chicken/egg problem in today's language... how<br>
> does it create a copy of an lvalue to pass the argument to this function<br>
> without calling this function?<br>
> Whatever answer exists that makes this work equally makes the case work<br>
> where this is reinterpreted as a move-constructor.<br>
><br>
> The only explanation I can imagine is; because this ISN'T actually a copy<br>
> constructor, the compiler determined that it was appropriate to synthesise<br>
> one (which would be to just copy all members), and so an implicit copy<br>
> constructor DOES actually exist beside this constructor, you just didn't<br>
> write it.<br>
> And assuming that's the case, when this becomes reinterpreted as a move<br>
> constructor, the code remains perfectly correct!<br>
><br>
> I don't see how elevating this declaration to a move-constructor actually<br>
> changes the semantics at all... I don't think it does? I think this<br>
> function ALREADY IS A MOVE CONSTRUCTOR (at least; it's an<br>
> rvalue-constructor, which is the same thing from a semantic perspective);<br>
> it's just working with an inefficient calling convention.<br>
> Move semantics as proposed simply improve this code, no?<br>
<br>
No, as far as the language is concerned, it's not a copy constructor, but it<br>
also isn't necessarily a move constructor. In the case that I've described,<br></blockquote></div></div><div dir="auto"><br></div><div dir="auto">I think it actually is a move constructor... can you explain how it compiles and works differently than what I say? </div><div dir="auto">You'll need to show me that my hypothesis is wrong...</div><div dir="auto"><br></div><div dir="auto"><br></div><div dir="auto"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
it might work as a move constructor, but there's no guarantee that all<br>
constructors with that signature would.</blockquote></div></div><div dir="auto"><br></div><div dir="auto">Yeah no, I think you're just wrong here. It's exactly a move constructor from a semantic perspective. It receives only rvalues, and the argument belongs to the callee, which can do whatever it likes with it.</div><div dir="auto">It's literally a move constructor with a retarded calling convention... unless my hypothesis about how it compiles at all is wrong?</div><div dir="auto"><br></div><div dir="auto"><br></div><div dir="auto"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Also, the constructor is question is<br>
likely to be a template, which will then probably not play well with what<br>
Walter is trying to do (e.g. copy constructors can't currently be templated,<br>
because that doesn't work unless copy constructors have a unique syntax,<br>
which they don't). As Razvan explained in this thread, in order for copy<br>
constructors (or move constructors) to be allowed to be templates, they<br>
really need a distinct syntax, otherwise the compiler can't know that they<br>
are in fact copy constructors or move constructors until they're<br>
instantiated, which causes a variety of issues.<br></blockquote></div></div><div dir="auto"><br></div><div dir="auto">They're all copy or move constructor of some flavour; just not the single special case one that the compiler recognises to suppress it's generation of the default one... they can all exist beside each other subject to functioning overload selection rules.</div><div dir="auto"><br></div><div dir="auto">Any constructor that receives any arg by value is a move constructor for all intents and purposes.</div><div dir="auto"><br></div><div dir="auto"><br></div><div dir="auto"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
Honestly, as a user, I see _zero_ benefit in trying to treat either copy<br>
constructors or move constructors like they're normal constructors.</blockquote></div></div><div dir="auto"><br></div><div dir="auto">Uniformity of semantics. Special cases are bad.</div><div dir="auto"><br></div><div dir="auto"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">They are<br>
treated as special by the compiler in a variety of ways,</blockquote></div></div><div dir="auto"><br></div><div dir="auto">In exactly one way that we were both able to identify, are there actually other cases?</div><div dir="auto"><br></div><div dir="auto"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"> and I want them to<br>
be visually distinct so that it's clear that they exist. It would also be<br>
nice if the compiler gave me an error when I screwed up a copy constructor<br>
or move constructor in a way that it wouldn't work as one for whatever<br>
reason (e.g. getting ref wrong by accident). A big part of the problem with<br>
the current copy constructors is that it really isn't easy to see at a<br>
glance which constructors are copy constructors. And the fact that they<br>
can't be templated is a _huge_ problem, particularly with regards to<br>
attributes.<br>
<br>
While the syntax =this() isn't necessarily great (personally, I'd probably<br>
just vote for using @move for move constructors and then change it so that<br>
copy constructors should have @copy), I see nothing but problems from not<br>
making copy and move constructors distinct and obvious.<br>
<br>
- Jonathan M Davis<br></blockquote></div></div><div dir="auto"><br></div><div dir="auto">Look, I'm not critically opposed to a special case for the special functions names *if we absolutely do need it and that's just not a lower level design error that we're further compounding*... but I'm absolutely not sold and I think it's a mistake to blindly accept it.</div><div dir="auto"><br></div><div dir="auto">But... and as I mentioned in my response to Walter; reading between the lines, it starts to look like the move semantics somehow uniquely apply to the move constructor and not generally, which is completely insufficient. That's not "move semantics", and it suggests that my reading of the DIP left me with the completely wrong impression.</div><div dir="auto"><br></div><div dir="auto">The move semantic described by the dip should apply to every rvalue everywhere; they're all potential move targets.</div><div dir="auto"><br></div><div dir="auto">Especially so for your weird not-a-move-constructor-but-actually-a-move-constructor that receives T by value; it's the exact definition of a move constructor, and it should be the case that concretely proves that it is also the exact proper syntax for the declaration!</div><div dir="auto"><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
</blockquote></div></div></div>