mirror of
https://github.com/yuzu-emu/ext-boost.git
synced 2025-01-05 17:35:41 +00:00
58 lines
1.5 KiB
C++
58 lines
1.5 KiB
C++
//////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// (C) Copyright Ion Gaztanaga 2016-2016. Distributed under the Boost
|
|
// Software License, Version 1.0. (See accompanying file
|
|
// LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
//
|
|
// See http://www.boost.org/libs/container for documentation.
|
|
//
|
|
//////////////////////////////////////////////////////////////////////////////
|
|
#ifndef BOOST_CONTAINER_DETAIL_IS_SORTED_HPP
|
|
#define BOOST_CONTAINER_DETAIL_IS_SORTED_HPP
|
|
|
|
#ifndef BOOST_CONFIG_HPP
|
|
# include <boost/config.hpp>
|
|
#endif
|
|
|
|
#if defined(BOOST_HAS_PRAGMA_ONCE)
|
|
# pragma once
|
|
#endif
|
|
|
|
namespace boost {
|
|
namespace container {
|
|
namespace container_detail {
|
|
|
|
template <class ForwardIterator, class Pred>
|
|
bool is_sorted (ForwardIterator first, ForwardIterator last, Pred pred)
|
|
{
|
|
if(first != last){
|
|
ForwardIterator next = first;
|
|
while (++next != last){
|
|
if(pred(*next, *first))
|
|
return false;
|
|
++first;
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
template <class ForwardIterator, class Pred>
|
|
bool is_sorted_and_unique (ForwardIterator first, ForwardIterator last, Pred pred)
|
|
{
|
|
if(first != last){
|
|
ForwardIterator next = first;
|
|
while (++next != last){
|
|
if(!pred(*first, *next))
|
|
return false;
|
|
++first;
|
|
}
|
|
}
|
|
return true;
|
|
}
|
|
|
|
} //namespace container_detail {
|
|
} //namespace container {
|
|
} //namespace boost {
|
|
|
|
#endif //#ifndef BOOST_CONTAINER_DETAIL_IS_SORTED_HPP
|