diff --git a/libcxx/include/atomic b/libcxx/include/atomic --- a/libcxx/include/atomic +++ b/libcxx/include/atomic @@ -1561,7 +1561,7 @@ mutable __cxx_atomic_impl<_Tp> __a_; #if defined(__cpp_lib_atomic_is_always_lock_free) - static _LIBCPP_CONSTEXPR bool is_always_lock_free = __atomic_always_lock_free(sizeof(__a_), 0); + static _LIBCPP_CONSTEXPR bool is_always_lock_free = __atomic_always_lock_free(sizeof(__a_), nullptr); #endif _LIBCPP_INLINE_VISIBILITY @@ -2664,7 +2664,7 @@ // atomic_*_lock_free : prefer the contention type most highly, then the largest lock-free type #ifdef __cpp_lib_atomic_is_always_lock_free -# define _LIBCPP_CONTENTION_LOCK_FREE __atomic_always_lock_free(sizeof(__cxx_contention_t), 0) +# define _LIBCPP_CONTENTION_LOCK_FREE __atomic_always_lock_free(sizeof(__cxx_contention_t), nullptr) #else # define _LIBCPP_CONTENTION_LOCK_FREE false #endif @@ -2691,7 +2691,9 @@ typedef atomic<__libcpp_unsigned_lock_free> atomic_unsigned_lock_free; #endif +#undef ATOMIC_FLAG_INIT #define ATOMIC_FLAG_INIT {false} +#undef ATOMIC_VAR_INIT #define ATOMIC_VAR_INIT(__v) {__v} #if _LIBCPP_STD_VER > 17 && !defined(_LIBCPP_DISABLE_DEPRECATION_WARNINGS) diff --git a/libcxx/include/cmath b/libcxx/include/cmath --- a/libcxx/include/cmath +++ b/libcxx/include/cmath @@ -531,8 +531,8 @@ #if _LIBCPP_STD_VER > 14 inline _LIBCPP_INLINE_VISIBILITY float hypot( float __x, float __y, float __z ) { return sqrt(__x*__x + __y*__y + __z*__z); } -inline _LIBCPP_INLINE_VISIBILITY double hypot( double __x, double __y, double __z ) { return sqrt(__x*__x + __y*__y + __z*__z); } -inline _LIBCPP_INLINE_VISIBILITY long double hypot( long double __x, long double __y, long double __z ) { return sqrt(__x*__x + __y*__y + __z*__z); } +inline _LIBCPP_INLINE_VISIBILITY double hypot( double __x, double __y, double __z ) { return sqrtf(__x*__x + __y*__y + __z*__z); } +inline _LIBCPP_INLINE_VISIBILITY long double hypot( long double __x, long double __y, long double __z ) { return sqrtl(__x*__x + __y*__y + __z*__z); } template inline _LIBCPP_INLINE_VISIBILITY diff --git a/libcxx/include/string b/libcxx/include/string --- a/libcxx/include/string +++ b/libcxx/include/string @@ -808,7 +808,7 @@ public: _LIBCPP_TEMPLATE_DATA_VIS - static const size_type npos = -1; + static const size_type npos = numeric_limits::max(); _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_AFTER_CXX17 basic_string() _NOEXCEPT_(is_nothrow_default_constructible::value); diff --git a/libcxx/include/string_view b/libcxx/include/string_view --- a/libcxx/include/string_view +++ b/libcxx/include/string_view @@ -285,7 +285,7 @@ typedef const_reverse_iterator reverse_iterator; typedef size_t size_type; typedef ptrdiff_t difference_type; - static _LIBCPP_CONSTEXPR const size_type npos = -1; // size_type(-1); + static _LIBCPP_CONSTEXPR const size_type npos = numeric_limits::max(); // size_type(-1); static_assert((!is_array::value), "Character type of basic_string_view must not be an array"); static_assert(( is_standard_layout::value), "Character type of basic_string_view must be standard-layout"); diff --git a/libcxx/include/variant b/libcxx/include/variant --- a/libcxx/include/variant +++ b/libcxx/include/variant @@ -318,7 +318,7 @@ using type = __type_pack_element<_Ip, _Types...>; }; -inline constexpr size_t variant_npos = static_cast(-1); +inline constexpr size_t variant_npos = numeric_limits::max(); constexpr int __choose_index_type(unsigned int __num_elem) { if (__num_elem < numeric_limits::max()) diff --git a/libcxx/utils/libcxx/test/params.py b/libcxx/utils/libcxx/test/params.py --- a/libcxx/utils/libcxx/test/params.py +++ b/libcxx/utils/libcxx/test/params.py @@ -16,6 +16,10 @@ '-Wextra', '-Wshadow', '-Wundef', + '-Wimplicit-float-conversion', + '-Wmacro-redefined', + '-Wsign-conversion', + '-Wzero-as-null-pointer-constant', '-Wno-unused-command-line-argument', '-Wno-attributes', '-Wno-pessimizing-move',