diff --git a/stl/inc/chrono b/stl/inc/chrono index 69d0f848fc..0744254385 100644 --- a/stl/inc/chrono +++ b/stl/inc/chrono @@ -58,20 +58,19 @@ namespace chrono { }; #if _HAS_CXX20 + template + inline constexpr bool _Is_clock_v = false; + template - concept _Is_clock = requires { - typename _Clock::rep; - typename _Clock::period; - typename _Clock::duration; - typename _Clock::time_point; - _Clock::is_steady; - _Clock::now(); - }; + inline constexpr bool + _Is_clock_v<_Clock, void_t> = + true; // TRANSITION, GH-602 template - struct is_clock : bool_constant<_Is_clock<_Clock>> {}; + struct is_clock : bool_constant<_Is_clock_v<_Clock>> {}; template - inline constexpr bool is_clock_v = _Is_clock<_Clock>; + inline constexpr bool is_clock_v = _Is_clock_v<_Clock>; #endif // _HAS_CXX20 // CLASS TEMPLATE duration diff --git a/stl/inc/sstream b/stl/inc/sstream index 90ce15f8ea..51763b89b6 100644 --- a/stl/inc/sstream +++ b/stl/inc/sstream @@ -168,7 +168,7 @@ public: } #if _HAS_CXX20 - template <_Allocator _Alloc2> + template ::value, int> = 0> _NODISCARD basic_string<_Elem, _Traits, _Alloc2> str(const _Alloc2& _Al) const { return basic_string<_Elem, _Traits, _Alloc2>{view(), _Al}; } @@ -632,7 +632,7 @@ public: } #if _HAS_CXX20 - template <_Allocator _Alloc2> + template ::value, int> = 0> _NODISCARD basic_string<_Elem, _Traits, _Alloc2> str(const _Alloc2& _Al) const { return _Stringbuffer.str(_Al); } @@ -752,7 +752,7 @@ public: } #if _HAS_CXX20 - template <_Allocator _Alloc2> + template ::value, int> = 0> _NODISCARD basic_string<_Elem, _Traits, _Alloc2> str(const _Alloc2& _Al) const { return _Stringbuffer.str(_Al); } @@ -878,7 +878,7 @@ public: } #if _HAS_CXX20 - template <_Allocator _Alloc2> + template ::value, int> = 0> _NODISCARD basic_string<_Elem, _Traits, _Alloc2> str(const _Alloc2& _Al) const { return _Stringbuffer.str(_Al); } diff --git a/stl/inc/xutility b/stl/inc/xutility index 2179e1251f..28a06fabfc 100644 --- a/stl/inc/xutility +++ b/stl/inc/xutility @@ -1459,11 +1459,6 @@ using _Enable_if_execution_policy_t = typename remove_reference_t<_ExPo>::_Stand #endif // _HAS_CXX17 -#if _HAS_CXX20 -template -concept _Allocator = _Is_allocator<_Ty>::value; -#endif // _HAS_CXX20 - // FUNCTION TEMPLATE _Idl_distance template _NODISCARD constexpr auto _Idl_distance(const _Iter& _First, const _Iter& _Last) {