Details
- Reviewers
ldionne Mordante var-const - Group Reviewers
Restricted Project - Commits
- rG64748efc2740: [libc++] Use _LIBCPP_ASSERT by default for _PSTL_ASSERTions
Diff Detail
- Repository
- rG LLVM Github Monorepo
Event Timeline
LGTM with the different approach.
libcxx/include/__assert | ||
---|---|---|
51–53 | I would rather not start pretending that _PSTL_ASSERT is a customization point. Instead, I think we should do something like this inside pstl_config.h: #if defined(_LIBCPP_VERSION) # define _PSTL_ASSERT(pred) _LIBCPP_ASSERT(pred, "") #elif defined(__GLIBCXX__) # // does libstdc++ want something special? if so, they can add it here #else # include <cassert> # define _PSTL_ASSERT(pred) (assert((pred))) #endif |
pstl/include/pstl/internal/pstl_config.h | ||
---|---|---|
33–34 ↗ | (On Diff #430640) | Makes sense to me in principle, although I think __glibcxx_assert is the wrong definition (even though that's what we use today). I see several assertions in parallel_backend_tbb.h like _PSTL_ASSERT(std::is_sorted(_M_x_beg + _M_xs, _M_x_beg + _M_xe, _M_comp)); which changes the complexity guarantees of the algo. That's not appropriate for __glibcxx_assert, but would be appropriate for the more heavyweight _GLIBCXX_DEBUG_ASSERT. Maybe that should be fixed as a separate issue, as I assume that isn't appropriate for libc++ either. We could introduce _PSTL_DEBUG_ASSERT for the more expensive assertions, and map that to _LIBCPP_DEBUG_ASSERT or _GLIBCXX_DEBUG_ASSERT. |
pstl/include/pstl/internal/pstl_config.h | ||
---|---|---|
33–34 ↗ | (On Diff #430640) | I'm going to take this as a yes. I think adding _PSTL_DEBUG_ASSERT or something similar should be deferred to after having added a CI configuration with the PSTL enabled, so we actually check it instead of hoping that it works. |
I would rather not start pretending that _PSTL_ASSERT is a customization point. Instead, I think we should do something like this inside pstl_config.h: