From: Patrick Palka Date: Fri, 23 Oct 2020 13:03:25 +0000 (-0400) Subject: libstdc++: Apply proposed resolutions for LWG 3428, 3447 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=50106208ff65fe8076329169cd97460a03e27388;p=gcc.git 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. --- 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>;