[libcxx-commits] [libcxx] [libc++] Fix ambiguity due to non-uglified member typedefs (PR #121664)

A. Jiang via libcxx-commits libcxx-commits at lists.llvm.org
Thu Jan 9 02:50:54 PST 2025


================
@@ -75,8 +75,10 @@ template <class, class _Cp, bool _IsConst, class _Tp, class _Proj, __enable_if_t
 _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 __iter_diff_t<__bit_iterator<_Cp, _IsConst> >
 __count(__bit_iterator<_Cp, _IsConst> __first, __bit_iterator<_Cp, _IsConst> __last, const _Tp& __value, _Proj&) {
   if (__value)
-    return std::__count_bool<true>(__first, static_cast<typename _Cp::size_type>(__last - __first));
-  return std::__count_bool<false>(__first, static_cast<typename _Cp::size_type>(__last - __first));
+    return std::__count_bool<true>(
+        __first, static_cast<typename __size_difference_type_traits<_Cp>::size_type>(__last - __first));
+  return std::__count_bool<false>(
----------------
frederick-vs-ja wrote:

How about just making `__bit_iterator` have `__size_type` and using `__bit_iterator<_Cp, _IsConst>::__size_type`? (Perhaps even pretty name `size_type` is OK, but it seems conventional that iterator types have no `size_type`.)

https://github.com/llvm/llvm-project/pull/121664


More information about the libcxx-commits mailing list