Skip to content

Commit

Permalink
[libc++] Simplify the implementation of is_null_pointer a bit (#98728)
Browse files Browse the repository at this point in the history
  • Loading branch information
philnik777 authored Jul 16, 2024
1 parent 0eebb48 commit 30cc12c
Show file tree
Hide file tree
Showing 3 changed files with 5 additions and 11 deletions.
2 changes: 1 addition & 1 deletion libcxx/include/__type_traits/is_fundamental.h
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ inline constexpr bool is_fundamental_v = __is_fundamental(_Tp);

template <class _Tp>
struct _LIBCPP_TEMPLATE_VIS is_fundamental
: public integral_constant<bool, is_void<_Tp>::value || __is_nullptr_t<_Tp>::value || is_arithmetic<_Tp>::value> {};
: public integral_constant<bool, is_void<_Tp>::value || __is_null_pointer_v<_Tp> || is_arithmetic<_Tp>::value> {};

# if _LIBCPP_STD_VER >= 17
template <class _Tp>
Expand Down
12 changes: 3 additions & 9 deletions libcxx/include/__type_traits/is_null_pointer.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@

#include <__config>
#include <__type_traits/integral_constant.h>
#include <__type_traits/remove_cv.h>
#include <cstddef>

#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)
Expand All @@ -21,20 +20,15 @@
_LIBCPP_BEGIN_NAMESPACE_STD

template <class _Tp>
struct __is_nullptr_t_impl : public false_type {};
template <>
struct __is_nullptr_t_impl<nullptr_t> : public true_type {};

template <class _Tp>
struct _LIBCPP_TEMPLATE_VIS __is_nullptr_t : public __is_nullptr_t_impl<__remove_cv_t<_Tp> > {};
inline const bool __is_null_pointer_v = __is_same(__remove_cv(_Tp), nullptr_t);

#if _LIBCPP_STD_VER >= 14
template <class _Tp>
struct _LIBCPP_TEMPLATE_VIS is_null_pointer : public __is_nullptr_t_impl<__remove_cv_t<_Tp> > {};
struct _LIBCPP_TEMPLATE_VIS is_null_pointer : integral_constant<bool, __is_null_pointer_v<_Tp>> {};

# if _LIBCPP_STD_VER >= 17
template <class _Tp>
inline constexpr bool is_null_pointer_v = is_null_pointer<_Tp>::value;
inline constexpr bool is_null_pointer_v = __is_null_pointer_v<_Tp>;
# endif
#endif // _LIBCPP_STD_VER >= 14

Expand Down
2 changes: 1 addition & 1 deletion libcxx/include/__type_traits/is_scalar.h
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ struct _LIBCPP_TEMPLATE_VIS is_scalar
bool, is_arithmetic<_Tp>::value ||
is_member_pointer<_Tp>::value ||
is_pointer<_Tp>::value ||
__is_nullptr_t<_Tp>::value ||
__is_null_pointer_v<_Tp> ||
__is_block<_Tp>::value ||
is_enum<_Tp>::value> {};
// clang-format on
Expand Down

0 comments on commit 30cc12c

Please sign in to comment.