[libcxx-commits] [PATCH] D116023: [libc++][ranges] Implement `uninitialized_copy{, _n}` and `uninitialized_move{, _n}`.

Konstantin Varlamov via Phabricator via libcxx-commits libcxx-commits at lists.llvm.org
Mon Jan 10 21:18:05 PST 2022


var-const added inline comments.


================
Comment at: libcxx/include/__memory/ranges_uninitialized_algorithms.h:182
 inline namespace __cpo {
 inline constexpr auto uninitialized_fill = __uninitialized_fill::__fn(__function_like::__tag());
 } // namespace __cpo
----------------
Quuxplusone wrote:
> Does this just need to be rebased? I think I remember fixing that `fil` to `fill` as a drive-by, too.
> Ditto throughout: I believe we agreed (at least for now) not to indent the big namespace but to leave the one-liner indented. Anyway, please look at the existing code (as it is now in `main`, not how it was last month ;)) and let's be consistent with whatever it looks like.
Done.

After some thinking, I still feel that having special rules for special cases adds more complexity than it's worth. Would a new programmer starting on the code base be able to figure out the reason for the inconsistency? Are we realistically going to document the rationale for all the special cases? I feel the answer to both is more likely no than yes.


================
Comment at: libcxx/include/__memory/ranges_uninitialized_algorithms.h:237
+
+  // clang-format off
+  template <input_range _InputRange, __nothrow_forward_range _OutputRange>
----------------
Quuxplusone wrote:
> Please remove all `clang-format` comments.
I'd rather leave these in. `clang-format` doesn't format `requires` clauses well. I understand you're not a big fan of `clang-format`, but removing those statements after they're already added seems a little overkill.


================
Comment at: libcxx/include/__memory/uninitialized_algorithms.h:30
+  template <class _Iter>
+  _LIBCPP_HIDE_FROM_ABI friend _LIBCPP_CONSTEXPR bool operator!=(const _Iter&, __unreachable_sentinel) _NOEXCEPT {
+    return true;
----------------
Quuxplusone wrote:
> I suspect the `_NOEXCEPT` is useless and thus should be removed; but I'm not sure. (Which is why I'd rather it hadn't been there at all! [Frost's corollary to Chesterton's Fence](https://www.youtube.com/watch?v=OQgFEkgKx2s&t=780s): it's going to take more work to remove a fence [keyword] than to erect one unnecessarily, so let's make sure we're only erecting the necessary ones.)
This class mimics `std::unreachable_sentinel_t` which [does define](https://eel.is/c++draft/unreachable.sentinel) its `operator==` as `noexcept`. I'd rather be consistent with the standard class, for simplicity if nothing else.


================
Comment at: libcxx/include/__memory/uninitialized_algorithms.h:37-39
+template <class _ValueType, class _InputIterator, class _Sentinel1, class _ForwardIterator, class _Sentinel2>
+inline _LIBCPP_HIDE_FROM_ABI pair<_InputIterator, _ForwardIterator>
+__uninitialized_copy(_InputIterator __ifirst, _Sentinel1 __ilast, _ForwardIterator __ofirst, _Sentinel2 __olast) {
----------------
Quuxplusone wrote:
> and so on throughout — let's not go out of our way to fit everything in 80 columns, but let's not go out of our way to shove everything onto one line either :)
Done, but I'm not very happy with the change. If we say that we're using 120 columns width, we should be using it.


================
Comment at: libcxx/test/std/algorithms/algorithms.results/in_out_result.pass.cpp:23-30
+#ifndef _LIBCPP_ABI_MICROSOFT // [[no_unique_address]] currently isn't implemented on Windows.
+// Size optimization.
+struct Empty {};
+struct Empty2 {};
+static_assert(sizeof(std::ranges::in_out_result<int, Empty>) == sizeof(int));
+static_assert(sizeof(std::ranges::in_out_result<Empty, int>) == sizeof(int));
+static_assert(sizeof(std::ranges::in_out_result<Empty, Empty2>) == sizeof(char));
----------------
Quuxplusone wrote:
> I remember a similar issue in the `in_in_result` review. Is this consistent with what we landed on there? (I don't //think// it is...?)
Made it consistent and copied a group of tests from that patch. Thanks for bringing this up!


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D116023/new/

https://reviews.llvm.org/D116023



More information about the libcxx-commits mailing list