Adopt LWG3645, which fixes the value categories of basic_string::resize_and_overwrite
https://timsong-cpp.github.io/lwg-issues/3645
Details
- Reviewers
• Quuxplusone Mordante ldionne - Group Reviewers
Restricted Project - Commits
- rG48224475222d: [libc++] basic_string::resize_and_overwrite: Adopt LWG3645 (Not voted in yet)
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
FWIW, I think this is a good idea (and might motivate LWG to DTRT), but I'm biased. Let's see what @ldionne thinks.
Also, I don't know if @ldionne would want us to mention LWG3645 in some csv file, or say nothing until it's adopted (and of course that question becomes moot if we just defer landing this at all).
libcxx/test/std/strings/basic.string/string.capacity/resize_and_overwrite.pass.cpp | ||
---|---|---|
79 | You could actually add line 79 to the test today, right? It should work both before and after this patch. |
One of the problems with straying from our custom of never shipping something until it's in the Standard is that we don't have a process for doing it. For instance, if we make this change, do we just avoid marking the issue as implemented in the status files because there's no entry for it, and then we mark it as having been implemented since <some LLVM version> once the issue resolution lands in the Standard? That seems somewhat hand-wavy, and if we all died tomorrow (hopefully not), our successors wouldn't have a way to easily tell what happened without digging out this discussion.
This seems like a small enough issue that I wouldn't oppose shipping its resolution even before it's been voted officially, but if we did that, I would like to add an entry in the csv file to track issues we implement that haven't been voted yet.
[And once we have a nice place to put those, I would have a harder time fighting back people who want to ship stuff that's not in the Standard -- but I'm ready for it :-)]
libcxx/include/string | ||
---|---|---|
985 | WDYT about using _LIBCPP_AUTO_CAST here? It would be closest to the standard. |
To clarify, perhaps I'd suggest adding a new tag to https://libcxx.llvm.org/Status/Cxx2b.html saying something like not-voted-yet, or a new column. Or maybe another table after the LWG issues table. I don't mind the details, but I'd like *some* way of tracking what we're doing here.
libcxx/include/string | ||
---|---|---|
985 | You mean __erase_to_end(_VSTD::move(__op)(data(), _LIBCPP_AUTO_CAST(__n))); ? I think that's heavier-weight (in terms of #includes and template instantiations) than +__n, but I don't object. |
WDYT about using _LIBCPP_AUTO_CAST here? It would be closest to the standard.