Defined in header <ranges> | ||
---|---|---|
template< ranges::range R > using borrowed_iterator_t = /* see below */; | (1) | (since C++20) |
template< ranges::range R > using borrowed_subrange_t = /* see below */; | (2) | (since C++20) |
std::ranges::subrange<std::ranges::iterator_t<R>>
if R
models borrowed_range
, std::ranges::dangling
otherwise.These two alias templates are used by some constrained algorithms to avoid returning potentially dangling iterators or views.
First version |
---|
template< std::ranges::range R > using borrowed_iterator_t = std::conditional_t<std::ranges::borrowed_range<R>, std::ranges::iterator_t<R>, std::ranges::dangling>; |
Second version |
template< std::ranges::range R > using borrowed_subrange_t = std::conditional_t<std::ranges::borrowed_range<R>, std::ranges::subrange<std::ranges::iterator_t<R>>, std::ranges::dangling>; |
(C++20) | a placeholder type indicating that an iterator or a subrange should not be returned since it would be dangling (class) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
https://en.cppreference.com/w/cpp/ranges/borrowed_iterator_t