5 #ifndef VCCC_ALGORITHM_RANGES_POP_HEAP_HPP_
6 #define VCCC_ALGORITHM_RANGES_POP_HEAP_HPP_
31 struct pop_heap_niebloid {
32 template<
typename I,
typename S,
typename Comp = ranges::less,
typename Proj = identity, std::enable_if_t<conjunction<
33 random_access_iterator<I>,
35 sortable<I, Comp, Proj>
37 constexpr I operator()(I
first, S last, Comp comp = {}, Proj proj = {})
const {
50 template<
typename R,
typename Comp = ranges::less,
typename Proj = identity, std::enable_if_t<conjunction<
51 random_access_range<R>,
52 sortable<iterator_t<R>, Comp, Proj>
54 constexpr borrowed_iterator_t<R> operator()(R&& r, Comp comp = {}, Proj proj = {})
const {
constexpr VCCC_INLINE_OR_STATIC detail::pop_heap_niebloid pop_heap
Definition: pop_heap.hpp:64
constexpr invoke_result_t< F, Args... > invoke(F &&f, Args &&... args) noexcept(is_nothrow_invocable< F, Args... >::value)
Definition: invoke.hpp:38
constexpr VCCC_INLINE_OR_STATIC detail::next_niebloid next
Definition: next.hpp:65
constexpr VCCC_INLINE_OR_STATIC detail::begin_niebloid begin
returns an iterator to the beginning of a range
Definition: begin.hpp:116
constexpr VCCC_INLINE_OR_STATIC detail::end_niebloid end
returns a sentinel indicating the end of a range
Definition: end.hpp:120
#define VCCC_INLINE_OR_STATIC
Definition: inline_or_static.hpp:9
Definition: directory.h:12
constexpr VCCC_INLINE_OR_STATIC detail::element_niebloid< 0 > first
Definition: key_value.hpp:34
constexpr VCCC_INLINE_OR_STATIC detail::element_niebloid< 1 > value
Definition: key_value.hpp:35