Thread overview
[Issue 24562] inout on the copy constructor makes it so that a normal opAssign does not work with multiple layers of objects
May 25, 2024
Jonathan M Davis
May 27, 2024
RazvanN
May 25, 2024
https://issues.dlang.org/show_bug.cgi?id=24562

Jonathan M Davis <issues.dlang@jmdavisProg.com> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
           Severity|blocker                     |major

--- Comment #1 from Jonathan M Davis <issues.dlang@jmdavisProg.com> ---
Okay. In our current situation we were able to work around the issue via explicit opAssigns, so I reduce this from being marked as a blocker, but in cases where you're dealing with templated code outside your control, that won't work. So, this is still a major issue.

--
May 27, 2024
https://issues.dlang.org/show_bug.cgi?id=24562

RazvanN <razvan.nitu1305@gmail.com> changed:

           What    |Removed                     |Added
----------------------------------------------------------------------------
                 CC|                            |razvan.nitu1305@gmail.com

--- Comment #2 from RazvanN <razvan.nitu1305@gmail.com> ---
(In reply to Jonathan M Davis from comment #1)
> Okay. In our current situation we were able to work around the issue via explicit opAssigns, so I reduce this from being marked as a blocker, but in cases where you're dealing with templated code outside your control, that won't work. So, this is still a major issue.

My hunch is that the generated opAssign is probably using some code internally that copy constructs an instance of S1 but it mismatches some qualifiers. Deleting the copy constructor probably fixes this because it can then do some implicit blitting. Will check now.

--
December 13
https://issues.dlang.org/show_bug.cgi?id=24562

--- Comment #3 from dlangBugzillaToGithub <robert.schadek@posteo.de> ---
THIS ISSUE HAS BEEN MOVED TO GITHUB

https://github.com/dlang/dmd/issues/20457

DO NOT COMMENT HERE ANYMORE, NOBODY WILL SEE IT, THIS ISSUE HAS BEEN MOVED TO GITHUB

--