[libcxx-commits] [libcxx] [libcxx] implement LWG4148: unique_ptr::operator* should not allow dangling references (PR #128213)
A. Jiang via libcxx-commits
libcxx-commits at lists.llvm.org
Sat Feb 22 08:46:59 PST 2025
================
@@ -261,7 +261,10 @@ class _LIBCPP_UNIQUE_PTR_TRIVIAL_ABI _LIBCPP_TEMPLATE_VIS unique_ptr {
}
_LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX23 __add_lvalue_reference_t<_Tp> operator*() const
- _NOEXCEPT_(_NOEXCEPT_(*std::declval<pointer>())) {
+ _NOEXCEPT_(_NOEXCEPT_(*std::declval<pointer>()))
+ // TODO: use reference_converts_from_temporary_v once implemented.
----------------
frederick-vs-ja wrote:
But `reference_converts_from_temporary_v` shouldn't be available before C++23. If you decide to add the `static_assert` in old modes, it may be more consistent (and less verbose) to solely use the intrinsic.
https://github.com/llvm/llvm-project/pull/128213
More information about the libcxx-commits
mailing list