Path: blob/main/contrib/llvm-project/libcxx/include/__algorithm/is_heap.h
35233 views
//===----------------------------------------------------------------------===//1//2// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.3// See https://llvm.org/LICENSE.txt for license information.4// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception5//6//===----------------------------------------------------------------------===//78#ifndef _LIBCPP___ALGORITHM_IS_HEAP_H9#define _LIBCPP___ALGORITHM_IS_HEAP_H1011#include <__algorithm/comp.h>12#include <__algorithm/comp_ref_type.h>13#include <__algorithm/is_heap_until.h>14#include <__config>15#include <__iterator/iterator_traits.h>1617#if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER)18# pragma GCC system_header19#endif2021_LIBCPP_BEGIN_NAMESPACE_STD2223template <class _RandomAccessIterator, class _Compare>24_LIBCPP_NODISCARD inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 bool25is_heap(_RandomAccessIterator __first, _RandomAccessIterator __last, _Compare __comp) {26return std::__is_heap_until(__first, __last, static_cast<__comp_ref_type<_Compare> >(__comp)) == __last;27}2829template <class _RandomAccessIterator>30_LIBCPP_NODISCARD inline _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR_SINCE_CXX20 bool31is_heap(_RandomAccessIterator __first, _RandomAccessIterator __last) {32return std::is_heap(__first, __last, __less<>());33}3435_LIBCPP_END_NAMESPACE_STD3637#endif // _LIBCPP___ALGORITHM_IS_HEAP_H383940