deductionguidesforstd::ranges::lazy_split_view(3) | C++ Standard Libary | deductionguidesforstd::ranges::lazy_split_view(3) |
NAME¶
deductionguidesforstd::ranges::lazy_split_view - deductionguidesforstd::ranges::lazy_split_view
Synopsis¶
template< class R, class P >
lazy_split_view( R&&, P&& ) (1) (since
C++20)
-> lazy_split_view<views::all_t<R>, views::all_t<P>>;
template< ranges::input_range R >
lazy_split_view( R&&, ranges::range_value_t<R> )
-> lazy_split_view<views::all_t<R>, (2) (since
C++20)
ranges::single_view<ranges::range_value_t<R>>>;
These deduction guides are provided for lazy_split_view to allow deduction
from a
range and a delimiter.
1) The delimiter is a range of elements.
2) The delimiter is a single element.
Example¶
// Run this code
#include <ranges>
#include <string_view>
#include <type_traits>
using std::operator""sv;
int main()
{
std::ranges::lazy_split_view w1{"a::b::c"sv, "::"sv};
// type of w1 is lazy_split_view<string_view, string_view>:
static_assert(std::is_same_v<
decltype(w1),
std::ranges::lazy_split_view<
std::basic_string_view<char, std::char_traits<char>>,
std::basic_string_view<char,
std::char_traits<char>>>>);
std::ranges::lazy_split_view w2{"x,y,z"sv, ','};
// type of w2 is lazy_split_view<string_view, single_view<char>>:
static_assert(std::is_same_v<
decltype(w2),
std::ranges::lazy_split_view<
std::basic_string_view<char, std::char_traits<char>>,
std::ranges::single_view<char>>>);
}
2024.06.10 | http://cppreference.com |