Friends | |
template<bool B = true, typename Stream = meta::if_c<B, std::ostream>> | |
Stream & | operator<< (Stream &sout, Derived &rng) |
Print a range to an ostream. | |
template<bool B = true, typename Stream = meta::if_c<B, std::ostream>, typename D = Derived, requires = (InputRange<D const>())> | |
Stream & | operator<< (Stream &sout, Derived const &rng) |
template<bool B = true, typename Stream = meta::if_c<B, std::ostream>> | |
Stream & | operator<< (Stream &sout, Derived &&rng) |
Public Member Functions | |
template<typename D = Derived, requires = (Same<D, Derived>() && BoundedRange<D>() && BidirectionalRange<D>())> | |
range_reference_t< D > | back () |
Access the last element in a range: | |
template<typename D = Derived, requires = (Same<D, Derived>() && BoundedRange<D const>() && BidirectionalRange<D const>())> | |
range_reference_t< D const > | back () const |
constexpr bool | empty () const |
template<class D = Derived, requires = (Same<D, Derived>() && Cardinality < 0 && ForwardRange<D const>())> | |
constexpr bool | empty () const |
template<typename D = Derived, requires = (Same<D, Derived>() && ForwardRange<D>())> | |
range_reference_t< D > | front () |
Access the first element in a range: | |
template<typename D = Derived, requires = (Same<D, Derived>() && ForwardRange<D const>())> | |
range_reference_t< D const > | front () const |
template<class D = Derived, requires = (Same<D, Derived>() && (Cardinality >= 0 || ForwardRange<D const>()))> | |
constexpr | operator bool () const |
template<typename Container , typename D = Derived, typename = typename Container::allocator_type, requires = (detail::ConvertibleToContainer<D, Container>())> | |
operator Container () | |
Implicit conversion to something that looks like a container. | |
template<typename Container , typename D = Derived, typename = typename Container::allocator_type, requires = (detail::ConvertibleToContainer<D const, Container>())> | |
operator Container () const | |
template<class D = Derived, requires = (Same<D, Derived>() && (Cardinality >= 0 || ForwardRange<D const>()))> | |
constexpr bool | operator! () const |
view_interface & | operator= (view_interface &&)=default |
view_interface & | operator= (view_interface const &)=default |
template<typename D = Derived, requires = (Same<D, Derived>() && RandomAccessRange<D>())> | |
auto | operator[] (range_difference_type_t< D > n) -> decltype(std::declval< D &>().begin()[n]) |
Simple indexing: | |
template<typename D = Derived, requires = (Same<D, Derived>() && RandomAccessRange<D const>())> | |
auto | operator[] (range_difference_type_t< D > n) const -> decltype(std::declval< D const &>().begin()[n]) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< range_difference_type_t< D >> offs) &-> decltype(std::declval< Slice >()(std::declval< D &>(), offs.from, offs.to)) |
Python-ic slicing: | |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< range_difference_type_t< D >> offs) const &-> decltype(std::declval< Slice >()(std::declval< D const &>(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< range_difference_type_t< D >> offs) &&-> decltype(std::declval< Slice >()(std::declval< D >(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< range_difference_type_t< D >, detail::from_end_< range_difference_type_t< D >>> offs) &-> decltype(std::declval< Slice >()(std::declval< D &>(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< range_difference_type_t< D >, detail::from_end_< range_difference_type_t< D >>> offs) const &-> decltype(std::declval< Slice >()(std::declval< D const &>(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< range_difference_type_t< D >, detail::from_end_< range_difference_type_t< D >>> offs) &&-> decltype(std::declval< Slice >()(std::declval< D >(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, detail::from_end_< range_difference_type_t< D >>> offs) &-> decltype(std::declval< Slice >()(std::declval< D &>(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, detail::from_end_< range_difference_type_t< D >>> offs) const &-> decltype(std::declval< Slice >()(std::declval< D const &>(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, detail::from_end_< range_difference_type_t< D >>> offs) &&-> decltype(std::declval< Slice >()(std::declval< D >(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< range_difference_type_t< D >, end_fn > offs) &-> decltype(std::declval< Slice >()(std::declval< D &>(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< range_difference_type_t< D >, end_fn > offs) const &-> decltype(std::declval< Slice >()(std::declval< D const &>(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< range_difference_type_t< D >, end_fn > offs) &&-> decltype(std::declval< Slice >()(std::declval< D >(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, end_fn > offs) &-> decltype(std::declval< Slice >()(std::declval< D &>(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, end_fn > offs) const &-> decltype(std::declval< Slice >()(std::declval< D const &>(), offs.from, offs.to)) |
template<typename D = Derived, typename Slice = view::slice_fn, requires = (Same<D, Derived>())> | |
auto | operator[] (detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, end_fn > offs) &&-> decltype(std::declval< Slice >()(std::declval< D >(), offs.from, offs.to)) |
template<typename D = Derived, requires = (Same<D, Derived>() && Cardinality >= 0)> | |
constexpr range_size_type_t< D > | size () const |
Access the size of the range, if it can be determined: | |
template<typename D = Derived, requires = (Same<D, Derived>() && Cardinality < 0 && SizedSentinel<sentinel_t<D const>, iterator_t<D const>>() && ForwardRange<D const>())> | |
constexpr range_size_type_t< D > | size () const |
view_interface (view_interface &&)=default | |
view_interface (view_interface const &)=default | |
Protected Member Functions | |
Derived & | derived () |
Derived const & | derived () const |
|
friend |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
|
friend |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
range_reference_t<D const> ranges::v3::view_interface< Derived, Cardinality >::back | ( | ) | const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
|
protected |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
constexpr bool ranges::v3::view_interface< Derived, Cardinality >::empty | ( | ) | const |
Referenced by ranges::v3::intersperse_view< Rng >::cursor_adaptor::advance().
range_reference_t<D const> ranges::v3::view_interface< Derived, Cardinality >::front | ( | ) | const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
ranges::v3::view_interface< Derived, Cardinality >::operator Container | ( | ) | const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | range_difference_type_t< D > | n | ) | const -> decltype(std::declval<D const &>().begin()[n]) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< range_difference_type_t< D >> | offs | ) | const & -> decltype(std::declval<Slice>()(std::declval<D const &>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< range_difference_type_t< D >> | offs | ) | && -> decltype(std::declval<Slice>()(std::declval<D>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< range_difference_type_t< D >, detail::from_end_< range_difference_type_t< D >>> | offs | ) | & -> decltype(std::declval<Slice>()(std::declval<D &>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< range_difference_type_t< D >, detail::from_end_< range_difference_type_t< D >>> | offs | ) | const & -> decltype(std::declval<Slice>()(std::declval<D const &>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< range_difference_type_t< D >, detail::from_end_< range_difference_type_t< D >>> | offs | ) | && -> decltype(std::declval<Slice>()(std::declval<D>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, detail::from_end_< range_difference_type_t< D >>> | offs | ) | & -> decltype(std::declval<Slice>()(std::declval<D &>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, detail::from_end_< range_difference_type_t< D >>> | offs | ) | const & -> decltype(std::declval<Slice>()(std::declval<D const &>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, detail::from_end_< range_difference_type_t< D >>> | offs | ) | && -> decltype(std::declval<Slice>()(std::declval<D>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< range_difference_type_t< D >, end_fn > | offs | ) | & -> decltype(std::declval<Slice>()(std::declval<D &>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< range_difference_type_t< D >, end_fn > | offs | ) | const & -> decltype(std::declval<Slice>()(std::declval<D const &>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< range_difference_type_t< D >, end_fn > | offs | ) | && -> decltype(std::declval<Slice>()(std::declval<D>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, end_fn > | offs | ) | & -> decltype(std::declval<Slice>()(std::declval<D &>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, end_fn > | offs | ) | const & -> decltype(std::declval<Slice>()(std::declval<D const &>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
auto ranges::v3::view_interface< Derived, Cardinality >::operator[] | ( | detail::slice_bounds< detail::from_end_< range_difference_type_t< D >>, end_fn > | offs | ) | && -> decltype(std::declval<Slice>()(std::declval<D>(), offs.from, offs.to)) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.