std::ranges::concat_view<Views...>::end
constexpr
auto end(
)
requires ( ! ( /*simple-view*/ <Views> && ...) ) ; |
(1) | (since C++26) |
constexpr
auto end(
)
const
requires (
ranges::range
<
const Views>
&& ...)
&&
|
(2) | (since C++26) |
Returns an iterator or std::default_sentinel that compares equal to the past-the-end iterator of the concat_view
constexpr auto N = sizeof...(Views);
if
constexpr
(
ranges::common_range
<Views...[N -
1
]
>
)
return
iterator
<
false
>
(this, std::in_place_index
<N -
1
>
ranges::end
(std::
get
<N -
1
>
(
views_
)));
else
return std::default_sentinel;
constexpr auto N = sizeof...(Views);
if
constexpr
(
ranges::common_range
<
const Views...[N -
1
]
>
)
return
iterator
<
true
>
(this, std::in_place_index
<N -
1
>
ranges::end
(std::
get
<N -
1
>
(
views_
)));
else
return std::default_sentinel;
Return value
As described above.
Example
The preliminary version can be checked out on Compiler Explorer.
#include <concepts> #include <iterator> #include <ranges> int main() { static constexpr int p[]{37, 42, 69}; static constexpr auto q = {19937, 1729}; constexpr auto cat = std::ranges::views::concat(p, q); static_assert(not std::same_as<std::default_sentinel_t, decltype(cat.end())>); static_assert(cat.end()[-1] == 1729); }
See also
returns an iterator to the beginning (public member function) |
|
(C++20)
|
returns a sentinel indicating the end of a range (customization point object) |