Namespaces
Variants

deduction guides for std::ranges::lazy_split_view

From cppreference.net
Ranges library
Range adaptors
template < class R, class P >

lazy_split_view ( R && , P && )

- > lazy_split_view < views:: all_t < R > , views:: all_t < P >> ;
(1) (depuis C++20)
template < ranges:: input_range R >

lazy_split_view ( R && , ranges:: range_value_t < R > )
- > lazy_split_view < views:: all_t < R > ,

ranges:: single_view < ranges:: range_value_t < R >>> ;
(2) (depuis C++20)

Ces guides de déduction sont fournis pour lazy_split_view afin de permettre la déduction à partir d'une plage et d'un délimiteur.

1) Le délimiteur est une plage d'éléments.
2) Le délimiteur est un élément unique.

Exemple

#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 de w1 est 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 de w2 est 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>>>);
}