From 50106208ff65fe8076329169cd97460a03e27388 Mon Sep 17 00:00:00 2001 From: Patrick Palka Date: Fri, 23 Oct 2020 09:03:25 -0400 Subject: [PATCH] libstdc++: Apply proposed resolutions for LWG 3428, 3447 libstdc++-v3/ChangeLog: * include/std/ranges (single_view::single_view): Mark the in place constructor explicit as per LWG 3428. (take_view): Remove the constraint on the deduction guide's template parameter as per LWG 3447. --- libstdc++-v3/include/std/ranges | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/libstdc++-v3/include/std/ranges b/libstdc++-v3/include/std/ranges index 4d3a4940c6f..a3e5354848a 100644 --- a/libstdc++-v3/include/std/ranges +++ b/libstdc++-v3/include/std/ranges @@ -205,9 +205,11 @@ namespace ranges : _M_value(std::move(__t)) { } + // _GLIBCXX_RESOLVE_LIB_DEFECTS + // 3428. single_view's in place constructor should be explicit template requires constructible_from<_Tp, _Args...> - constexpr + constexpr explicit single_view(in_place_t, _Args&&... __args) : _M_value{in_place, std::forward<_Args>(__args)...} { } @@ -1801,7 +1803,10 @@ namespace views } }; - template + // _GLIBCXX_RESOLVE_LIB_DEFECTS + // 3447. Deduction guides for take_view and drop_view have different + // constraints + template take_view(_Range&&, range_difference_t<_Range>) -> take_view>; -- 2.30.2