mirror of
https://github.com/boostorg/detail.git
synced 2025-07-31 21:04:27 +02:00
Merged more fixes from trunk; added is_sorted.hpp because that is needed for BGL fixes
[SVN r70704]
This commit is contained in:
56
include/boost/detail/is_sorted.hpp
Normal file
56
include/boost/detail/is_sorted.hpp
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
/*==============================================================================
|
||||||
|
Copyright (c) 2010-2011 Bryce Lelbach
|
||||||
|
|
||||||
|
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)
|
||||||
|
==============================================================================*/
|
||||||
|
|
||||||
|
#ifndef BOOST_DETAIL_SORTED_HPP
|
||||||
|
#define BOOST_DETAIL_SORTED_HPP
|
||||||
|
|
||||||
|
#include <boost/detail/iterator.hpp>
|
||||||
|
|
||||||
|
#include <functional>
|
||||||
|
|
||||||
|
namespace boost {
|
||||||
|
namespace detail {
|
||||||
|
|
||||||
|
template<class Iterator, class Comp>
|
||||||
|
inline Iterator is_sorted_until (Iterator first, Iterator last, Comp c) {
|
||||||
|
if (first == last)
|
||||||
|
return last;
|
||||||
|
|
||||||
|
Iterator it = first; ++it;
|
||||||
|
|
||||||
|
for (; it != last; first = it, ++it)
|
||||||
|
if (c(*it, *first))
|
||||||
|
return it;
|
||||||
|
|
||||||
|
return it;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<class Iterator>
|
||||||
|
inline Iterator is_sorted_until (Iterator first, Iterator last) {
|
||||||
|
typedef typename boost::detail::iterator_traits<Iterator>::value_type
|
||||||
|
value_type;
|
||||||
|
|
||||||
|
typedef std::less<value_type> c;
|
||||||
|
|
||||||
|
return ::boost::detail::is_sorted_until(first, last, c());
|
||||||
|
}
|
||||||
|
|
||||||
|
template<class Iterator, class Comp>
|
||||||
|
inline bool is_sorted (Iterator first, Iterator last, Comp c) {
|
||||||
|
return ::boost::detail::is_sorted_until(first, last, c) == last;
|
||||||
|
}
|
||||||
|
|
||||||
|
template<class Iterator>
|
||||||
|
inline bool is_sorted (Iterator first, Iterator last) {
|
||||||
|
return ::boost::detail::is_sorted_until(first, last) == last;
|
||||||
|
}
|
||||||
|
|
||||||
|
} // detail
|
||||||
|
} // boost
|
||||||
|
|
||||||
|
#endif // BOOST_DETAIL_SORTED_HPP
|
||||||
|
|
Reference in New Issue
Block a user