Header file range/v3/view/drop_while.hpp

#include <meta/meta.hpp>

#include <range/v3/range_fwd.hpp>

#include <range/v3/range_traits.hpp>

#include <range/v3/range_concepts.hpp>

#include <range/v3/view_interface.hpp>

#include <range/v3/utility/optional.hpp>

#include <range/v3/utility/functional.hpp>

#include <range/v3/utility/semiregular.hpp>

#include <range/v3/utility/static_const.hpp>

#include <range/v3/algorithm/find_if_not.hpp>

#include <range/v3/view/all.hpp>

#include <range/v3/view/view.hpp>

namespace ranges
{
    inline namespace v3
    {
        template <typename Rng, typename Pred>
        struct drop_while_view;
        
        namespace view
        {
            struct drop_while_fn
            {
                template <typename Rng, typename Pred>
                using Concept = meta::and_<InputRange<Rng>, IndirectCallablePredicate<Pred, range_iterator_t<Rng>>>;
                
                template <typename Rng, typename Pred, int _concept_requires_118 = 42, typename std::enable_if<(_concept_requires_118==43)||(Concept<Rng, Pred>()), int>::type=0>
                drop_while_view<all_t<Rng>, Pred> operator()(Rng&& rng, Pred pred) const;
                
                template <typename Rng, typename Pred, int _concept_requires_126 = 42, typename std::enable_if<(_concept_requires_126==43)||(!Concept<Rng, Pred>()), int>::type=0>
                void operator()(Rng&&, Pred) const;
            };
            
            inline namespace 
            {
                constexpr auto& drop_while = static_const<view<drop_while_fn>>::value;
            }
        }
    }
}

Class template ranges::v3::drop_while_view<Rng, Pred>

template <typename Rng, typename Pred>
struct drop_while_view
: view_interface<drop_while_view<Rng, Pred>, is_finite<Rng>::value ? finite : unknown>
{
    drop_while_view() = default;
    
    drop_while_view(drop_while_view&& that);
    
    drop_while_view(drop_while_view const& that);
    
    drop_while_view(Rng rng, Pred pred);
    
    drop_while_view& operator=(drop_while_view&& that);
    
    drop_while_view& operator=(drop_while_view const& that);
    
    range_iterator_t<Rng> begin();
    
    range_sentinel_t<Rng> end();
    
    Rng& base();
    
    Rng const& base() const;
};

@{

Function ranges::v3::drop_while_view<Rng, Pred>::base

Rng const& base() const;

@}